From c3e08ced5274604502c9c476006645f64b5ea516 Mon Sep 17 00:00:00 2001 From: Tim Angus Date: Mon, 6 Dec 2010 23:27:56 +0000 Subject: * Mild performance improvements to callees of Item_Text_Wrap --- src/ui/ui_main.c | 7 +++-- src/ui/ui_shared.c | 79 +++++++++++++++++++++++++++++++----------------------- src/ui/ui_shared.h | 2 ++ 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; -- cgit