浏览代码

add color frames; remove scrollbar

Laserlicht 11 月之前
父节点
当前提交
3038e5140a
共有 3 个文件被更改,包括 36 次插入6 次删除
  1. 二进制
      Mods/vcmi/Data/stackWindow/bonus-effects-noscroll.png
  2. 32 5
      client/windows/CCreatureWindow.cpp
  3. 4 1
      client/windows/CCreatureWindow.h

二进制
Mods/vcmi/Data/stackWindow/bonus-effects-noscroll.png


+ 32 - 5
client/windows/CCreatureWindow.cpp

@@ -22,6 +22,7 @@
 #include "../widgets/Images.h"
 #include "../widgets/TextControls.h"
 #include "../widgets/ObjectLists.h"
+#include "../widgets/GraphicalPrimitiveCanvas.h"
 #include "../windows/InfoWindows.h"
 #include "../gui/CGuiHandler.h"
 #include "../gui/Shortcut.h"
@@ -239,8 +240,8 @@ CStackWindow::ActiveSpellsSection::ActiveSpellsSection(CStackWindow * owner, int
 	}
 }
 
-CStackWindow::BonusLineSection::BonusLineSection(CStackWindow * owner, size_t lineIndex)
-	: CWindowSection(owner, ImagePath::builtin("stackWindow/bonus-effects"), 0)
+CStackWindow::BonusLineSection::BonusLineSection(CStackWindow * owner, size_t lineIndex, bool noScroll)
+	: CWindowSection(owner, ImagePath::builtin(noScroll ? "stackWindow/bonus-effects-noscroll" : "stackWindow/bonus-effects"), 0)
 {
 	OBJECT_CONSTRUCTION;
 
@@ -261,6 +262,31 @@ CStackWindow::BonusLineSection::BonusLineSection(CStackWindow * owner, size_t li
 			icon[leftRight] = std::make_shared<CPicture>(bi.imagePath, position.x, position.y);
 			name[leftRight] = std::make_shared<CLabel>(position.x + 60, position.y + 2, FONT_SMALL, ETextAlignment::TOPLEFT, Colors::WHITE, bi.name);
 			description[leftRight] = std::make_shared<CMultiLineLabel>(Rect(position.x + 60, position.y + 17, 137, 30), FONT_SMALL, ETextAlignment::TOPLEFT, Colors::WHITE, bi.description);
+
+			std::map<BonusSource, ColorRGBA> bonusColors = {
+				{BonusSource::ARTIFACT,          ColorRGBA(255, 0, 0)},
+				{BonusSource::ARTIFACT_INSTANCE, ColorRGBA(255, 0, 0)},
+				{BonusSource::OBJECT_TYPE,       ColorRGBA(255, 0, 0)},
+				{BonusSource::OBJECT_INSTANCE,   ColorRGBA(255, 0, 0)},
+				{BonusSource::CREATURE_ABILITY,  ColorRGBA(255, 0, 0)},
+				{BonusSource::TERRAIN_NATIVE,    ColorRGBA(255, 0, 0)},
+				{BonusSource::TERRAIN_OVERLAY,   ColorRGBA(255, 0, 0)},
+				{BonusSource::SPELL_EFFECT,      ColorRGBA(255, 0, 0)},
+				{BonusSource::TOWN_STRUCTURE,    ColorRGBA(255, 0, 0)},
+				{BonusSource::HERO_BASE_SKILL,   ColorRGBA(255, 0, 0)},
+				{BonusSource::SECONDARY_SKILL,   ColorRGBA(0, 0, 255)},
+				{BonusSource::HERO_SPECIAL,      ColorRGBA(0, 0, 255)},
+				{BonusSource::ARMY,              ColorRGBA(0, 255, 0)},
+				{BonusSource::CAMPAIGN_BONUS,    ColorRGBA(255, 0, 0)},
+				{BonusSource::STACK_EXPERIENCE,  ColorRGBA(255, 0, 0)},
+				{BonusSource::COMMANDER,         ColorRGBA(255, 0, 0)},
+				{BonusSource::GLOBAL,            ColorRGBA(255, 0, 0)},
+				{BonusSource::OTHER,             ColorRGBA(255, 0, 0)}
+			};
+
+			frame[leftRight] = std::make_shared<GraphicalPrimitiveCanvas>(Rect(position.x, position.y, 50, 50));
+			if(bonusColors.count(bi.bonus->source))
+				frame[leftRight]->addRectangle(Point(0, 0), Point(50, 50), bonusColors[bi.bonus->source]);
 		}
 	}
 }
@@ -281,10 +307,10 @@ CStackWindow::BonusesSection::BonusesSection(CStackWindow * owner, int yOffset,
 
 	auto onCreate = [=](size_t index) -> std::shared_ptr<CIntObject>
 	{
-		return std::make_shared<BonusLineSection>(owner, index);
+		return std::make_shared<BonusLineSection>(owner, index, totalSize <= 3);
 	};
 
-	lines = std::make_shared<CListBox>(onCreate, Point(0, 0), Point(0, itemHeight), visibleSize, totalSize, 0, 1, Rect(pos.w - 15, 0, pos.h, pos.h));
+	lines = std::make_shared<CListBox>(onCreate, Point(0, 0), Point(0, itemHeight), visibleSize, totalSize, 0, totalSize > 3 ? 1 : 0, Rect(pos.w - 15, 0, pos.h, pos.h));
 }
 
 CStackWindow::ButtonsSection::ButtonsSection(CStackWindow * owner, int yOffset)
@@ -533,7 +559,7 @@ CStackWindow::MainSection::MainSection(CStackWindow * owner, int yOffset, bool s
 		animation->setAmount(parent->info->creatureCount);
 	}
 
-	name = std::make_shared<CLabel>(215, 12, FONT_SMALL, ETextAlignment::CENTER, Colors::YELLOW, parent->info->getName());
+	name = std::make_shared<CLabel>(215, 13, FONT_SMALL, ETextAlignment::CENTER, Colors::YELLOW, parent->info->getName());
 
 	const BattleInterface* battleInterface = LOCPLINT->battleInt.get();
 	const CStack* battleStack = parent->info->stack;
@@ -801,6 +827,7 @@ void CStackWindow::initBonusesList()
 		bonusInfo.name = info->stackNode->bonusToString(b, false);
 		bonusInfo.description = info->stackNode->bonusToString(b, true);
 		bonusInfo.imagePath = info->stackNode->bonusToGraphics(b);
+		bonusInfo.bonus = b;
 
 		//if it's possible to give any description or image for this kind of bonus
 		//TODO: figure out why half of bonuses don't have proper description

+ 4 - 1
client/windows/CCreatureWindow.h

@@ -31,6 +31,7 @@ class CListBox;
 class CArtPlace;
 class CCommanderArtPlace;
 class LRClickableArea;
+class GraphicalPrimitiveCanvas;
 
 class CCommanderSkillIcon : public LRClickableAreaWText //TODO: maybe bring commander skill button initialization logic inside?
 {
@@ -58,6 +59,7 @@ class CStackWindow : public CWindowObject
 		std::string name;
 		std::string description;
 		ImagePath imagePath;
+		std::shared_ptr<Bonus> bonus;
 	};
 
 	class CWindowSection : public CIntObject
@@ -84,8 +86,9 @@ class CStackWindow : public CWindowObject
 		std::array<std::shared_ptr<CPicture>, 2> icon;
 		std::array<std::shared_ptr<CLabel>, 2> name;
 		std::array<std::shared_ptr<CMultiLineLabel>, 2> description;
+		std::array<std::shared_ptr<GraphicalPrimitiveCanvas>, 2> frame;
 	public:
-		BonusLineSection(CStackWindow * owner, size_t lineIndex);
+		BonusLineSection(CStackWindow * owner, size_t lineIndex, bool noScroll);
 	};
 
 	class BonusesSection : public CWindowSection