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

Fix UI glitch due slots recreation & repositioning

This commit is contained in:
Ivan Savenko 2024-06-04 14:41:33 +00:00
parent 106a3b6c8e
commit b92f0c5619

View File

@ -542,42 +542,34 @@ void CGarrisonInt::addSplitBtn(std::shared_ptr<CButton> button)
void CGarrisonInt::createSlots() void CGarrisonInt::createSlots()
{ {
availableSlots.clear();
int distance = interx + (smallIcons ? 32 : 58); int distance = interx + (smallIcons ? 32 : 58);
for(auto i : { EGarrisonType::UPPER, EGarrisonType::LOWER }) for(auto i : { EGarrisonType::UPPER, EGarrisonType::LOWER })
{ {
Point offset = garOffset * static_cast<int>(i); Point offset = garOffset * static_cast<int>(i);
std::vector<std::shared_ptr<CGarrisonSlot>> garrisonSlots;
garrisonSlots.resize(7);
if(army(i))
{
for(auto & elem : army(i)->Slots())
{
garrisonSlots[elem.first.getNum()] = std::make_shared<CGarrisonSlot>(this, offset.x + (elem.first.getNum()*distance), offset.y, elem.first, i, elem.second);
}
}
for(int j = 0; j < 7; j++) for(int j = 0; j < 7; j++)
{ {
if(!garrisonSlots[j]) Point position(offset.x + (j*distance), offset.y);
garrisonSlots[j] = std::make_shared<CGarrisonSlot>(this, offset.x + (j*distance), offset.y, SlotID(j), i, nullptr);
if(layout == ESlotsLayout::TWO_ROWS && j >= 4) if(layout == ESlotsLayout::TWO_ROWS && j >= 4)
{ {
garrisonSlots[j]->moveBy(Point(-126, 37)); position += Point(-126, 37);
} }
else if(layout == ESlotsLayout::REVERSED_TWO_ROWS) else if(layout == ESlotsLayout::REVERSED_TWO_ROWS)
{ {
if(j >= 3) if(j >= 3)
{ {
garrisonSlots[j]->moveBy(Point(-90, 49)); position += Point(-90, 49);
} }
else else
{ {
garrisonSlots[j]->moveBy(Point(36, 0)); position += Point(36, 0);
} }
} }
SlotID slot(j);
availableSlots.push_back(std::make_shared<CGarrisonSlot>(this, position.x, position.y, slot, i, army(i) ? army(i)->getStackPtr(slot) : nullptr));
} }
vstd::concatenate(availableSlots, garrisonSlots);
} }
} }