mirror of
https://github.com/mapbase-source/source-sdk-2013.git
synced 2025-01-14 15:57:59 +03:00
Added image commentary nodes and better scaling/positioning for the text commentary panel
This commit is contained in:
parent
f67a1b95e5
commit
3ab83ba1c2
@ -20,6 +20,7 @@
|
|||||||
#include "in_buttons.h"
|
#include "in_buttons.h"
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
#include "vgui_controls/Label.h"
|
#include "vgui_controls/Label.h"
|
||||||
|
#include "vgui_controls/ImagePanel.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// memdbgon must be the last include file in a .cpp file!!!
|
// memdbgon must be the last include file in a .cpp file!!!
|
||||||
@ -41,8 +42,9 @@ bool IsInCommentaryMode( void )
|
|||||||
static bool g_bTracingVsCommentaryNodes = false;
|
static bool g_bTracingVsCommentaryNodes = false;
|
||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
ConVar commentary_text_force( "commentary_text_force", "0", FCVAR_NONE, "Forces all commentary nodes to use the text type." );
|
ConVar commentary_type_force( "commentary_type_force", "-1", FCVAR_NONE, "Forces all commentary nodes to use the specified type." );
|
||||||
ConVar commentary_text_endtime( "commentary_text_endtime", "120" );
|
ConVar commentary_type_text_endtime( "commentary_type_text_endtime", "120" );
|
||||||
|
ConVar commentary_type_image_endtime( "commentary_type_image_endtime", "120" );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -62,6 +64,7 @@ public:
|
|||||||
void StartCommentary( C_PointCommentaryNode *pNode, char *pszSpeakers, int iNode, int iNodeMax, float flStartTime, float flEndTime );
|
void StartCommentary( C_PointCommentaryNode *pNode, char *pszSpeakers, int iNode, int iNodeMax, float flStartTime, float flEndTime );
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
void StartTextCommentary( C_PointCommentaryNode *pNode, const char *pszText, char *pszSpeakers, int iNode, int iNodeMax, float flStartTime, float flEndTime );
|
void StartTextCommentary( C_PointCommentaryNode *pNode, const char *pszText, char *pszSpeakers, int iNode, int iNodeMax, float flStartTime, float flEndTime );
|
||||||
|
void StartImageCommentary( C_PointCommentaryNode *pNode, const char *pszImage, char *pszSpeakers, int iNode, int iNodeMax, float flStartTime, float flEndTime );
|
||||||
#endif
|
#endif
|
||||||
void StopCommentary( void );
|
void StopCommentary( void );
|
||||||
bool IsTheActiveNode( C_PointCommentaryNode *pNode ) { return (pNode == m_hActiveNode); }
|
bool IsTheActiveNode( C_PointCommentaryNode *pNode ) { return (pNode == m_hActiveNode); }
|
||||||
@ -69,6 +72,10 @@ public:
|
|||||||
// vgui overrides
|
// vgui overrides
|
||||||
virtual void Paint( void );
|
virtual void Paint( void );
|
||||||
virtual bool ShouldDraw( void );
|
virtual bool ShouldDraw( void );
|
||||||
|
#ifdef MAPBASE
|
||||||
|
virtual void PerformLayout();
|
||||||
|
void ResolveBounds( int width, int height );
|
||||||
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
CHandle<C_PointCommentaryNode> m_hActiveNode;
|
CHandle<C_PointCommentaryNode> m_hActiveNode;
|
||||||
@ -80,9 +87,14 @@ private:
|
|||||||
CMaterialReference m_matIcon;
|
CMaterialReference m_matIcon;
|
||||||
bool m_bHiding;
|
bool m_bHiding;
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
bool m_bTextCommentary; // NOTE: If any more types are needed, use an enum
|
int m_iCommentaryType;
|
||||||
wchar_t *m_pszText;
|
float m_flPanelScale;
|
||||||
|
float m_flOverrideX;
|
||||||
|
float m_flOverrideY;
|
||||||
|
|
||||||
vgui::Label *m_pLabel;
|
vgui::Label *m_pLabel;
|
||||||
|
vgui::ImagePanel *m_pImage;
|
||||||
|
vgui::HFont m_hFont;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Painting
|
// Painting
|
||||||
@ -110,14 +122,16 @@ private:
|
|||||||
CPanelAnimationVarAliasType( int, m_iTypeTextW, "type_text_wide", "400", "proportional_int" );
|
CPanelAnimationVarAliasType( int, m_iTypeTextW, "type_text_wide", "400", "proportional_int" );
|
||||||
CPanelAnimationVarAliasType( int, m_iTypeTextT, "type_text_tall", "200", "proportional_int" );
|
CPanelAnimationVarAliasType( int, m_iTypeTextT, "type_text_tall", "200", "proportional_int" );
|
||||||
CPanelAnimationVarAliasType( int, m_iTypeTextCountXFR, "type_text_count_xpos_from_right", "10", "proportional_int" );
|
CPanelAnimationVarAliasType( int, m_iTypeTextCountXFR, "type_text_count_xpos_from_right", "10", "proportional_int" );
|
||||||
CPanelAnimationVarAliasType( int, m_iTypeTextCountYFB, "type_text_count_ypos_from_bottom", "16", "proportional_int" );
|
CPanelAnimationVarAliasType( int, m_iTypeTextCountYFB, "type_text_count_ypos_from_bottom", "10", "proportional_int" );
|
||||||
CPanelAnimationVar( Color, m_TextBackgroundColor, "type_text_bg", "0 0 0 192" );
|
CPanelAnimationVar( Color, m_TextBackgroundColor, "BackgroundColorTextContent", "0 0 0 192" );
|
||||||
CPanelAnimationVar( Color, m_TextColor, "type_text_fg", "255 230 180 255" );
|
CPanelAnimationVar( Color, m_TypeTextContentColor, "TextContentColor", "255 230 180 255" );
|
||||||
|
CPanelAnimationVar( int, m_iTextBorderSpace, "type_text_border_space", "8" );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
CPanelAnimationVar( bool, m_bUseScriptBGColor, "use_script_bgcolor", "0" );
|
CPanelAnimationVar( bool, m_bUseScriptBGColor, "use_script_bgcolor", "0" );
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
CPanelAnimationVar( Color, m_BackgroundColor, "BackgroundColor", "Panel.BgColor" );
|
CPanelAnimationVar( Color, m_BackgroundColor, "BackgroundColor", "Panel.BgColor" );
|
||||||
|
CPanelAnimationVar( Color, m_ForegroundColor, "ForegroundColor", "255 170 0 255" );
|
||||||
#else
|
#else
|
||||||
CPanelAnimationVar( Color, m_BackgroundColor, "BackgroundColor", "0 0 0 0" );
|
CPanelAnimationVar( Color, m_BackgroundColor, "BackgroundColor", "0 0 0 0" );
|
||||||
#endif
|
#endif
|
||||||
@ -140,6 +154,7 @@ public:
|
|||||||
void StartAudioCommentary( const char *pszCommentaryFile, C_BasePlayer *pPlayer );
|
void StartAudioCommentary( const char *pszCommentaryFile, C_BasePlayer *pPlayer );
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
void StartTextCommentary( const char *pszCommentaryFile, C_BasePlayer *pPlayer );
|
void StartTextCommentary( const char *pszCommentaryFile, C_BasePlayer *pPlayer );
|
||||||
|
void StartImageCommentary( const char *pszCommentaryFile, C_BasePlayer *pPlayer );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void OnRestore( void )
|
void OnRestore( void )
|
||||||
@ -222,7 +237,10 @@ public:
|
|||||||
EHANDLE m_hViewPosition;
|
EHANDLE m_hViewPosition;
|
||||||
bool m_bRestartAfterRestore;
|
bool m_bRestartAfterRestore;
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
bool m_bTextCommentary;
|
int m_iCommentaryType;
|
||||||
|
float m_flPanelScale;
|
||||||
|
float m_flPanelX;
|
||||||
|
float m_flPanelY;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -236,7 +254,10 @@ IMPLEMENT_CLIENTCLASS_DT(C_PointCommentaryNode, DT_PointCommentaryNode, CPointCo
|
|||||||
RecvPropInt( RECVINFO( m_iNodeNumberMax ) ),
|
RecvPropInt( RECVINFO( m_iNodeNumberMax ) ),
|
||||||
RecvPropEHandle( RECVINFO(m_hViewPosition) ),
|
RecvPropEHandle( RECVINFO(m_hViewPosition) ),
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
RecvPropBool( RECVINFO( m_bTextCommentary ) ),
|
RecvPropInt( RECVINFO( m_iCommentaryType ) ),
|
||||||
|
RecvPropFloat( RECVINFO( m_flPanelScale ) ),
|
||||||
|
RecvPropFloat( RECVINFO( m_flPanelX ) ),
|
||||||
|
RecvPropFloat( RECVINFO( m_flPanelY ) ),
|
||||||
#endif
|
#endif
|
||||||
END_RECV_TABLE()
|
END_RECV_TABLE()
|
||||||
|
|
||||||
@ -292,11 +313,28 @@ void C_PointCommentaryNode::OnDataChanged( DataUpdateType_t updateType )
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
if (m_bTextCommentary || commentary_text_force.GetBool())
|
int iCommentaryType = m_iCommentaryType;
|
||||||
|
if (commentary_type_force.GetInt() != -1)
|
||||||
|
iCommentaryType = commentary_type_force.GetInt();
|
||||||
|
|
||||||
|
switch (iCommentaryType)
|
||||||
|
{
|
||||||
|
case COMMENTARY_TYPE_TEXT:
|
||||||
StartTextCommentary( pszCommentaryFile, pPlayer );
|
StartTextCommentary( pszCommentaryFile, pPlayer );
|
||||||
else
|
break;
|
||||||
#endif
|
|
||||||
|
case COMMENTARY_TYPE_IMAGE:
|
||||||
|
StartImageCommentary( pszCommentaryFile, pPlayer );
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
case COMMENTARY_TYPE_AUDIO:
|
||||||
StartAudioCommentary( pszCommentaryFile, pPlayer );
|
StartAudioCommentary( pszCommentaryFile, pPlayer );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
StartAudioCommentary( pszCommentaryFile, pPlayer );
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else if ( m_bWasActive )
|
else if ( m_bWasActive )
|
||||||
{
|
{
|
||||||
@ -381,12 +419,27 @@ void C_PointCommentaryNode::StartTextCommentary( const char *pszCommentaryFile,
|
|||||||
//float flDuration = enginesound->GetSoundDuration( STRING( CSoundEnvelopeController::GetController().SoundGetName( m_sndCommentary ) ) ) ;
|
//float flDuration = enginesound->GetSoundDuration( STRING( CSoundEnvelopeController::GetController().SoundGetName( m_sndCommentary ) ) ) ;
|
||||||
|
|
||||||
// TODO: Determine from text length?
|
// TODO: Determine from text length?
|
||||||
float flDuration = commentary_text_endtime.GetFloat();
|
float flDuration = commentary_type_text_endtime.GetFloat();
|
||||||
|
|
||||||
// Tell the HUD element
|
// Tell the HUD element
|
||||||
CHudCommentary *pHudCommentary = (CHudCommentary *)GET_HUDELEMENT( CHudCommentary );
|
CHudCommentary *pHudCommentary = (CHudCommentary *)GET_HUDELEMENT( CHudCommentary );
|
||||||
pHudCommentary->StartTextCommentary( this, pszCommentaryFile, m_iszSpeakers, m_iNodeNumber, m_iNodeNumberMax, m_flStartTime, m_flStartTime + flDuration );
|
pHudCommentary->StartTextCommentary( this, pszCommentaryFile, m_iszSpeakers, m_iNodeNumber, m_iNodeNumberMax, m_flStartTime, m_flStartTime + flDuration );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void C_PointCommentaryNode::StartImageCommentary( const char *pszCommentaryFile, C_BasePlayer *pPlayer )
|
||||||
|
{
|
||||||
|
// Get the duration so we know when it finishes
|
||||||
|
//float flDuration = enginesound->GetSoundDuration( STRING( CSoundEnvelopeController::GetController().SoundGetName( m_sndCommentary ) ) ) ;
|
||||||
|
|
||||||
|
float flDuration = commentary_type_image_endtime.GetFloat();
|
||||||
|
|
||||||
|
// Tell the HUD element
|
||||||
|
CHudCommentary *pHudCommentary = (CHudCommentary *)GET_HUDELEMENT( CHudCommentary );
|
||||||
|
pHudCommentary->StartImageCommentary( this, pszCommentaryFile, m_iszSpeakers, m_iNodeNumber, m_iNodeNumberMax, m_flStartTime, m_flStartTime + flDuration );
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -454,6 +507,8 @@ CHudCommentary::CHudCommentary( const char *name ) : vgui::Panel( NULL, "HudComm
|
|||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
m_pLabel = new vgui::Label( this, "HudCommentaryTextLabel", "" );
|
m_pLabel = new vgui::Label( this, "HudCommentaryTextLabel", "" );
|
||||||
|
m_pImage = new vgui::ImagePanel( this, "HudCommentaryImagePanel" );
|
||||||
|
m_pImage->SetShouldScaleImage( true );
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -516,60 +571,57 @@ void CHudCommentary::Paint()
|
|||||||
int yOffset = m_iBarY;
|
int yOffset = m_iBarY;
|
||||||
|
|
||||||
// Find our fade based on our time shown
|
// Find our fade based on our time shown
|
||||||
Color clr = Color( 255, 170, 0, GetAlpha() );
|
Color clr = m_ForegroundColor;
|
||||||
|
|
||||||
// Get our scheme and font information
|
|
||||||
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
|
||||||
vgui::HFont hFont = vgui::scheme()->GetIScheme(scheme)->GetFont( "CommentaryDefault" );
|
|
||||||
if ( !hFont )
|
|
||||||
{
|
|
||||||
hFont = vgui::scheme()->GetIScheme(scheme)->GetFont( "Default" );
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
if (m_bTextCommentary)
|
switch (m_iCommentaryType)
|
||||||
|
{
|
||||||
|
case COMMENTARY_TYPE_TEXT:
|
||||||
{
|
{
|
||||||
// TODO: Make this a control?
|
|
||||||
static int iTextBorderSpace = 8;
|
|
||||||
|
|
||||||
// Figure out the size before setting bounds
|
// Figure out the size before setting bounds
|
||||||
int lW, lT;
|
int lW, lT;
|
||||||
m_pLabel->GetContentSize( lW, lT );
|
m_pLabel->GetContentSize( lW, lT );
|
||||||
|
|
||||||
m_pLabel->SetFgColor( m_TextColor );
|
lT += (m_iTextBorderSpace * 2);
|
||||||
m_pLabel->SetBounds(
|
|
||||||
xOffset + iTextBorderSpace,
|
|
||||||
yOffset + iTextBorderSpace,
|
|
||||||
m_iBarWide - iTextBorderSpace,
|
|
||||||
lT /*m_iTypeTextT - ((yOffset * 2) + iTextBorderSpace)*/ );
|
|
||||||
m_pLabel->SetFont( hFont );
|
|
||||||
|
|
||||||
// Draw the speaker names
|
|
||||||
/*vgui::surface()->DrawSetTextFont( hFont );
|
|
||||||
vgui::surface()->DrawSetTextColor( Color( 255, 200, 100, GetAlpha() ) );
|
|
||||||
vgui::surface()->DrawSetTextPos( xOffset+4, yOffset+4 );
|
|
||||||
vgui::surface()->DrawPrintText( m_pszText, wcslen( m_pszText ) );*/
|
|
||||||
|
|
||||||
lT += (iTextBorderSpace * 2);
|
|
||||||
|
|
||||||
vgui::surface()->DrawSetColor( clr );
|
vgui::surface()->DrawSetColor( clr );
|
||||||
vgui::surface()->DrawOutlinedRect( xOffset, yOffset, xOffset + m_iBarWide, yOffset + lT ); //m_iTypeTextT - (yOffset /*+ m_iBarTall*/) );
|
vgui::surface()->DrawOutlinedRect( xOffset, yOffset, xOffset + (m_iBarWide * m_flPanelScale), yOffset + (lT /** m_flPanelScale*/) ); //m_iTypeTextT - (yOffset /*+ m_iBarTall*/) );
|
||||||
|
} break;
|
||||||
|
|
||||||
lT += (yOffset * 2);
|
case COMMENTARY_TYPE_IMAGE:
|
||||||
SetBounds( x, ( (float)m_iTypeTextT * MAX( (200.0f / (float)lT), 1.75f ) ), wide, lT );
|
{
|
||||||
}
|
// Figure out the size before setting bounds
|
||||||
else
|
int iW, iT;
|
||||||
#endif
|
m_pImage->GetSize( iW, iT );
|
||||||
|
//vgui::surface()->DrawGetTextureSize( m_pImage->GetImage()->GetID(), iW, iT );
|
||||||
|
|
||||||
|
iW += (m_iTextBorderSpace * 2);
|
||||||
|
iT += (m_iTextBorderSpace * 2);
|
||||||
|
|
||||||
|
vgui::surface()->DrawSetColor( clr );
|
||||||
|
vgui::surface()->DrawOutlinedRect( xOffset, yOffset, xOffset + iW, yOffset + iT ); //m_iTypeTextT - (yOffset /*+ m_iBarTall*/) );
|
||||||
|
} break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
case COMMENTARY_TYPE_AUDIO:
|
||||||
{
|
{
|
||||||
// Draw the progress bar
|
// Draw the progress bar
|
||||||
vgui::surface()->DrawSetColor( clr );
|
vgui::surface()->DrawSetColor( clr );
|
||||||
vgui::surface()->DrawOutlinedRect( xOffset, yOffset, xOffset+m_iBarWide, yOffset+m_iBarTall );
|
vgui::surface()->DrawOutlinedRect( xOffset, yOffset, xOffset+m_iBarWide, yOffset+m_iBarTall );
|
||||||
vgui::surface()->DrawSetColor( clr );
|
vgui::surface()->DrawSetColor( clr );
|
||||||
vgui::surface()->DrawFilledRect( xOffset+2, yOffset+2, xOffset+(int)(flPercentage*m_iBarWide)-2, yOffset+m_iBarTall-2 );
|
vgui::surface()->DrawFilledRect( xOffset+2, yOffset+2, xOffset+(int)(flPercentage*m_iBarWide)-2, yOffset+m_iBarTall-2 );
|
||||||
|
} break;
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
// Draw the progress bar
|
||||||
|
vgui::surface()->DrawSetColor( clr );
|
||||||
|
vgui::surface()->DrawOutlinedRect( xOffset, yOffset, xOffset+m_iBarWide, yOffset+m_iBarTall );
|
||||||
|
vgui::surface()->DrawSetColor( clr );
|
||||||
|
vgui::surface()->DrawFilledRect( xOffset+2, yOffset+2, xOffset+(int)(flPercentage*m_iBarWide)-2, yOffset+m_iBarTall-2 );
|
||||||
|
#endif
|
||||||
|
|
||||||
// Draw the speaker names
|
// Draw the speaker names
|
||||||
vgui::surface()->DrawSetTextFont( hFont );
|
vgui::surface()->DrawSetTextFont( m_hFont );
|
||||||
vgui::surface()->DrawSetTextColor( clr );
|
vgui::surface()->DrawSetTextColor( clr );
|
||||||
vgui::surface()->DrawSetTextPos( m_iSpeakersX, m_iSpeakersY );
|
vgui::surface()->DrawSetTextPos( m_iSpeakersX, m_iSpeakersY );
|
||||||
vgui::surface()->DrawPrintText( m_szSpeakers, wcslen(m_szSpeakers) );
|
vgui::surface()->DrawPrintText( m_szSpeakers, wcslen(m_szSpeakers) );
|
||||||
@ -592,7 +644,7 @@ void CHudCommentary::Paint()
|
|||||||
{
|
{
|
||||||
int w, h;
|
int w, h;
|
||||||
UTIL_ReplaceKeyBindings( pszText, 0, wzFinal, sizeof( wzFinal ) );
|
UTIL_ReplaceKeyBindings( pszText, 0, wzFinal, sizeof( wzFinal ) );
|
||||||
vgui::surface()->GetTextSize( hFont, wzFinal, w, h );
|
vgui::surface()->GetTextSize( m_hFont, wzFinal, w, h );
|
||||||
vgui::surface()->DrawSetTextPos( m_iBarX + m_iBarWide - w, iY );
|
vgui::surface()->DrawSetTextPos( m_iBarX + m_iBarWide - w, iY );
|
||||||
vgui::surface()->DrawPrintText( wzFinal, wcslen(wzFinal) );
|
vgui::surface()->DrawPrintText( wzFinal, wcslen(wzFinal) );
|
||||||
}
|
}
|
||||||
@ -601,10 +653,10 @@ void CHudCommentary::Paint()
|
|||||||
// Draw the commentary count
|
// Draw the commentary count
|
||||||
// Determine our text size, and move that far in from the right hand size (plus the offset)
|
// Determine our text size, and move that far in from the right hand size (plus the offset)
|
||||||
int iCountWide, iCountTall;
|
int iCountWide, iCountTall;
|
||||||
vgui::surface()->GetTextSize( hFont, m_szCount, iCountWide, iCountTall );
|
vgui::surface()->GetTextSize( m_hFont, m_szCount, iCountWide, iCountTall );
|
||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
if (m_bTextCommentary)
|
if (m_iCommentaryType != COMMENTARY_TYPE_AUDIO)
|
||||||
vgui::surface()->DrawSetTextPos( wide - m_iTypeTextCountXFR - iCountWide, tall - m_iTypeTextCountYFB - iCountTall );
|
vgui::surface()->DrawSetTextPos( wide - m_iTypeTextCountXFR - iCountWide, tall - m_iTypeTextCountYFB - iCountTall );
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
@ -626,6 +678,128 @@ bool CHudCommentary::ShouldDraw()
|
|||||||
return ( m_hActiveNode || GetAlpha() > 0 );
|
return ( m_hActiveNode || GetAlpha() > 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CHudCommentary::PerformLayout()
|
||||||
|
{
|
||||||
|
BaseClass::PerformLayout();
|
||||||
|
|
||||||
|
switch (m_iCommentaryType)
|
||||||
|
{
|
||||||
|
case COMMENTARY_TYPE_TEXT:
|
||||||
|
{
|
||||||
|
int xOffset = m_iBarX;
|
||||||
|
int yOffset = m_iBarY;
|
||||||
|
|
||||||
|
int x, y, wide, tall;
|
||||||
|
GetBounds( x, y, wide, tall );
|
||||||
|
|
||||||
|
// Figure out the size before setting bounds
|
||||||
|
int lW, lT;
|
||||||
|
m_pLabel->GetContentSize( lW, lT );
|
||||||
|
|
||||||
|
lW = (float)(m_iBarWide * m_flPanelScale) - m_iTextBorderSpace;
|
||||||
|
//lT = (float)lT * m_flPanelScale; // Don't affect height when scaling
|
||||||
|
|
||||||
|
m_pLabel->SetBounds(
|
||||||
|
xOffset + m_iTextBorderSpace,
|
||||||
|
yOffset + m_iTextBorderSpace,
|
||||||
|
lW, lT );
|
||||||
|
|
||||||
|
lW += (float)((m_iTextBorderSpace * 2) + (xOffset * 2));
|
||||||
|
lT += (float)((m_iTextBorderSpace * 2) + (yOffset * 2));
|
||||||
|
|
||||||
|
ResolveBounds( lW, lT );
|
||||||
|
} break;
|
||||||
|
|
||||||
|
case COMMENTARY_TYPE_IMAGE:
|
||||||
|
{
|
||||||
|
int xOffset = m_iBarX;
|
||||||
|
int yOffset = m_iBarY;
|
||||||
|
|
||||||
|
// Figure out the size before setting bounds
|
||||||
|
int iW, iT;
|
||||||
|
//m_pImage->GetImage()->GetSize( iW, iT );
|
||||||
|
vgui::surface()->DrawGetTextureSize( m_pImage->GetImage()->GetID(), iW, iT );
|
||||||
|
if (iW <= 0)
|
||||||
|
iW = 1;
|
||||||
|
|
||||||
|
int iTargetSize = (m_iBarWide - m_iTextBorderSpace);
|
||||||
|
iT *= (iTargetSize / iW);
|
||||||
|
iW = iTargetSize;
|
||||||
|
|
||||||
|
iW = (float)iW * m_flPanelScale;
|
||||||
|
iT = (float)iT * m_flPanelScale;
|
||||||
|
|
||||||
|
m_pImage->SetBounds(
|
||||||
|
xOffset + m_iTextBorderSpace,
|
||||||
|
yOffset + m_iTextBorderSpace,
|
||||||
|
iW, iT );
|
||||||
|
|
||||||
|
iW += (float)((m_iTextBorderSpace * 2) + (xOffset * 2));
|
||||||
|
iT += (float)((m_iTextBorderSpace * 2) + (yOffset * 2));
|
||||||
|
|
||||||
|
ResolveBounds( iW, iT );
|
||||||
|
} break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
case COMMENTARY_TYPE_AUDIO:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Resolves position on screen; Heavily borrows from CHudMessage::XPosition/YPosition
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CHudCommentary::ResolveBounds( int width, int height )
|
||||||
|
{
|
||||||
|
int xPos;
|
||||||
|
int yPos;
|
||||||
|
|
||||||
|
// ====== X ======
|
||||||
|
if ( m_flOverrideX == -1 )
|
||||||
|
{
|
||||||
|
xPos = (ScreenWidth() - width) * 0.5f;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( m_flOverrideX < 0 )
|
||||||
|
xPos = (1.0 + m_flOverrideX) * ScreenWidth() - width; // Align to right
|
||||||
|
else
|
||||||
|
xPos = m_flOverrideX * (ScreenWidth() - width);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Clamp to edge of screen
|
||||||
|
if ( xPos + width > ScreenWidth() )
|
||||||
|
xPos = ScreenWidth() - width;
|
||||||
|
else if ( xPos < 0 )
|
||||||
|
xPos = 0;
|
||||||
|
|
||||||
|
// ====== Y ======
|
||||||
|
if ( m_flOverrideY == -1 )
|
||||||
|
{
|
||||||
|
yPos = (ScreenHeight() - height) * 0.5f;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( m_flOverrideY < 0 )
|
||||||
|
yPos = (1.0 + m_flOverrideY) * ScreenHeight() - height; // Align to bottom
|
||||||
|
else
|
||||||
|
yPos = m_flOverrideY * (ScreenHeight() - height);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Clamp to edge of screen
|
||||||
|
if ( yPos + height > ScreenHeight() )
|
||||||
|
yPos = ScreenHeight() - height;
|
||||||
|
else if ( yPos < 0 )
|
||||||
|
yPos = 0;
|
||||||
|
|
||||||
|
SetBounds( xPos, yPos, width, height );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose:
|
// Purpose:
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -660,7 +834,10 @@ void CHudCommentary::StartCommentary( C_PointCommentaryNode *pNode, char *pszSpe
|
|||||||
m_flEndTime = flEndTime;
|
m_flEndTime = flEndTime;
|
||||||
m_bHiding = false;
|
m_bHiding = false;
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
m_bTextCommentary = false;
|
m_iCommentaryType = COMMENTARY_TYPE_AUDIO;
|
||||||
|
m_flPanelScale = pNode->m_flPanelScale;
|
||||||
|
m_flOverrideX = pNode->m_flPanelX;
|
||||||
|
m_flOverrideY = pNode->m_flPanelY;
|
||||||
#endif
|
#endif
|
||||||
g_pVGuiLocalize->ConvertANSIToUnicode( pszSpeakers, m_szSpeakers, sizeof( m_szSpeakers ) );
|
g_pVGuiLocalize->ConvertANSIToUnicode( pszSpeakers, m_szSpeakers, sizeof( m_szSpeakers ) );
|
||||||
|
|
||||||
@ -669,6 +846,16 @@ void CHudCommentary::StartCommentary( C_PointCommentaryNode *pNode, char *pszSpe
|
|||||||
SetBgColor( m_bUseScriptBGColor ? m_BGOverrideColor : m_BackgroundColor );
|
SetBgColor( m_bUseScriptBGColor ? m_BGOverrideColor : m_BackgroundColor );
|
||||||
|
|
||||||
m_pLabel->SetPaintEnabled( false );
|
m_pLabel->SetPaintEnabled( false );
|
||||||
|
m_pImage->SetPaintEnabled( false );
|
||||||
|
m_pImage->EvictImage();
|
||||||
|
|
||||||
|
// Get our scheme and font information
|
||||||
|
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
||||||
|
m_hFont = vgui::scheme()->GetIScheme(scheme)->GetFont( "CommentaryDefault" );
|
||||||
|
if ( !m_hFont )
|
||||||
|
{
|
||||||
|
m_hFont = vgui::scheme()->GetIScheme(scheme)->GetFont( "Default" );
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Don't draw the element itself if closecaptions are on (and captions are always on in non-english mode)
|
// Don't draw the element itself if closecaptions are on (and captions are always on in non-english mode)
|
||||||
@ -712,19 +899,89 @@ void CHudCommentary::StartTextCommentary( C_PointCommentaryNode *pNode, const ch
|
|||||||
m_flStartTime = flStartTime;
|
m_flStartTime = flStartTime;
|
||||||
m_flEndTime = flEndTime;
|
m_flEndTime = flEndTime;
|
||||||
m_bHiding = false;
|
m_bHiding = false;
|
||||||
m_bTextCommentary = true;
|
m_iCommentaryType = COMMENTARY_TYPE_TEXT;
|
||||||
|
m_flPanelScale = pNode->m_flPanelScale;
|
||||||
|
m_flOverrideX = pNode->m_flPanelX;
|
||||||
|
m_flOverrideY = pNode->m_flPanelY;
|
||||||
g_pVGuiLocalize->ConvertANSIToUnicode( pszSpeakers, m_szSpeakers, sizeof( m_szSpeakers ) );
|
g_pVGuiLocalize->ConvertANSIToUnicode( pszSpeakers, m_szSpeakers, sizeof( m_szSpeakers ) );
|
||||||
|
|
||||||
SetBounds( m_iTypeTextX, m_iTypeTextY, m_iTypeTextW, m_iTypeTextT );
|
SetBounds( m_iTypeTextX, m_iTypeTextY, m_iTypeTextW, m_iTypeTextT );
|
||||||
SetBgColor( m_bUseScriptBGColor ? m_BGOverrideColor : m_TextBackgroundColor );
|
SetBgColor( m_bUseScriptBGColor ? m_BGOverrideColor : m_TextBackgroundColor );
|
||||||
|
|
||||||
|
// Get our scheme and font information
|
||||||
|
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
||||||
|
m_hFont = vgui::scheme()->GetIScheme(scheme)->GetFont( "CommentaryDefault" );
|
||||||
|
if ( !m_hFont )
|
||||||
|
{
|
||||||
|
m_hFont = vgui::scheme()->GetIScheme(scheme)->GetFont( "Default" );
|
||||||
|
}
|
||||||
|
|
||||||
m_pLabel->SetText( pszText );
|
m_pLabel->SetText( pszText );
|
||||||
|
m_pLabel->SetFont( m_hFont );
|
||||||
m_pLabel->SetWrap( true );
|
m_pLabel->SetWrap( true );
|
||||||
m_pLabel->SetPaintEnabled( true );
|
m_pLabel->SetPaintEnabled( true );
|
||||||
m_pLabel->SetPaintBackgroundEnabled( false );
|
m_pLabel->SetPaintBackgroundEnabled( false );
|
||||||
m_pLabel->SetPaintBorderEnabled( false );
|
m_pLabel->SetPaintBorderEnabled( false );
|
||||||
//m_pLabel->SizeToContents();
|
//m_pLabel->SizeToContents();
|
||||||
m_pLabel->SetContentAlignment( vgui::Label::a_northwest );
|
m_pLabel->SetContentAlignment( vgui::Label::a_northwest );
|
||||||
|
m_pLabel->SetFgColor( m_TypeTextContentColor );
|
||||||
|
|
||||||
|
m_pImage->SetPaintEnabled( false );
|
||||||
|
m_pImage->EvictImage();
|
||||||
|
|
||||||
|
m_bShouldPaint = true;
|
||||||
|
SetPaintBackgroundEnabled( m_bShouldPaint );
|
||||||
|
|
||||||
|
char sz[MAX_COUNT_STRING];
|
||||||
|
Q_snprintf( sz, sizeof(sz), "%d \\ %d", iNode, iNodeMax );
|
||||||
|
g_pVGuiLocalize->ConvertANSIToUnicode( sz, m_szCount, sizeof(m_szCount) );
|
||||||
|
|
||||||
|
// If the commentary just started, play the commentary fade in.
|
||||||
|
if ( fabs(flStartTime - gpGlobals->curtime) < 1.0 )
|
||||||
|
{
|
||||||
|
g_pClientMode->GetViewportAnimationController()->StartAnimationSequence( "ShowCommentary" );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// We're reloading a savegame that has an active commentary going in it. Don't fade in.
|
||||||
|
SetAlpha( 255 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CHudCommentary::StartImageCommentary( C_PointCommentaryNode *pNode, const char *pszImage, char *pszSpeakers, int iNode, int iNodeMax, float flStartTime, float flEndTime )
|
||||||
|
{
|
||||||
|
if ( (flEndTime - flStartTime) <= 0 )
|
||||||
|
return;
|
||||||
|
|
||||||
|
m_hActiveNode = pNode;
|
||||||
|
m_flStartTime = flStartTime;
|
||||||
|
m_flEndTime = flEndTime;
|
||||||
|
m_bHiding = false;
|
||||||
|
m_iCommentaryType = COMMENTARY_TYPE_IMAGE;
|
||||||
|
m_flPanelScale = pNode->m_flPanelScale;
|
||||||
|
m_flOverrideX = pNode->m_flPanelX;
|
||||||
|
m_flOverrideY = pNode->m_flPanelY;
|
||||||
|
g_pVGuiLocalize->ConvertANSIToUnicode( pszSpeakers, m_szSpeakers, sizeof( m_szSpeakers ) );
|
||||||
|
|
||||||
|
SetBounds( m_iTypeTextX, m_iTypeTextY, m_iTypeTextW, m_iTypeTextT );
|
||||||
|
SetBgColor( m_bUseScriptBGColor ? m_BGOverrideColor : m_TextBackgroundColor );
|
||||||
|
|
||||||
|
m_pLabel->SetPaintEnabled( false );
|
||||||
|
|
||||||
|
m_pImage->SetPaintEnabled( true );
|
||||||
|
m_pImage->SetImage( pszImage );
|
||||||
|
m_pImage->SetWide( m_iBarWide - m_iTextBorderSpace );
|
||||||
|
|
||||||
|
// Get our scheme and font information
|
||||||
|
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
||||||
|
m_hFont = vgui::scheme()->GetIScheme(scheme)->GetFont( "CommentaryDefault" );
|
||||||
|
if ( !m_hFont )
|
||||||
|
{
|
||||||
|
m_hFont = vgui::scheme()->GetIScheme(scheme)->GetFont( "Default" );
|
||||||
|
}
|
||||||
|
|
||||||
m_bShouldPaint = true;
|
m_bShouldPaint = true;
|
||||||
SetPaintBackgroundEnabled( m_bShouldPaint );
|
SetPaintBackgroundEnabled( m_bShouldPaint );
|
||||||
|
@ -74,6 +74,15 @@ public:
|
|||||||
DECLARE_DATADESC();
|
DECLARE_DATADESC();
|
||||||
DECLARE_SERVERCLASS();
|
DECLARE_SERVERCLASS();
|
||||||
|
|
||||||
|
CPointCommentaryNode()
|
||||||
|
{
|
||||||
|
#ifdef MAPBASE
|
||||||
|
m_flPanelScale = 1.0f;
|
||||||
|
m_flPanelX = -1.0f;
|
||||||
|
m_flPanelY = -1.0f;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
void Spawn( void );
|
void Spawn( void );
|
||||||
void Precache( void );
|
void Precache( void );
|
||||||
void Activate( void );
|
void Activate( void );
|
||||||
@ -140,7 +149,10 @@ private:
|
|||||||
CNetworkVar( int, m_iNodeNumberMax );
|
CNetworkVar( int, m_iNodeNumberMax );
|
||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
CNetworkVar( bool, m_bTextCommentary );
|
CNetworkVar( int, m_iCommentaryType );
|
||||||
|
CNetworkVar( float, m_flPanelScale );
|
||||||
|
CNetworkVar( float, m_flPanelX );
|
||||||
|
CNetworkVar( float, m_flPanelY );
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -171,7 +183,10 @@ BEGIN_DATADESC( CPointCommentaryNode )
|
|||||||
DEFINE_KEYFIELD( m_bDisabled, FIELD_BOOLEAN, "start_disabled" ),
|
DEFINE_KEYFIELD( m_bDisabled, FIELD_BOOLEAN, "start_disabled" ),
|
||||||
DEFINE_KEYFIELD( m_vecTeleportOrigin, FIELD_VECTOR, "teleport_origin" ),
|
DEFINE_KEYFIELD( m_vecTeleportOrigin, FIELD_VECTOR, "teleport_origin" ),
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
DEFINE_KEYFIELD( m_bTextCommentary, FIELD_BOOLEAN, "type" ), // Open to additional types in the future
|
DEFINE_KEYFIELD( m_iCommentaryType, FIELD_INTEGER, "type" ),
|
||||||
|
DEFINE_KEYFIELD( m_flPanelScale, FIELD_FLOAT, "panelscale" ),
|
||||||
|
DEFINE_KEYFIELD( m_flPanelX, FIELD_FLOAT, "x" ),
|
||||||
|
DEFINE_KEYFIELD( m_flPanelY, FIELD_FLOAT, "y" ),
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Outputs
|
// Outputs
|
||||||
@ -200,7 +215,10 @@ IMPLEMENT_SERVERCLASS_ST( CPointCommentaryNode, DT_PointCommentaryNode )
|
|||||||
SendPropInt( SENDINFO(m_iNodeNumberMax), 8, SPROP_UNSIGNED ),
|
SendPropInt( SENDINFO(m_iNodeNumberMax), 8, SPROP_UNSIGNED ),
|
||||||
SendPropEHandle( SENDINFO(m_hViewPosition) ),
|
SendPropEHandle( SENDINFO(m_hViewPosition) ),
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
SendPropBool( SENDINFO( m_bTextCommentary ) ),
|
SendPropInt( SENDINFO( m_iCommentaryType ), 2, SPROP_UNSIGNED ),
|
||||||
|
SendPropFloat( SENDINFO( m_flPanelScale ) ),
|
||||||
|
SendPropFloat( SENDINFO( m_flPanelX ) ),
|
||||||
|
SendPropFloat( SENDINFO( m_flPanelY ) ),
|
||||||
#endif
|
#endif
|
||||||
END_SEND_TABLE()
|
END_SEND_TABLE()
|
||||||
|
|
||||||
@ -906,11 +924,24 @@ void CPointCommentaryNode::Spawn( void )
|
|||||||
if (!szModel || !*szModel)
|
if (!szModel || !*szModel)
|
||||||
{
|
{
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
if (m_bTextCommentary)
|
switch (m_iCommentaryType)
|
||||||
|
{
|
||||||
|
case COMMENTARY_TYPE_TEXT:
|
||||||
szModel = "models/extras/info_text.mdl";
|
szModel = "models/extras/info_text.mdl";
|
||||||
else
|
break;
|
||||||
#endif
|
|
||||||
|
case COMMENTARY_TYPE_IMAGE:
|
||||||
|
szModel = "models/extras/info_image.mdl"; // TODO
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
case COMMENTARY_TYPE_AUDIO:
|
||||||
szModel = "models/extras/info_speech.mdl";
|
szModel = "models/extras/info_speech.mdl";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
szModel = "models/extras/info_speech.mdl";
|
||||||
|
#endif
|
||||||
SetModelName( AllocPooledString(szModel) );
|
SetModelName( AllocPooledString(szModel) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1048,4 +1048,15 @@ enum
|
|||||||
};
|
};
|
||||||
#endif // TF_DLL || TF_CLIENT_DLL
|
#endif // TF_DLL || TF_CLIENT_DLL
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// Developer commentary types
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
COMMENTARY_TYPE_AUDIO, // Play commentary audio (default)
|
||||||
|
|
||||||
|
COMMENTARY_TYPE_TEXT, // Display text data
|
||||||
|
COMMENTARY_TYPE_IMAGE, // Display an image
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif // SHAREDDEFS_H
|
#endif // SHAREDDEFS_H
|
||||||
|
Loading…
x
Reference in New Issue
Block a user