diff --git a/code/nel/include/nel/gui/group_html.h b/code/nel/include/nel/gui/group_html.h index 8b8d63c79..6b8212c6e 100644 --- a/code/nel/include/nel/gui/group_html.h +++ b/code/nel/include/nel/gui/group_html.h @@ -77,7 +77,7 @@ namespace NLGUI class CStyleParams { public: - CStyleParams () : TextColor(255,255,255,255) + CStyleParams () : FontFamily(""), TextColor(255,255,255,255) { FontSize=10; FontWeight=400; @@ -92,6 +92,7 @@ namespace NLGUI uint FontSize; uint FontWeight; bool FontOblique; + std::string FontFamily; NLMISC::CRGBA TextColor; bool Underlined; bool StrikeThrough; @@ -508,6 +509,15 @@ namespace NLGUI return _GlobalColor.back(); } + // Current font name + std::vector _FontFamily; + inline const char* getFontFamily() const + { + if (_FontFamily.empty()) + return ""; + return _FontFamily.back().c_str(); + } + // Current font size std::vector _FontSize; inline uint getFontSize() const diff --git a/code/nel/include/nel/gui/view_renderer.h b/code/nel/include/nel/gui/view_renderer.h index 99d92a7cd..6a09a085b 100644 --- a/code/nel/include/nel/gui/view_renderer.h +++ b/code/nel/include/nel/gui/view_renderer.h @@ -600,8 +600,13 @@ namespace NLGUI static CViewRenderer *instance; static NL3D::UDriver *driver; static NL3D::UTextContext *textcontext; + + typedef CHashMap< std::string, NL3D::UTextContext* > TFontsList; + static TFontsList fonts; + public: - static NL3D::UTextContext* getTextContext(){ return textcontext; } + static NL3D::UTextContext* getTextContext(const std::string &name=""); + static bool registerFont(const std::string &name, const std::string &font); /// Set of hw cursor images static std::set< std::string > *hwCursors; diff --git a/code/nel/include/nel/gui/view_text.h b/code/nel/include/nel/gui/view_text.h index c814bcb7b..265935067 100644 --- a/code/nel/include/nel/gui/view_text.h +++ b/code/nel/include/nel/gui/view_text.h @@ -80,6 +80,7 @@ namespace NLGUI /// Set void setText (const ucstring &text); + void setFontName (const std::string &name); void setFontSize (sint nFontSize); void setEmbolden (bool nEmbolden); void setOblique (bool nOblique); @@ -104,6 +105,7 @@ namespace NLGUI ucstring getText() const { return _Text; } sint getFontSize() const; + std::string getFontName() const { return _FontName; } bool getEmbolden() { return _Embolden; } bool getOblique() { return _Oblique; } NLMISC::CRGBA getColor() { return _Color; } @@ -227,6 +229,8 @@ namespace NLGUI uint _Index; /// info on the computed String associated to this text control NL3D::UTextContext::CStringInfo _Info; + /// Font name to get TextContext + std::string _FontName; /// the font size sint _FontSize; bool _Embolden; @@ -322,7 +326,7 @@ namespace NLGUI CFormatInfo Format; public: // build from a string, using the current text context - void build(const ucstring &text, uint numSpaces= 0); + void build(const ucstring &text, NL3D::UTextContext &textContext, uint numSpaces= 0); }; typedef std::vector TWordVect; @@ -333,9 +337,9 @@ namespace NLGUI // ctor CLine(); // Clear the line & remove text contexts - void clear(); + void clear(NL3D::UTextContext &textContext); // Add a new word (and its context) in the line + a number of spaces to append at the end of the line - void addWord(const ucstring &word, uint numSpaces, const CFormatInfo &wordFormat, float fontWidth); + void addWord(const ucstring &word, uint numSpaces, const CFormatInfo &wordFormat, float fontWidth, NL3D::UTextContext &textContext); void addWord(const CWord &word, float fontWidth); uint getNumWords() const { return (uint)_Words.size(); } CWord &getWord(uint index) { return _Words[index]; } diff --git a/code/nel/include/nel/gui/widget_manager.h b/code/nel/include/nel/gui/widget_manager.h index 7566a8ad4..8cca08cc6 100644 --- a/code/nel/include/nel/gui/widget_manager.h +++ b/code/nel/include/nel/gui/widget_manager.h @@ -442,6 +442,7 @@ namespace NLGUI OptionTimeoutMessages, OptionTimeoutContext, OptionTimeoutContextHtml, + OptionMonospaceFont, NumSystemOptions }; diff --git a/code/nel/src/gui/group_html.cpp b/code/nel/src/gui/group_html.cpp index 964610149..00f25ed19 100644 --- a/code/nel/src/gui/group_html.cpp +++ b/code/nel/src/gui/group_html.cpp @@ -1218,6 +1218,7 @@ namespace NLGUI registerAnchorName(MY_HTML_A); CStyleParams style; + style.FontFamily = getFontFamily(); style.FontSize = getFontSize(); style.TextColor = LinkColor; style.Underlined = true; @@ -1226,6 +1227,7 @@ namespace NLGUI if (present[HTML_A_STYLE] && value[HTML_A_STYLE]) getStyleParams(value[HTML_A_STYLE], style); + _FontFamily.push_back(style.FontFamily); _FontSize.push_back(style.FontSize); _TextColor.push_back(style.TextColor); _FontUnderlined.push_back(style.Underlined); @@ -1568,7 +1570,7 @@ namespace NLGUI if (present[MY_HTML_INPUT_ALT] && value[MY_HTML_INPUT_ALT]) tooltip = value[MY_HTML_INPUT_ALT]; - // by default not inherited + // by default not inherited, font family defaults to system font CStyleParams style; style.TextColor = TextColor; style.FontSize = TextFontSize; @@ -1579,6 +1581,7 @@ namespace NLGUI getStyleParams(value[MY_HTML_INPUT_STYLE], style); _TextColor.push_back(style.TextColor); + _FontFamily.push_back(style.FontFamily); _FontSize.push_back(style.FontSize); _FontWeight.push_back(style.FontWeight); _FontOblique.push_back(style.FontOblique); @@ -1794,6 +1797,7 @@ namespace NLGUI } } + popIfNotEmpty(_FontFamily); popIfNotEmpty(_FontSize); popIfNotEmpty(_TextColor); popIfNotEmpty(_FontWeight); @@ -1910,7 +1914,29 @@ namespace NLGUI newParagraph(PBeginSpace); break; case HTML_PRE: - _PRE.push_back(true); + { + CStyleParams style; + style.TextColor = getTextColor(); + style.FontFamily = "monospace"; + style.FontSize = getFontSize(); + style.FontWeight = getFontWeight(); + style.FontOblique = getFontOblique(); + style.Underlined = getFontUnderlined(); + style.StrikeThrough = getFontStrikeThrough(); + + if (present[MY_HTML_SPAN_STYLE] && value[MY_HTML_SPAN_STYLE]) + getStyleParams(value[MY_HTML_SPAN_STYLE], style); + + _TextColor.push_back(style.TextColor); + _FontFamily.push_back(style.FontFamily); + _FontSize.push_back(style.FontSize); + _FontWeight.push_back(style.FontWeight); + _FontOblique.push_back(style.FontOblique); + _FontUnderlined.push_back(style.Underlined); + _FontStrikeThrough.push_back(style.StrikeThrough); + + _PRE.push_back(true); + } break; case HTML_TABLE: { @@ -2039,7 +2065,7 @@ namespace NLGUI // Got one form ? if (!(_Forms.empty())) { - // not inherited by default + // not inherited by default, font family defaults to system font CStyleParams style; style.TextColor = TextColor; style.FontWeight = FONT_WEIGHT_NORMAL; @@ -2050,6 +2076,7 @@ namespace NLGUI getStyleParams(value[MY_HTML_TEXTAREA_STYLE], style); _TextColor.push_back(style.TextColor); + _FontFamily.push_back(style.FontFamily); _FontSize.push_back(style.FontSize); _FontWeight.push_back(style.FontWeight); _FontOblique.push_back(style.FontOblique); @@ -2136,6 +2163,7 @@ namespace NLGUI { CStyleParams style; style.TextColor = getTextColor(); + style.FontFamily = getFontFamily(); style.FontSize = getFontSize(); style.FontWeight = getFontWeight(); style.FontOblique = getFontOblique(); @@ -2146,6 +2174,7 @@ namespace NLGUI getStyleParams(value[MY_HTML_SPAN_STYLE], style); _TextColor.push_back(style.TextColor); + _FontFamily.push_back(style.FontFamily); _FontSize.push_back(style.FontSize); _FontWeight.push_back(style.FontWeight); _FontOblique.push_back(style.FontOblique); @@ -2300,6 +2329,7 @@ namespace NLGUI popIfNotEmpty (_FontSize); break; case HTML_A: + popIfNotEmpty (_FontFamily); popIfNotEmpty (_FontSize); popIfNotEmpty (_TextColor); popIfNotEmpty (_FontUnderlined); @@ -2325,6 +2355,13 @@ namespace NLGUI endParagraph(); break; case HTML_PRE: + popIfNotEmpty (_FontFamily); + popIfNotEmpty (_FontSize); + popIfNotEmpty (_FontWeight); + popIfNotEmpty (_FontOblique); + popIfNotEmpty (_TextColor); + popIfNotEmpty (_FontUnderlined); + popIfNotEmpty (_FontStrikeThrough); popIfNotEmpty (_PRE); break; case HTML_DIV: @@ -2371,6 +2408,7 @@ namespace NLGUI _Forms.back().Entries.push_back (entry); } + popIfNotEmpty (_FontFamily); popIfNotEmpty (_FontSize); popIfNotEmpty (_FontWeight); popIfNotEmpty (_FontOblique); @@ -2537,6 +2575,7 @@ namespace NLGUI } break; case HTML_SPAN: + popIfNotEmpty (_FontFamily); popIfNotEmpty (_FontSize); popIfNotEmpty (_FontWeight); popIfNotEmpty (_FontOblique); @@ -4008,6 +4047,7 @@ namespace NLGUI // Compatible with current parameters ? if (!skipLine && (getTextColor() == _CurrentViewLink->getColor()) && + (getFontFamily() == _CurrentViewLink->getFontName()) && (getFontSize() == (uint)_CurrentViewLink->getFontSize()) && (getFontUnderlined() == _CurrentViewLink->getUnderlined()) && (getFontStrikeThrough() == _CurrentViewLink->getStrikeThrough()) && @@ -4072,6 +4112,7 @@ namespace NLGUI } newLink->setText(tmpStr); newLink->setColor(getTextColor()); + newLink->setFontName(getFontFamily()); newLink->setFontSize(getFontSize()); newLink->setEmbolden(embolden); newLink->setOblique(getFontOblique()); @@ -5762,6 +5803,17 @@ namespace NLGUI style.FontOblique = true; } else + if (it->first == "font-family") + { + if (it->second == "inherit") + style.FontFamily = getFontFamily(); + else + if (it->second == "monospace") + style.FontFamily = "monospace"; + else + style.FontFamily = ""; + } + else if (it->first == "font-weight") { // https://developer.mozilla.org/en-US/docs/Web/CSS/font-weight diff --git a/code/nel/src/gui/view_renderer.cpp b/code/nel/src/gui/view_renderer.cpp index d0bb214b2..5c7403cfc 100644 --- a/code/nel/src/gui/view_renderer.cpp +++ b/code/nel/src/gui/view_renderer.cpp @@ -34,6 +34,7 @@ namespace NLGUI NL3D::UTextContext* CViewRenderer::textcontext = NULL; std::set< std::string >* CViewRenderer::hwCursors = NULL; float CViewRenderer::hwCursorScale = 1.0f; + CViewRenderer::TFontsList CViewRenderer::fonts; CViewRenderer::CViewRenderer() { @@ -264,17 +265,65 @@ namespace NLGUI ite++; } + TFontsList::iterator iteFonts = fonts.begin(); + while (iteFonts != fonts.end()) + { + driver->deleteTextContext(iteFonts->second); + ++iteFonts; + } + _GlobalTextures.clear(); _SImages.clear(); _SImageIterators.clear(); _TextureMap.clear(); _IndexesToTextureIds.clear(); + fonts.clear(); } NL3D::UDriver* CViewRenderer::getDriver(){ return driver; } + // *************************************************************************** + NL3D::UTextContext* CViewRenderer::getTextContext(const std::string &name) + { + if (name.size() > 0 && fonts.count(name) > 0) + return fonts[name]; + + return textcontext; + } + + // *************************************************************************** + bool CViewRenderer::registerFont(const std::string &name, const std::string &font) + { + nlassert(driver != NULL); + + // free existing font + if (fonts.count(name) > 0) + driver->deleteTextContext(fonts[name]); + + std::string fontFile = CPath::lookup(font, false); + if (fontFile.size() == 0) + { + nlwarning("Font file '%s' not found", font.c_str()); + return false; + } + + NL3D::UTextContext *context; + context = driver->createTextContext(fontFile); + if (context == NULL) + { + nlwarning("Cannot create a TextContext with font '%s'.", font.c_str()); + return false; + } + + context->setKeep800x600Ratio(false); + + fonts[name] = context; + + return true; + } + void CViewRenderer::setTextContext(NL3D::UTextContext *textcontext) { CViewRenderer::textcontext = textcontext; diff --git a/code/nel/src/gui/view_text.cpp b/code/nel/src/gui/view_text.cpp index ea0c96ca5..0ff74c963 100644 --- a/code/nel/src/gui/view_text.cpp +++ b/code/nel/src/gui/view_text.cpp @@ -61,6 +61,7 @@ namespace NLGUI _FontSize = 12 + CWidgetManager::getInstance()->getSystemOption( CWidgetManager::OptionAddCoefFont ).getValSInt32(); + _FontName.clear(); _Embolden = false; _Oblique = false; _Color = CRGBA(255,255,255,255); @@ -135,7 +136,7 @@ namespace NLGUI CViewText::~CViewText() { if (_Index != 0xFFFFFFFF) - CViewRenderer::getTextContext()->erase (_Index); + CViewRenderer::getTextContext(_FontName)->erase (_Index); clearLines(); if (!_Setuped) @@ -149,7 +150,7 @@ namespace NLGUI CViewText &CViewText::operator=(const CViewText &vt) { if (_Index != 0xFFFFFFFF) - CViewRenderer::getTextContext()->erase (_Index); + CViewRenderer::getTextContext(_FontName)->erase (_Index); // Create database entries _Active = vt._Active; @@ -961,7 +962,7 @@ namespace NLGUI if (rVR.isMinimized()) return; - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); // *** get current color @@ -986,8 +987,6 @@ namespace NLGUI { if (_Lines.size() == 0) return; - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); - TextContext->setHotSpot (UTextContext::BottomLeft); TextContext->setShaded (_Shadow); TextContext->setShadeOutline (_ShadowOutline); @@ -1258,6 +1257,24 @@ namespace NLGUI _FormatTags.clear(); } + // *************************************************************************** + void CViewText::setFontName(const std::string &name) + { + if (_FontName == name) + return; + + if (_FontName.length() > 0) + { + if (_Index != 0xFFFFFFFF) + CViewRenderer::getTextContext(_FontName)->erase (_Index); + clearLines(); + } + + _FontName = name; + computeFontSize (); + invalidateContent(); + } + // *************************************************************************** void CViewText::setFontSize (sint nFontSize) { @@ -1401,6 +1418,7 @@ namespace NLGUI // *************************************************************************** void CViewText::flushWordInLine(ucstring &ucCurrentWord, bool &linePushed, const CFormatInfo &wordFormat) { + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); // create a new line? if(!linePushed) { @@ -1408,7 +1426,7 @@ namespace NLGUI linePushed= true; } // Append to the last line - _Lines.back()->addWord(ucCurrentWord, 0, wordFormat, _FontWidth); + _Lines.back()->addWord(ucCurrentWord, 0, wordFormat, _FontWidth, *TextContext); // reset the word ucCurrentWord = ucstring(""); } @@ -1444,7 +1462,7 @@ namespace NLGUI rWidthCurrentLine= max(rWidthCurrentLine, (float)wordFormat.TabX*_FontWidth); } - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); // Parse the letter { @@ -1490,6 +1508,7 @@ namespace NLGUI // *************************************************************************** void CViewText::addDontClipWordLine(std::vector &currLine) { + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); // create a new line _Lines.push_back(TLineSPtr(new CLine)); @@ -1504,7 +1523,7 @@ namespace NLGUI if(currLine[i].Format!=lineWordFormat) { // add the current lineWord to the line. - _Lines.back()->addWord(lineWord, 0, lineWordFormat, _FontWidth); + _Lines.back()->addWord(lineWord, 0, lineWordFormat, _FontWidth, *TextContext); // get new lineWordFormat lineWordFormat= currLine[i].Format; // and clear @@ -1519,7 +1538,7 @@ namespace NLGUI } if(!lineWord.empty()) - _Lines.back()->addWord(lineWord, 0, lineWordFormat, _FontWidth); + _Lines.back()->addWord(lineWord, 0, lineWordFormat, _FontWidth, *TextContext); // clear currLine.clear(); @@ -1529,6 +1548,7 @@ namespace NLGUI // *************************************************************************** void CViewText::updateTextContextMultiLineJustified(uint nMaxWidth, bool expandSpaces) { + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); UTextContext::CStringInfo si; // TCharPos currPos = 0; @@ -1622,7 +1642,7 @@ namespace NLGUI // Get the word value. wordValue = _Text.substr(spaceEnd, wordEnd - spaceEnd); // compute width of word - si = CViewRenderer::getTextContext()->getStringInfo(wordValue); + si = TextContext->getStringInfo(wordValue); // compute size of spaces/Tab + word newLineWidth = lineWidth + numSpaces * _SpaceWidth; @@ -1679,7 +1699,7 @@ namespace NLGUI { uint maxNumSpaces = std::max(1U, (uint) (nMaxWidth / _SpaceWidth)); CWord spaceWord; // a word with only spaces in it - spaceWord.build (ucstring (""), maxNumSpaces); + spaceWord.build (ucstring (""), *TextContext, maxNumSpaces); spaceWord.Format= wordFormat; _Lines.push_back(TLineSPtr(new CLine)); _Lines.back()->addWord(spaceWord, _FontWidth); @@ -1701,14 +1721,14 @@ namespace NLGUI for(currChar = 0; currChar < wordValue.length(); ++currChar) { oneChar = wordValue[currChar]; - si = CViewRenderer::getTextContext()->getStringInfo(oneChar); + si = TextContext->getStringInfo(oneChar); if ((uint) (px + si.StringWidth / _Scale) > nMaxWidth) break; px += si.StringWidth / _Scale; } currChar = std::max((uint) 1, currChar); // must fit at least one character otherwise there's an infinite loop wordValue = _Text.substr(spaceEnd, currChar); CWord word; - word.build(wordValue, numSpaces); + word.build(wordValue, *TextContext, numSpaces); word.Format= wordFormat; _Lines.push_back(TLineSPtr(new CLine)); float roomForSpaces = (float) nMaxWidth - word.Info.StringWidth; @@ -1743,7 +1763,7 @@ namespace NLGUI if (!wordValue.empty() || numSpaces != 0) { CWord word; - word.build(wordValue, numSpaces); + word.build(wordValue, *TextContext, numSpaces); word.Format= wordFormat; // update line width _Lines.back()->addWord(word, _FontWidth); @@ -1823,7 +1843,7 @@ namespace NLGUI if (_Scale != CViewRenderer::getInstance()->getInterfaceScale()) computeFontSize(); - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); TextContext->setHotSpot (UTextContext::BottomLeft); TextContext->setShaded (_Shadow); @@ -1857,13 +1877,13 @@ namespace NLGUI { while (_Lines.size() > _MultiMaxLine) { - _Lines.back()->clear(); + _Lines.back()->clear(*TextContext); _Lines.pop_back(); } _Lines.pop_back(); CViewText::CLine *endLine = new CViewText::CLine; CViewText::CWord w; - w.build(string("...")); + w.build(string("..."), *TextContext); endLine->addWord(w, _FontWidth); _Lines.push_back(TLineSPtr(endLine)); } @@ -2153,7 +2173,7 @@ namespace NLGUI void CViewText::getCharacterPositionFromIndex(sint index, bool cursorAtPreviousLineEnd, sint &x, sint &y, sint &height) const { NLMISC::clamp(index, 0, (sint) _Text.length()); - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); TextContext->setHotSpot (UTextContext::BottomLeft); TextContext->setShaded (_Shadow); TextContext->setShadeOutline (_ShadowOutline); @@ -2260,7 +2280,7 @@ namespace NLGUI // *************************************************************************** // Tool fct : From a word and a x coordinate, give the matching character index - static uint getCharacterIndex(const ucstring &textValue, float x) + static uint getCharacterIndex(const ucstring &textValue, float x, NL3D::UTextContext &textContext) { float px = 0.f; float sw; @@ -2271,7 +2291,7 @@ namespace NLGUI { // get character width singleChar[0] = textValue[i]; - si = CViewRenderer::getTextContext()->getStringInfo(singleChar); + si = textContext.getStringInfo(singleChar); sw = si.StringWidth / CViewRenderer::getInstance()->getInterfaceScale(); px += sw / CViewRenderer::getInstance()->getInterfaceScale(); // the character is at the i - 1 position @@ -2289,7 +2309,7 @@ namespace NLGUI // *************************************************************************** void CViewText::getCharacterIndexFromPosition(sint x, sint y, uint &index, bool &cursorAtPreviousLineEnd) const { - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); // setup the text context TextContext->setHotSpot (UTextContext::BottomLeft); @@ -2370,7 +2390,7 @@ namespace NLGUI else { // the coord is in the word itself - index = charPos + currWord.NumSpaces + getCharacterIndex(currWord.Text, (float) x - (px + spacesWidth)); + index = charPos + currWord.NumSpaces + getCharacterIndex(currWord.Text, (float) x - (px + spacesWidth), *TextContext); cursorAtPreviousLineEnd = false; return; } @@ -2395,7 +2415,7 @@ namespace NLGUI index = 0; return; } - index = getCharacterIndex(_Text, (float) x); + index = getCharacterIndex(_Text, (float) x, *TextContext); return; } } @@ -2433,15 +2453,16 @@ namespace NLGUI quadSize--; } // select what quad to skip - CViewRenderer::getTextContext()->setStringSelection(stringId, quadStart, quadSize); + CViewRenderer::getTextContext(_FontName)->setStringSelection(stringId, quadStart, quadSize); } // *************************************************************************** void CViewText::clearLines() { + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); for(uint k = 0; k < _Lines.size(); ++k) { - _Lines[k]->clear(); + _Lines[k]->clear(*TextContext); } _Lines.clear(); } @@ -2495,10 +2516,10 @@ namespace NLGUI } // *************************************************************************** - void CViewText::CLine::addWord(const ucstring &text, uint numSpaces, const CFormatInfo &wordFormat, float fontWidth) + void CViewText::CLine::addWord(const ucstring &text, uint numSpaces, const CFormatInfo &wordFormat, float fontWidth, NL3D::UTextContext &textContext) { CWord word; - word.build(text, numSpaces); + word.build(text, textContext, numSpaces); word.Format= wordFormat; addWord(word, fontWidth); } @@ -2520,12 +2541,12 @@ namespace NLGUI } // *************************************************************************** - void CViewText::CLine::clear() + void CViewText::CLine::clear(NL3D::UTextContext &textContext) { for(uint k = 0; k < _Words.size(); ++k) { if (_Words[k].Index != 0xffffffff) - CViewRenderer::getTextContext()->erase(_Words[k].Index); + textContext.erase(_Words[k].Index); } _Words.clear(); _NumChars = 0; @@ -2542,13 +2563,12 @@ namespace NLGUI } // *************************************************************************** - void CViewText::CWord::build(const ucstring &text, uint numSpaces/*=0*/) + void CViewText::CWord::build(const ucstring &text, NL3D::UTextContext &textContext, uint numSpaces) { Text = text; NumSpaces = numSpaces; - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); - Index = TextContext->textPush(text); - Info = TextContext->getStringInfo(Index); + Index = textContext.textPush(text); + Info = textContext.getStringInfo(Index); Info.StringWidth /= CViewRenderer::getInstance()->getInterfaceScale(); } @@ -2570,7 +2590,7 @@ namespace NLGUI static const ucstring lineFeedStr("\n"); float maxWidth = 0; - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); TextContext->setHotSpot (UTextContext::BottomLeft); TextContext->setShaded (_Shadow); TextContext->setShadeOutline (_ShadowOutline); @@ -2657,7 +2677,7 @@ namespace NLGUI // If we can't clip the words, return the size of the largest word else if ((_TextMode == DontClipWord) || (_TextMode == Justified)) { - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); TextContext->setHotSpot (UTextContext::BottomLeft); TextContext->setShaded (_Shadow); TextContext->setShadeOutline (_ShadowOutline); @@ -2717,7 +2737,7 @@ namespace NLGUI { _Scale = CViewRenderer::getInstance()->getInterfaceScale(); - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); TextContext->setHotSpot (UTextContext::BottomLeft); TextContext->setShaded (_Shadow); TextContext->setShadeOutline (_ShadowOutline); @@ -2735,6 +2755,13 @@ namespace NLGUI // for now we can't know that directly from UTextContext UTextContext::CStringInfo si = TextContext->getStringInfo(chars); + + // font generator changes unknown glyphs to dot '.'. use fallback if it looks odd + if (_FontSize > (si.StringHeight + si.StringLine)) + { + chars.fromUtf8("|"); + si = TextContext->getStringInfo(chars); + } // add a padding of 1 pixel else the top will be truncated _FontHeight = (si.StringHeight / _Scale) + 1; _FontLegHeight = si.StringLine / _Scale; @@ -3089,7 +3116,7 @@ namespace NLGUI } // convert in ULetterColors - NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(); + NL3D::UTextContext *TextContext = CViewRenderer::getTextContext(_FontName); ULetterColors * letterColors = TextContext->createLetterColors(); for(uint i=0; igetValue("messages_timeout"); _SystemOptions[OptionTimeoutContext]= opt->getValue("context_timeout"); _SystemOptions[OptionTimeoutContextHtml]= opt->getValue("context_html_timeout"); + _SystemOptions[OptionMonospaceFont]= opt->getValue("monospace_font"); } } diff --git a/code/ryzom/client/data/gamedev/interfaces_v3/config.xml b/code/ryzom/client/data/gamedev/interfaces_v3/config.xml index 5d5e9143b..b74fa9e8b 100644 --- a/code/ryzom/client/data/gamedev/interfaces_v3/config.xml +++ b/code/ryzom/client/data/gamedev/interfaces_v3/config.xml @@ -1916,6 +1916,8 @@ This MUST follow the Enum MISSION_DESC::TIconId value="basic.ttf" /> --> + --> + --> + --> + getSystemOption (CWidgetManager::OptionMonospaceFont).getValStr(); + if ((!sFont.empty()) && (Driver != NULL)) + CViewRenderer::registerFont("monospace", sFont); } // ------------------------------------------------------------------------------------------------