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:
commit
dc926aac03
@ -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);
|
||||||
|
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user