1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-26 03:52:01 +02:00

Merge pull request #1690 from rilian-la-te/fixup-infobars

Fix yellow text rendering.
This commit is contained in:
Ivan Savenko 2023-03-16 14:47:43 +02:00 committed by GitHub
commit dc926aac03
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 11 additions and 5 deletions

View File

@ -401,11 +401,11 @@ void CInfoBar::prepareComponents(const std::vector<Component> & components, std:
// Order matters - priority form should be chosen first // Order matters - priority form should be chosen first
if(imageH + textH < CInfoBar::data_height) if(imageH + textH < CInfoBar::data_height)
pushComponents(components, message, textH, false, timer); pushComponents(components, message, textH, false, timer);
else if(!imageH && tinyH < CInfoBar::data_height) else if(imageH + tinyH < CInfoBar::data_height)
pushComponents(components, message, tinyH, true, timer); pushComponents(components, message, tinyH, true, timer);
else if(imageH + headerH < CInfoBar::data_height) else if(imageH + headerH < CInfoBar::data_height)
pushComponents(components, header, headerH, false, timer); pushComponents(components, header, headerH, false, timer);
else if(imageH + headerTinyH < CInfoBar::data_height - 2 * CInfoBar::offset) else if(imageH + headerTinyH < CInfoBar::data_height)
pushComponents(components, header, headerTinyH, true, timer); pushComponents(components, header, headerTinyH, true, timer);
else else
pushComponents(components, "", 0, false, timer); pushComponents(components, "", 0, false, timer);

View File

@ -140,6 +140,13 @@ void CTextContainer::blitLine(SDL_Surface * to, Rect destRect, std::string what)
{ {
const auto f = graphics->fonts[font]; const auto f = graphics->fonts[font];
Point where = destRect.topLeft(); Point where = destRect.topLeft();
const std::string delimeters = "{}";
auto delimitersCount = std::count_if(what.cbegin(), what.cend(), [&delimeters](char c)
{
return delimeters.find(c) != std::string::npos;
});
//We should count delimiters length from string to correct centering later.
delimitersCount *= f->getStringWidth(delimeters)/2;
// input is rect in which given text should be placed // input is rect in which given text should be placed
// calculate proper position for top-left corner of the text // calculate proper position for top-left corner of the text
@ -151,18 +158,17 @@ void CTextContainer::blitLine(SDL_Surface * to, Rect destRect, std::string what)
if(alignment == ETextAlignment::CENTER) if(alignment == ETextAlignment::CENTER)
{ {
where.x += (int(destRect.w) - int(f->getStringWidth(what))) / 2; where.x += (int(destRect.w) - int(f->getStringWidth(what) - delimitersCount)) / 2;
where.y += (int(destRect.h) - int(f->getLineHeight())) / 2; where.y += (int(destRect.h) - int(f->getLineHeight())) / 2;
} }
if(alignment == ETextAlignment::BOTTOMRIGHT) if(alignment == ETextAlignment::BOTTOMRIGHT)
{ {
where.x += getBorderSize().x + destRect.w - (int)f->getStringWidth(what); where.x += getBorderSize().x + destRect.w - ((int)f->getStringWidth(what) - delimitersCount);
where.y += getBorderSize().y + destRect.h - (int)f->getLineHeight(); where.y += getBorderSize().y + destRect.h - (int)f->getLineHeight();
} }
size_t begin = 0; size_t begin = 0;
std::string delimeters = "{}";
size_t currDelimeter = 0; size_t currDelimeter = 0;
do do