311 lines
7 KiB
C++
311 lines
7 KiB
C++
|
//========= 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();
|
||
|
}
|