//========= Copyright Valve Corporation, All rights reserved. ============// // // Purpose: // // $NoKeywords: $ //=============================================================================// #include <mxtk/mx.h> #include "mxStatusWindow.h" #include "hlfaceposer.h" #include "choreowidgetdrawhelper.h" #include "MDLViewer.h" #include "faceposertoolwindow.h" extern double realtime; mxStatusWindow *g_pStatusWindow = NULL; #define STATUS_SCROLLBAR_SIZE 12 #define STATUS_FONT_SIZE 9 mxStatusWindow::mxStatusWindow(mxWindow *parent, int x, int y, int w, int h, const char *label /*= 0*/ ) : mxWindow( parent, x, y, w, h, label ), IFacePoserToolWindow( "Status Window", "Output" ), m_pScrollbar(NULL) { for ( int i = 0; i < MAX_TEXT_LINES; i++ ) { m_rgTextLines[ i ].m_szText[ 0 ] = 0; m_rgTextLines[ i ].rgb = CONSOLE_COLOR; m_rgTextLines[ i ].curtime = 0; } m_nCurrentLine = 0; m_pScrollbar = new mxScrollbar( this, 0, 0, STATUS_SCROLLBAR_SIZE, 100, IDC_STATUS_SCROLL, mxScrollbar::Vertical ); m_pScrollbar->setRange( 0, 1000 ); m_pScrollbar->setPagesize( 100 ); } mxStatusWindow::~mxStatusWindow() { g_pStatusWindow = NULL; } void mxStatusWindow::redraw() { // if ( !ToolCanDraw() ) // return; if ( !m_pScrollbar ) return; CChoreoWidgetDrawHelper helper( this, RGB( 0, 0, 0 ) ); HandleToolRedraw( helper ); RECT rc; helper.GetClientRect( rc ); RECT rcText = rc; int lineheight = ( STATUS_FONT_SIZE + 2 ); InflateRect( &rcText, -4, 0 ); rcText.bottom = h2() - 4; rcText.top = rcText.bottom - lineheight; //int minval = m_pScrollbar->getMinValue(); int maxval = m_pScrollbar->getMaxValue(); int pagesize = m_pScrollbar->getPagesize(); int curval = m_pScrollbar->getValue(); int offset = ( maxval - pagesize ) - curval; offset = ( offset + lineheight - 1 ) / lineheight; offset = max( 0, offset ); //offset = 0; //offset += 10; //offset = max( 0, offset ); for ( int i = 0; i < MAX_TEXT_LINES - offset; i++ ) { int rawline = m_nCurrentLine - i - 1; if ( rawline <= 0 ) continue; if ( rcText.bottom < 0 ) break; int line = ( rawline - offset ) & TEXT_LINE_MASK; char *ptext = m_rgTextLines[ line ].m_szText; RECT rcTime = rcText; rcTime.right = rcTime.left + 50; char sz[ 32 ]; sprintf( sz, "%.3f", m_rgTextLines[ line ].curtime ); int len = helper.CalcTextWidth( "Arial", STATUS_FONT_SIZE, FW_NORMAL, sz ); rcTime.left = rcTime.right - len - 5; helper.DrawColoredText( "Arial", STATUS_FONT_SIZE, FW_NORMAL, RGB( 255, 255, 150 ), rcTime, sz ); rcTime = rcText; rcTime.left += 50; helper.DrawColoredText( "Arial", STATUS_FONT_SIZE, FW_NORMAL, m_rgTextLines[ line ].rgb, rcTime, ptext ); OffsetRect( &rcText, 0, -lineheight ); } DrawActiveTool(); } //----------------------------------------------------------------------------- // Purpose: // Output : Returns true on success, false on failure. //----------------------------------------------------------------------------- bool mxStatusWindow::PaintBackground( void ) { redraw(); return false; } void mxStatusWindow::StatusPrint( COLORREF clr, bool overwrite, const char *text ) { float curtime = (float)Plat_FloatTime(); char sz[32]; sprintf( sz, "%.3f ", curtime ); OutputDebugString( sz ); OutputDebugString( text ); char fixedtext[ 512 ]; char *in, *out; in = (char *)text; out = fixedtext; int c = 0; while ( *in && c < 511 ) { if ( *in == '\n' || *in == '\r' ) { in++; } else { *out++ = *in++; c++; } } *out = 0; if ( overwrite ) { m_nCurrentLine--; } int i = m_nCurrentLine & TEXT_LINE_MASK; strncpy( m_rgTextLines[ i ].m_szText, fixedtext, 511 ); m_rgTextLines[ i ].m_szText[ 511 ] = 0; m_rgTextLines[ i ].rgb = clr; m_rgTextLines[ i ].curtime = curtime; m_nCurrentLine++; if ( m_nCurrentLine <= MAX_TEXT_LINES ) { PositionSliders( 0 ); } m_pScrollbar->setValue( m_pScrollbar->getMaxValue() ); redraw(); } //----------------------------------------------------------------------------- // Purpose: // Input : sboffset - //----------------------------------------------------------------------------- void mxStatusWindow::PositionSliders( int sboffset ) { int lineheight = ( STATUS_FONT_SIZE + 2 ); int linesused = min( (int)MAX_TEXT_LINES, m_nCurrentLine ); linesused = max( linesused, 1 ); int trueh = h2() - GetCaptionHeight(); int vpixelsneeded = max( linesused * lineheight, trueh ); m_pScrollbar->setVisible( linesused * lineheight > trueh ); m_pScrollbar->setPagesize( trueh ); m_pScrollbar->setRange( 0, vpixelsneeded ); redraw(); } //----------------------------------------------------------------------------- // Purpose: // Input : *event - // Output : int //----------------------------------------------------------------------------- int mxStatusWindow::handleEvent( mxEvent *event ) { int iret = 0; if ( HandleToolEvent( event ) ) { return iret; } switch ( event->event ) { default: break; case mxEvent::Size: { m_pScrollbar->setBounds( w2() - STATUS_SCROLLBAR_SIZE, GetCaptionHeight(), STATUS_SCROLLBAR_SIZE, h2()-GetCaptionHeight() ); PositionSliders( 0 ); m_pScrollbar->setValue( m_pScrollbar->getMaxValue() ); iret = 1; } break; case mxEvent::Action: { iret = 1; switch ( event->action ) { default: iret = 0; break; case IDC_STATUS_SCROLL: { if ( event->event == mxEvent::Action && event->modifiers == SB_THUMBTRACK) { int offset = event->height; m_pScrollbar->setValue( offset ); PositionSliders( offset ); DrawActiveTool(); } } break; } } break; } return iret; } #include "StudioModel.h" #include "faceposer_models.h" //----------------------------------------------------------------------------- // Purpose: //----------------------------------------------------------------------------- void mxStatusWindow::DrawActiveTool() { RECT rcTool; rcTool.left = 0; rcTool.top = GetCaptionHeight() + 2; rcTool.bottom = h2(); rcTool.right = w2() - 16; rcTool.bottom = rcTool.top + 10; rcTool.left = rcTool.right - 500; char sz[ 256 ]; IFacePoserToolWindow *activeTool = IFacePoserToolWindow::GetActiveTool(); static float lastrealtime = 0.0f; float dt = (float)realtime - lastrealtime; dt = clamp( dt, 0.0f, 1.0f ); float fps = 0.0f; if ( dt > 0.0001f ) { fps = 1.0f / dt; } sprintf( sz, "%s (%i) at %.3f (%.2f fps) (soundcount %i)", activeTool ? activeTool->GetToolName() : "None", g_MDLViewer->GetCurrentFrame(), (float)realtime, fps, models->CountActiveSources() ); lastrealtime = realtime; int len = CChoreoWidgetDrawHelper::CalcTextWidth( "Courier New", 10, FW_NORMAL, sz ); CChoreoWidgetDrawHelper helper( this, rcTool, RGB( 32, 0, 0 ) ); rcTool.left = rcTool.right - len - 15; helper.DrawColoredText( "Courier New", 10, FW_NORMAL, RGB( 255, 255, 200 ), rcTool, sz ); } //----------------------------------------------------------------------------- // Purpose: // Input : dt - //----------------------------------------------------------------------------- void mxStatusWindow::Think( float dt ) { DrawActiveTool(); }