summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTim Angus <tim@ngus.net>2010-12-06 23:27:56 +0000
committerTim Angus <tim@ngus.net>2013-01-03 00:17:44 +0000
commitc3e08ced5274604502c9c476006645f64b5ea516 (patch)
tree5c6464d5ac2c4c5592ae29c2ef5034819bf5924f
parent1af0b33c17bfc7b3e42aa08cba1db6c17f12343b (diff)
* Mild performance improvements to callees of Item_Text_Wrap
-rw-r--r--src/ui/ui_main.c7
-rw-r--r--src/ui/ui_shared.c79
-rw-r--r--src/ui/ui_shared.h2
3 files changed, 52 insertions, 36 deletions
diff --git a/src/ui/ui_main.c b/src/ui/ui_main.c
index f581e944..158bebbd 100644
--- a/src/ui/ui_main.c
+++ b/src/ui/ui_main.c
@@ -116,8 +116,8 @@ static cvarTable_t cvarTable[ ] =
{ &ui_lastServerRefresh_1, "ui_lastServerRefresh_1_time", "", CVAR_ARCHIVE},
{ &ui_lastServerRefresh_2, "ui_lastServerRefresh_2_time", "", CVAR_ARCHIVE},
{ &ui_lastServerRefresh_3, "ui_lastServerRefresh_3_time", "", CVAR_ARCHIVE},
- { &ui_smallFont, "ui_smallFont", "0.2", CVAR_ARCHIVE},
- { &ui_bigFont, "ui_bigFont", "0.5", CVAR_ARCHIVE},
+ { &ui_smallFont, "ui_smallFont", "0.2", CVAR_ARCHIVE | CVAR_LATCH },
+ { &ui_bigFont, "ui_bigFont", "0.5", CVAR_ARCHIVE | CVAR_LATCH },
{ &ui_findPlayer, "ui_findPlayer", "", CVAR_ARCHIVE},
{ &ui_serverStatusTimeOut, "ui_serverStatusTimeOut", "7000", CVAR_ARCHIVE},
{ &ui_textWrapCache, "ui_textWrapCache", "1", CVAR_ARCHIVE },
@@ -4051,6 +4051,9 @@ void UI_Init( qboolean inGameLoad )
uiInfo.uiDC.aspectScale = ( ( 640.0f * uiInfo.uiDC.glconfig.vidHeight ) /
( 480.0f * uiInfo.uiDC.glconfig.vidWidth ) );
+ uiInfo.uiDC.smallFontScale = trap_Cvar_VariableValue( "ui_smallFont" );
+ uiInfo.uiDC.bigFontScale = trap_Cvar_VariableValue( "ui_bigFont" );
+
uiInfo.uiDC.registerShaderNoMip = &trap_R_RegisterShaderNoMip;
uiInfo.uiDC.setColor = &UI_SetColor;
uiInfo.uiDC.drawHandlePic = &UI_DrawHandlePic;
diff --git a/src/ui/ui_shared.c b/src/ui/ui_shared.c
index 1fbee153..b03313be 100644
--- a/src/ui/ui_shared.c
+++ b/src/ui/ui_shared.c
@@ -1858,6 +1858,16 @@ void Script_playLooped( itemDef_t *item, char **args )
}
}
+static ID_INLINE float UI_EmoticonHeight( fontInfo_t *font, float scale )
+{
+ return font->glyphs[ (int)'[' ].height * scale * font->glyphScale;
+}
+
+static ID_INLINE float UI_EmoticonWidth( fontInfo_t *font, float scale )
+{
+ return UI_EmoticonHeight( font, scale ) * DC->aspectScale;
+}
+
void UI_EscapeEmoticons( char *dest, const char *src, int destsize )
{
int len;
@@ -1927,12 +1937,11 @@ qboolean UI_Text_IsEmoticon( const char *s, qboolean *escaped,
static float UI_Parse_Indent( const char **text )
{
- char indentWidth[ MAX_STRING_CHARS ];
- char *p = indentWidth;
- int numChars;
- float pixels;
-
- Q_strncpyz( indentWidth, *text, MAX_STRING_CHARS );
+ char indentWidth[ 32 ];
+ char *indentWidthPtr;
+ const char *p = *text;
+ int numDigits;
+ float pixels;
while( isdigit( *p ) || *p == '.' )
p++;
@@ -1940,18 +1949,34 @@ static float UI_Parse_Indent( const char **text )
if( *p != INDENT_MARKER )
return 0.0f;
- *p++ = '\0';
- numChars = ( p - indentWidth );
- p = indentWidth;
+ numDigits = ( p - *text );
+
+ if( numDigits > sizeof( indentWidth ) - 1 )
+ return 0.0f;
+
+ strncpy( indentWidth, *text, numDigits );
+
+ indentWidth[ numDigits ] = '\0';
+ indentWidthPtr = indentWidth;
- if( !Float_Parse( &p, &pixels ) )
+ if( !Float_Parse( &indentWidthPtr, &pixels ) )
return 0.0f;
- (*text) += numChars;
+ (*text) += ( numDigits + 1 );
return pixels;
}
+static ID_INLINE fontInfo_t *UI_FontForScale( float scale )
+{
+ if( scale <= DC->smallFontScale )
+ return &DC->Assets.smallFont;
+ else if( scale >= DC->bigFontScale )
+ return &DC->Assets.bigFont;
+ else
+ return &DC->Assets.textFont;
+}
+
float UI_Text_Width( const char *text, float scale, int limit )
{
int count;
@@ -1959,7 +1984,7 @@ float UI_Text_Width( const char *text, float scale, int limit )
glyphInfo_t *glyph;
float useScale;
const char *s = text;
- fontInfo_t *font = &DC->Assets.textFont;
+ fontInfo_t *font = UI_FontForScale( scale );
int emoticonLen;
qboolean emoticonEscaped;
float emoticonW;
@@ -1967,13 +1992,8 @@ float UI_Text_Width( const char *text, float scale, int limit )
int emoticons = 0;
float indentWidth = 0.0f;
- if( scale <= DC->getCVarValue( "ui_smallFont" ) )
- font = &DC->Assets.smallFont;
- else if( scale >= DC->getCVarValue( "ui_bigFont" ) )
- font = &DC->Assets.bigFont;
-
useScale = scale * font->glyphScale;
- emoticonW = UI_Text_Height( "[", scale, 0 ) * DC->aspectScale;
+ emoticonW = UI_EmoticonWidth( font, scale );
out = 0;
if( text )
@@ -2027,12 +2047,7 @@ float UI_Text_Height( const char *text, float scale, int limit )
glyphInfo_t *glyph;
float useScale;
const char *s = text;
- fontInfo_t *font = &DC->Assets.textFont;
-
- if( scale <= DC->getCVarValue( "ui_smallFont" ) )
- font = &DC->Assets.smallFont;
- else if( scale >= DC->getCVarValue( "ui_bigFont" ) )
- font = &DC->Assets.bigFont;
+ fontInfo_t *font = UI_FontForScale( scale );
useScale = scale * font->glyphScale;
max = 0;
@@ -2163,7 +2178,7 @@ static void UI_Text_Paint_Generic( float x, float y, float scale, float gapAdjus
int len;
int count = 0;
vec4_t newColor;
- fontInfo_t *font = &DC->Assets.textFont;
+ fontInfo_t *font = UI_FontForScale( scale );
glyphInfo_t *glyph;
float useScale;
qhandle_t emoticonHandle = 0;
@@ -2176,15 +2191,10 @@ static void UI_Text_Paint_Generic( float x, float y, float scale, float gapAdjus
if( !text )
return;
- if( scale <= DC->getCVarValue( "ui_smallFont" ) )
- font = &DC->Assets.smallFont;
- else if( scale >= DC->getCVarValue( "ui_bigFont" ) )
- font = &DC->Assets.bigFont;
-
useScale = scale * font->glyphScale;
- emoticonH = font->glyphs[ (int)'[' ].height * useScale;
- emoticonW = emoticonH * DC->aspectScale;
+ emoticonH = UI_EmoticonHeight( font, scale );
+ emoticonW = UI_EmoticonWidth( font, scale );
len = strlen( text );
if( limit > 0 && len > limit )
@@ -4324,6 +4334,7 @@ const char *Item_Text_Wrap( const char *text, float scale, float width )
while( *p )
{
+ int pLength = strlen( p );
eol = p;
q = p + 1;
testLength = 0;
@@ -4338,9 +4349,9 @@ const char *Item_Text_Wrap( const char *text, float scale, float width )
qboolean previousCharIsSpace = qfalse;
// Remaining string is too short to wrap
- if( testLength >= strlen( p ) )
+ if( testLength >= pLength )
{
- eol = p + strlen( p );
+ eol = p + pLength;
break;
}
diff --git a/src/ui/ui_shared.h b/src/ui/ui_shared.h
index 154325dd..ab7336de 100644
--- a/src/ui/ui_shared.h
+++ b/src/ui/ui_shared.h
@@ -451,6 +451,8 @@ typedef struct
int frameTime;
float cursorx;
float cursory;
+ float smallFontScale;
+ float bigFontScale;
qboolean debug;
cachedAssets_t Assets;