From 2a83f06905353f53de4520998806875362f1fc74 Mon Sep 17 00:00:00 2001 From: Evgeniy Meshcheryakov Date: Mon, 14 Aug 2023 00:06:22 +0300 Subject: [PATCH 01/20] Preserve order of secondary skills during hero serialization/deserialization --- lib/mapObjects/CGHeroInstance.cpp | 45 +++++++++++++++++++++---------- 1 file changed, 31 insertions(+), 14 deletions(-) diff --git a/lib/mapObjects/CGHeroInstance.cpp b/lib/mapObjects/CGHeroInstance.cpp index 80fac1523..c7e2700b6 100644 --- a/lib/mapObjects/CGHeroInstance.cpp +++ b/lib/mapObjects/CGHeroInstance.cpp @@ -1617,52 +1617,69 @@ void CGHeroInstance::serializeCommonOptions(JsonSerializeFormat & handler) //in json default skills means no field/null if(!defaultSkills) { - //enter structure here as handler initialize it - auto secondarySkills = handler.enterStruct("secondarySkills"); + //enter array here as handler initialize it + auto secondarySkills = handler.enterArray("secondarySkills"); + secondarySkills.syncSize(secSkills, JsonNode::JsonType::DATA_VECTOR); - for(auto & p : secSkills) + for(size_t skillIndex = 0; skillIndex < secondarySkills.size(); ++skillIndex) { - const si32 rawId = p.first.num; + JsonArraySerializer inner = secondarySkills.enterArray(skillIndex); + const si32 rawId = secSkills.at(skillIndex).first; if(rawId < 0 || rawId >= VLC->skillh->size()) logGlobal->error("Invalid secondary skill %d", rawId); - handler.serializeEnum((*VLC->skillh)[SecondarySkill(rawId)]->getJsonKey(), p.second, 0, NSecondarySkill::levels); + auto value = (*VLC->skillh)[SecondarySkill(rawId)]->getJsonKey(); + handler.serializeString("skill", value); + value = NSecondarySkill::levels.at(secSkills.at(skillIndex).second); + handler.serializeString("level", value); } } } else { - auto secondarySkills = handler.enterStruct("secondarySkills"); - const JsonNode & skillMap = handler.getCurrent(); + auto secondarySkills = handler.getCurrent()["secondarySkills"]; secSkills.clear(); - if(skillMap.getType() == JsonNode::JsonType::DATA_NULL) + if(secondarySkills.getType() == JsonNode::JsonType::DATA_NULL) { secSkills.emplace_back(SecondarySkill::DEFAULT, -1); } else { - for(const auto & p : skillMap.Struct()) + auto addSkill = [this](const std::string & skillId, const std::string & levelId) { - const std::string skillId = p.first; - const std::string levelId = p.second.String(); - const int rawId = CSkillHandler::decodeSkill(skillId); if(rawId < 0) { logGlobal->error("Invalid secondary skill %s", skillId); - continue; + return; } const int level = vstd::find_pos(NSecondarySkill::levels, levelId); if(level < 0) { logGlobal->error("Invalid secondary skill level%s", levelId); - continue; + return; } secSkills.emplace_back(SecondarySkill(rawId), level); + }; + + if(secondarySkills.getType() == JsonNode::JsonType::DATA_VECTOR) + { + for(const auto & p : secondarySkills.Vector()) + { + auto skillMap = p.Struct(); + addSkill(skillMap["skill"].String(), skillMap["level"].String()); + } + } + else if(secondarySkills.getType() == JsonNode::JsonType::DATA_STRUCT) + { + for(const auto & p : secondarySkills.Struct()) + { + addSkill(p.first, p.second.String()); + }; } } } From db81d75f7546e788793ded8207dc569d747b8fb0 Mon Sep 17 00:00:00 2001 From: Ivan Savenko Date: Tue, 15 Aug 2023 18:47:42 +0300 Subject: [PATCH 02/20] Compile against SDK version 33 --- android/vcmi-app/build.gradle | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/android/vcmi-app/build.gradle b/android/vcmi-app/build.gradle index 34c9dcc70..ae2785861 100644 --- a/android/vcmi-app/build.gradle +++ b/android/vcmi-app/build.gradle @@ -3,13 +3,13 @@ plugins { } android { - compileSdk 31 + compileSdk 33 ndkVersion '25.2.9519653' defaultConfig { applicationId "is.xyz.vcmi" minSdk 19 - targetSdk 31 + targetSdk 33 versionCode 1306 versionName "1.3.0" setProperty("archivesBaseName", "vcmi") From 6cb6a6d785c717af1f0843f29b60723effc21260 Mon Sep 17 00:00:00 2001 From: Dydzio Date: Fri, 18 Aug 2023 20:24:31 +0200 Subject: [PATCH 03/20] Fix updating opponent hero spellpoints in battle window --- client/CPlayerInterface.cpp | 3 --- client/NetPacksClient.cpp | 5 +++++ 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/client/CPlayerInterface.cpp b/client/CPlayerInterface.cpp index 69fde8c7b..f0feb6a9c 100644 --- a/client/CPlayerInterface.cpp +++ b/client/CPlayerInterface.cpp @@ -476,9 +476,6 @@ void CPlayerInterface::heroManaPointsChanged(const CGHeroInstance * hero) adventureInt->onHeroChanged(hero); if (makingTurn && hero->tempOwner == playerID) adventureInt->onHeroChanged(hero); - - for (auto window : GH.windows().findWindows()) - window->heroManaPointsChanged(hero); } void CPlayerInterface::heroMovePointsChanged(const CGHeroInstance * hero) { diff --git a/client/NetPacksClient.cpp b/client/NetPacksClient.cpp index c2f89316f..422aa3481 100644 --- a/client/NetPacksClient.cpp +++ b/client/NetPacksClient.cpp @@ -17,7 +17,9 @@ #include "mapView/mapHandler.h" #include "adventureMap/CInGameConsole.h" #include "battle/BattleInterface.h" +#include "battle/BattleWindow.h" #include "gui/CGuiHandler.h" +#include "gui/WindowHandler.h" #include "widgets/MiscWidgets.h" #include "CMT.h" #include "CServerHandler.h" @@ -153,6 +155,9 @@ void ApplyClientNetPackVisitor::visitSetMana(SetMana & pack) { const CGHeroInstance *h = cl.getHero(pack.hid); callInterfaceIfPresent(cl, h->tempOwner, &IGameEventsReceiver::heroManaPointsChanged, h); + + for (auto window : GH.windows().findWindows()) + window->heroManaPointsChanged(h); } void ApplyClientNetPackVisitor::visitSetMovePoints(SetMovePoints & pack) From 6bfbe80cc9524612251599e47ec22aa3feb6ae8e Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sat, 19 Aug 2023 17:23:55 +0200 Subject: [PATCH 04/20] Allow toggling quick combat spells usage --- AI/BattleAI/BattleAI.cpp | 9 +++++- AI/BattleAI/BattleAI.h | 2 ++ client/CPlayerInterface.cpp | 6 +++- client/battle/BattleWindow.cpp | 6 +++- client/windows/settings/BattleOptionsTab.cpp | 13 +++++++++ client/windows/settings/BattleOptionsTab.h | 1 + cmake_modules/VCMI_lib.cmake | 2 ++ config/schemas/settings.json | 6 +++- config/widgets/settings/battleOptionsTab.json | 29 +++++++++++++++++-- lib/CGameInterface.h | 2 ++ lib/battle/AutocombatPreferences.cpp | 11 +++++++ lib/battle/AutocombatPreferences.h | 21 ++++++++++++++ 12 files changed, 101 insertions(+), 7 deletions(-) create mode 100644 lib/battle/AutocombatPreferences.cpp create mode 100644 lib/battle/AutocombatPreferences.h diff --git a/AI/BattleAI/BattleAI.cpp b/AI/BattleAI/BattleAI.cpp index 0f7068402..00f6295e7 100644 --- a/AI/BattleAI/BattleAI.cpp +++ b/AI/BattleAI/BattleAI.cpp @@ -93,6 +93,12 @@ void CBattleAI::initBattleInterface(std::shared_ptr ENV, std::share movesSkippedByDefense = 0; } +void CBattleAI::initBattleInterface(std::shared_ptr ENV, std::shared_ptr CB, AutocombatPreferences autocombatPreferences) +{ + initBattleInterface(ENV, CB); + autobattlePreferences = autocombatPreferences; +} + BattleAction CBattleAI::useHealingTent(const CStack *stack) { auto healingTargets = cb->battleGetStacks(CBattleInfoEssentials::ONLY_MINE); @@ -283,7 +289,8 @@ void CBattleAI::activeStack( const CStack * stack ) return; } - attemptCastingSpell(); + if(autobattlePreferences.enableSpellsUsage) + attemptCastingSpell(); logAi->trace("Spellcast attempt completed in %lld", timeElapsed(start)); diff --git a/AI/BattleAI/BattleAI.h b/AI/BattleAI/BattleAI.h index 37338d299..a83fcfd25 100644 --- a/AI/BattleAI/BattleAI.h +++ b/AI/BattleAI/BattleAI.h @@ -68,6 +68,7 @@ public: ~CBattleAI(); void initBattleInterface(std::shared_ptr ENV, std::shared_ptr CB) override; + void initBattleInterface(std::shared_ptr ENV, std::shared_ptr CB, AutocombatPreferences autocombatPreferences) override; void attemptCastingSpell(); void evaluateCreatureSpellcast(const CStack * stack, PossibleSpellcast & ps); //for offensive damaging spells only @@ -102,4 +103,5 @@ public: private: BattleAction goTowardsNearest(const CStack * stack, std::vector hexes) const; std::vector getBrokenWallMoatHexes() const; + AutocombatPreferences autobattlePreferences = AutocombatPreferences(); }; diff --git a/client/CPlayerInterface.cpp b/client/CPlayerInterface.cpp index 69fde8c7b..3232fd724 100644 --- a/client/CPlayerInterface.cpp +++ b/client/CPlayerInterface.cpp @@ -662,7 +662,11 @@ void CPlayerInterface::battleStart(const CCreatureSet *army1, const CCreatureSet if ((replayAllowed && useQuickCombat) || forceQuickCombat) { autofightingAI = CDynLibHandler::getNewBattleAI(settings["server"]["friendlyAI"].String()); - autofightingAI->initBattleInterface(env, cb); + + AutocombatPreferences autocombatPreferences = AutocombatPreferences(); + autocombatPreferences.enableSpellsUsage = settings["battle"]["enableAutocombatSpells"].Bool(); + + autofightingAI->initBattleInterface(env, cb, autocombatPreferences); autofightingAI->battleStart(army1, army2, tile, hero1, hero2, side, false); isAutoFightOn = true; cb->registerBattleInterface(autofightingAI); diff --git a/client/battle/BattleWindow.cpp b/client/battle/BattleWindow.cpp index 36c430272..36cf2441c 100644 --- a/client/battle/BattleWindow.cpp +++ b/client/battle/BattleWindow.cpp @@ -500,7 +500,11 @@ void BattleWindow::bAutofightf() blockUI(true); auto ai = CDynLibHandler::getNewBattleAI(settings["server"]["friendlyAI"].String()); - ai->initBattleInterface(owner.curInt->env, owner.curInt->cb); + + AutocombatPreferences autocombatPreferences = AutocombatPreferences(); + autocombatPreferences.enableSpellsUsage = settings["battle"]["enableAutocombatSpells"].Bool(); + + ai->initBattleInterface(owner.curInt->env, owner.curInt->cb, autocombatPreferences); ai->battleStart(owner.army1, owner.army2, int3(0,0,0), owner.attackingHeroInstance, owner.defendingHeroInstance, owner.curInt->cb->battleGetMySide(), false); owner.curInt->autofightingAI = ai; owner.curInt->cb->registerBattleInterface(ai); diff --git a/client/windows/settings/BattleOptionsTab.cpp b/client/windows/settings/BattleOptionsTab.cpp index 99f874a4e..1e657d61c 100644 --- a/client/windows/settings/BattleOptionsTab.cpp +++ b/client/windows/settings/BattleOptionsTab.cpp @@ -64,6 +64,10 @@ BattleOptionsTab::BattleOptionsTab(BattleInterface * owner) { showStickyHeroWindowsChangedCallback(value, owner); }); + addCallback("enableAutocombatSpellsChanged", [this](bool value) + { + enableAutocombatSpellsChangedCallback(value); + }); build(config); std::shared_ptr animationSpeedToggle = widget("animationSpeedPicker"); @@ -92,6 +96,9 @@ BattleOptionsTab::BattleOptionsTab(BattleInterface * owner) std::shared_ptr skipBattleIntroMusicCheckbox = widget("skipBattleIntroMusicCheckbox"); skipBattleIntroMusicCheckbox->setSelected(settings["gameTweaks"]["skipBattleIntroMusic"].Bool()); + + std::shared_ptr enableAutocombatSpellsCheckbox = widget("enableAutocombatSpellsCheckbox"); + enableAutocombatSpellsCheckbox->setSelected(settings["battle"]["enableAutocombatSpells"].Bool()); } int BattleOptionsTab::getAnimSpeed() const @@ -235,3 +242,9 @@ void BattleOptionsTab::skipBattleIntroMusicChangedCallback(bool value) musicSkipSettingValue->Bool() = value; } +void BattleOptionsTab::enableAutocombatSpellsChangedCallback(bool value) +{ + Settings enableAutocombatSpells = settings.write["battle"]["enableAutocombatSpells"]; + enableAutocombatSpells->Bool() = value; +} + diff --git a/client/windows/settings/BattleOptionsTab.h b/client/windows/settings/BattleOptionsTab.h index 6a71d2e68..43d4d7e50 100644 --- a/client/windows/settings/BattleOptionsTab.h +++ b/client/windows/settings/BattleOptionsTab.h @@ -32,6 +32,7 @@ private: void queueSizeChangedCallback(int value, BattleInterface * parentBattleInterface); void skipBattleIntroMusicChangedCallback(bool value); void showStickyHeroWindowsChangedCallback(bool value, BattleInterface * parentBattleInterface); + void enableAutocombatSpellsChangedCallback(bool value); public: BattleOptionsTab(BattleInterface * owner = nullptr); }; diff --git a/cmake_modules/VCMI_lib.cmake b/cmake_modules/VCMI_lib.cmake index 70c41549a..8f6ccbdc1 100644 --- a/cmake_modules/VCMI_lib.cmake +++ b/cmake_modules/VCMI_lib.cmake @@ -7,6 +7,7 @@ macro(add_main_lib TARGET_NAME LIBRARY_TYPE) ${MAIN_LIB_DIR}/StdInc.cpp ${MAIN_LIB_DIR}/battle/AccessibilityInfo.cpp + ${MAIN_LIB_DIR}/battle/AutocombatPreferences.cpp ${MAIN_LIB_DIR}/battle/BattleAction.cpp ${MAIN_LIB_DIR}/battle/BattleAttackInfo.cpp ${MAIN_LIB_DIR}/battle/BattleHex.cpp @@ -322,6 +323,7 @@ macro(add_main_lib TARGET_NAME LIBRARY_TYPE) ${MAIN_LIB_DIR}/../include/vcmi/Team.h ${MAIN_LIB_DIR}/battle/AccessibilityInfo.h + ${MAIN_LIB_DIR}/battle/AutocombatPreferences.h ${MAIN_LIB_DIR}/battle/BattleAction.h ${MAIN_LIB_DIR}/battle/BattleAttackInfo.h ${MAIN_LIB_DIR}/battle/BattleHex.h diff --git a/config/schemas/settings.json b/config/schemas/settings.json index 20699af25..5f3acffbc 100644 --- a/config/schemas/settings.json +++ b/config/schemas/settings.json @@ -272,7 +272,7 @@ "type" : "object", "additionalProperties" : false, "default" : {}, - "required" : [ "speedFactor", "mouseShadow", "cellBorders", "stackRange", "movementHighlightOnHover", "rangeLimitHighlightOnHover", "showQueue", "swipeAttackDistance", "queueSize", "stickyHeroInfoWindows" ], + "required" : [ "speedFactor", "mouseShadow", "cellBorders", "stackRange", "movementHighlightOnHover", "rangeLimitHighlightOnHover", "showQueue", "swipeAttackDistance", "queueSize", "stickyHeroInfoWindows", "enableAutocombatSpells" ], "properties" : { "speedFactor" : { "type" : "number", @@ -314,6 +314,10 @@ "stickyHeroInfoWindows" : { "type" : "boolean", "default" : true + }, + "enableAutocombatSpells" : { + "type": "boolean", + "default": true } } }, diff --git a/config/widgets/settings/battleOptionsTab.json b/config/widgets/settings/battleOptionsTab.json index 0fde2a031..8f47a3fd5 100644 --- a/config/widgets/settings/battleOptionsTab.json +++ b/config/widgets/settings/battleOptionsTab.json @@ -51,14 +51,37 @@ ] }, { - "name": "autoCombatCheckboxes", + "name": "autoCombatFakeCheckboxes", "type" : "verticalLayout", "customType" : "checkboxFake", "position": {"x": 380, "y": 83}, "items": [ - {}, - {}, + {} + ] + }, + + { + "type" : "verticalLayout", + "customType" : "checkbox", + "position": {"x": 380, "y": 113}, + "items": + [ + { + "name": "enableAutocombatSpellsCheckbox", + "help": "vcmi.battleOptions.enableAutocombatSpells", + "callback": "enableAutocombatSpellsChanged" + } + ] + }, + + { + "name": "autoCombatFakeCheckboxes2", + "type" : "verticalLayout", + "customType" : "checkboxFake", + "position": {"x": 380, "y": 143}, + "items": + [ {}, {}, {} diff --git a/lib/CGameInterface.h b/lib/CGameInterface.h index 3ee27c21a..9ffcc80ad 100644 --- a/lib/CGameInterface.h +++ b/lib/CGameInterface.h @@ -9,6 +9,7 @@ */ #pragma once +#include "battle/AutocombatPreferences.h" #include "battle/BattleAction.h" #include "IGameEventsReceiver.h" @@ -76,6 +77,7 @@ public: virtual ~CBattleGameInterface() {}; virtual void initBattleInterface(std::shared_ptr ENV, std::shared_ptr CB){}; + virtual void initBattleInterface(std::shared_ptr ENV, std::shared_ptr CB, AutocombatPreferences autocombatPreferences){}; //battle call-ins virtual void activeStack(const CStack * stack)=0; //called when it's turn of that stack diff --git a/lib/battle/AutocombatPreferences.cpp b/lib/battle/AutocombatPreferences.cpp new file mode 100644 index 000000000..669a5f776 --- /dev/null +++ b/lib/battle/AutocombatPreferences.cpp @@ -0,0 +1,11 @@ +/* + * AutocombatPreferences.cpp, part of VCMI engine + * + * Authors: listed in file AUTHORS in main folder + * + * License: GNU General Public License v2.0 or later + * Full text of license available in license.txt file, in main folder + * + */ + +#include "AutocombatPreferences.h" diff --git a/lib/battle/AutocombatPreferences.h b/lib/battle/AutocombatPreferences.h new file mode 100644 index 000000000..da6224ead --- /dev/null +++ b/lib/battle/AutocombatPreferences.h @@ -0,0 +1,21 @@ +/* + * AutocombatPreferences.h, part of VCMI engine + * + * Authors: listed in file AUTHORS in main folder + * + * License: GNU General Public License v2.0 or later + * Full text of license available in license.txt file, in main folder + * + */ +#pragma once + +struct AutocombatPreferences +{ + bool enableSpellsUsage = true; + //TODO: below options exist in original H3, consider usefulness of mixed human-AI combat when enabling autocombat inside battle + bool enableUnitsUsage = true; + bool enableCatapultUsage = true; + bool enableBallistaUsage = true; + bool enableFirstAidTendUsage = true; +}; + From f409b6ced97603269f048e29ec51e670d7a25749 Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sat, 19 Aug 2023 21:09:02 +0200 Subject: [PATCH 05/20] Fix counting wood mines starting from 8 in kingdom overview --- client/windows/CKingdomInterface.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/client/windows/CKingdomInterface.cpp b/client/windows/CKingdomInterface.cpp index 300092027..d81acf5a9 100644 --- a/client/windows/CKingdomInterface.cpp +++ b/client/windows/CKingdomInterface.cpp @@ -555,7 +555,7 @@ std::shared_ptr CKingdomInterface::createMainTab(size_t index) void CKingdomInterface::generateMinesList(const std::vector & ownedObjects) { ui32 footerPos = OVERVIEW_SIZE * 116; - TResources minesCount(GameConstants::RESOURCE_QUANTITY, 0); + ResourceSet minesCount = ResourceSet(); int totalIncome=0; for(const CGObjectInstance * object : ownedObjects) From f24910e5d2f7e95d8d030e124e33d5da5ac9c05d Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sun, 20 Aug 2023 00:52:03 +0200 Subject: [PATCH 06/20] Artifacts backpack window GUI improvements --- client/widgets/CArtifactsOfHeroBackpack.cpp | 1 + client/windows/CHeroBackpackWindow.cpp | 23 +++++++++++++++++---- client/windows/CHeroBackpackWindow.h | 5 +++++ 3 files changed, 25 insertions(+), 4 deletions(-) diff --git a/client/widgets/CArtifactsOfHeroBackpack.cpp b/client/widgets/CArtifactsOfHeroBackpack.cpp index 18a704a19..2bf968cdf 100644 --- a/client/widgets/CArtifactsOfHeroBackpack.cpp +++ b/client/widgets/CArtifactsOfHeroBackpack.cpp @@ -84,6 +84,7 @@ void CArtifactsOfHeroBackpack::scrollBackpack(int offset) slot = slot + 1; } redraw(); + setRedrawParent(true); } void CArtifactsOfHeroBackpack::updateBackpackSlots() diff --git a/client/windows/CHeroBackpackWindow.cpp b/client/windows/CHeroBackpackWindow.cpp index b491bf57d..424388e5b 100644 --- a/client/windows/CHeroBackpackWindow.cpp +++ b/client/windows/CHeroBackpackWindow.cpp @@ -14,17 +14,32 @@ #include "../gui/Shortcut.h" #include "../widgets/Buttons.h" +#include "../widgets/Images.h" +#include "CMessage.h" +#include "render/Canvas.h" CHeroBackpackWindow::CHeroBackpackWindow(const CGHeroInstance * hero) - : CWindowObject(PLAYER_COLORED) + : CWindowObject((EOptions)0) { OBJECT_CONSTRUCTION_CAPTURING(255-DISPOSE); - - arts = std::make_shared(Point(-100, -170)); + + stretchedBackground = std::make_shared("DIBOXBCK", Rect(0, 0, 410, 425)); + pos.w = stretchedBackground->pos.w; + pos.h = stretchedBackground->pos.h; + center(); + + + arts = std::make_shared(/*Point(-100, -170)*/Point(10, 10)); arts->setHero(hero); addSet(arts); addCloseCallback(std::bind(&CHeroBackpackWindow::close, this)); - quitButton = std::make_shared(Point(242, 200), "hsbtns.def", CButton::tooltip(""), [this]() { close(); }, EShortcut::GLOBAL_RETURN); + quitButton = std::make_shared(Point(173, 385), "IOKAY32.def", CButton::tooltip(""), [this]() { close(); }, EShortcut::GLOBAL_RETURN); +} + +void CHeroBackpackWindow::showAll(Canvas &to) +{ + CIntObject::showAll(to); + CMessage::drawBorder(PlayerColor(1), to.getInternalSurface(), pos.w+28, pos.h+29, pos.x-14, pos.y-15); } diff --git a/client/windows/CHeroBackpackWindow.h b/client/windows/CHeroBackpackWindow.h index fefd1902d..df9aeb08d 100644 --- a/client/windows/CHeroBackpackWindow.h +++ b/client/windows/CHeroBackpackWindow.h @@ -12,6 +12,8 @@ #include "../widgets/CWindowWithArtifacts.h" #include "CWindowObject.h" +class CFilledTexture; + class CHeroBackpackWindow : public CWindowObject, public CWindowWithArtifacts { public: @@ -20,4 +22,7 @@ public: private: std::shared_ptr arts; std::shared_ptr quitButton; + std::shared_ptr stretchedBackground; + + void showAll(Canvas &to) override; }; From d8eef4905abe8c7cdb39e003ad30e92368f69c2d Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sun, 20 Aug 2023 13:53:25 +0200 Subject: [PATCH 07/20] Implement new callback in stupidAI --- AI/StupidAI/StupidAI.cpp | 5 +++++ AI/StupidAI/StupidAI.h | 1 + 2 files changed, 6 insertions(+) diff --git a/AI/StupidAI/StupidAI.cpp b/AI/StupidAI/StupidAI.cpp index 85a9fe571..aad18351e 100644 --- a/AI/StupidAI/StupidAI.cpp +++ b/AI/StupidAI/StupidAI.cpp @@ -47,6 +47,11 @@ void CStupidAI::initBattleInterface(std::shared_ptr ENV, std::share CB->unlockGsWhenWaiting = false; } +void CStupidAI::initBattleInterface(std::shared_ptr ENV, std::shared_ptr CB, AutocombatPreferences autocombatPreferences) +{ + initBattleInterface(ENV, CB); +} + void CStupidAI::actionFinished(const BattleAction &action) { print("actionFinished called"); diff --git a/AI/StupidAI/StupidAI.h b/AI/StupidAI/StupidAI.h index 3b074d643..6b0d230ad 100644 --- a/AI/StupidAI/StupidAI.h +++ b/AI/StupidAI/StupidAI.h @@ -29,6 +29,7 @@ public: ~CStupidAI(); void initBattleInterface(std::shared_ptr ENV, std::shared_ptr CB) override; + void initBattleInterface(std::shared_ptr ENV, std::shared_ptr CB, AutocombatPreferences autocombatPreferences) override; void actionFinished(const BattleAction &action) override;//occurs AFTER every action taken by any stack or by the hero void actionStarted(const BattleAction &action) override;//occurs BEFORE every action taken by any stack or by the hero void activeStack(const CStack * stack) override; //called when it's turn of that stack From cab6fb76aac20c3137796c26d1eef9b94f5d1d09 Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sun, 20 Aug 2023 17:45:43 +0200 Subject: [PATCH 08/20] Draft version of backpack button + new setting for original H3 UI mode --- Mods/vcmi/Sprites/buttons/backpack.json | 8 ++++++++ Mods/vcmi/Sprites/buttons/backpackNormal.png | Bin 0 -> 3008 bytes Mods/vcmi/Sprites/buttons/backpackPressed.png | Bin 0 -> 2848 bytes Mods/vcmi/config/vcmi/english.json | 2 ++ Mods/vcmi/config/vcmi/polish.json | 2 ++ client/windows/CHeroWindow.cpp | 18 +++++++++++++----- config/schemas/settings.json | 7 ++++++- 7 files changed, 31 insertions(+), 6 deletions(-) create mode 100644 Mods/vcmi/Sprites/buttons/backpack.json create mode 100644 Mods/vcmi/Sprites/buttons/backpackNormal.png create mode 100644 Mods/vcmi/Sprites/buttons/backpackPressed.png diff --git a/Mods/vcmi/Sprites/buttons/backpack.json b/Mods/vcmi/Sprites/buttons/backpack.json new file mode 100644 index 000000000..a74a8c3a1 --- /dev/null +++ b/Mods/vcmi/Sprites/buttons/backpack.json @@ -0,0 +1,8 @@ +{ + "basepath" : "buttons/", + "images" : + [ + { "frame" : 0, "file" : "backpackNormal.png"}, + { "frame" : 1, "file" : "backpackPressed.png"} + ] +} diff --git a/Mods/vcmi/Sprites/buttons/backpackNormal.png b/Mods/vcmi/Sprites/buttons/backpackNormal.png new file mode 100644 index 0000000000000000000000000000000000000000..541ec56c55f3481806c72726246a4a2ec2b1f30b GIT binary patch literal 3008 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, 516), "hsbtns.def", CButton::tooltip(heroscrn[17]), [=](){ close(); }, EShortcut::GLOBAL_RETURN); - dismissLabel = std::make_shared(CGI->generaltexth->jktexts[8], Rect(370, 430, 65, 35), 0, FONT_SMALL, ETextAlignment::TOPLEFT, Colors::WHITE); - dismissButton = std::make_shared(Point(454, 429), "hsbtns2.def", CButton::tooltip(heroscrn[28]), [=](){ dismissCurrent(); }, EShortcut::HERO_DISMISS); - - questlogLabel = std::make_shared(CGI->generaltexth->jktexts[9], Rect(510, 430, 65, 35), 0, FONT_SMALL, ETextAlignment::TOPLEFT, Colors::WHITE); - questlogButton = std::make_shared(Point(314, 429), "hsbtns4.def", CButton::tooltip(heroscrn[0]), [=](){ LOCPLINT->showQuestLog(); }, EShortcut::ADVENTURE_QUEST_LOG); + if(settings["general"]["enableUiEnhancements"].Bool()) + { + questlogButton = std::make_shared(Point(314, 429), "hsbtns4.def", CButton::tooltip(heroscrn[0]), [=](){ LOCPLINT->showQuestLog(); }, EShortcut::ADVENTURE_QUEST_LOG); + backpackButton = std::make_shared(Point(424, 429), "buttons/backpack", CButton::tooltipLocalized("vcmi.heroWindow.Backpack"), [=](){ createBackpackWindow(); }, EShortcut::HERO_BACKPACK); + dismissButton = std::make_shared(Point(534, 429), "hsbtns2.def", CButton::tooltip(heroscrn[28]), [=](){ dismissCurrent(); }, EShortcut::HERO_DISMISS); + } + else + { + dismissLabel = std::make_shared(CGI->generaltexth->jktexts[8], Rect(370, 430, 65, 35), 0, FONT_SMALL, ETextAlignment::TOPLEFT, Colors::WHITE); + questlogLabel = std::make_shared(CGI->generaltexth->jktexts[9], Rect(510, 430, 65, 35), 0, FONT_SMALL, ETextAlignment::TOPLEFT, Colors::WHITE); + dismissButton = std::make_shared(Point(454, 429), "hsbtns2.def", CButton::tooltip(heroscrn[28]), [=](){ dismissCurrent(); }, EShortcut::HERO_DISMISS); + questlogButton = std::make_shared(Point(314, 429), "hsbtns4.def", CButton::tooltip(heroscrn[0]), [=](){ LOCPLINT->showQuestLog(); }, EShortcut::ADVENTURE_QUEST_LOG); + } formations = std::make_shared(0); formations->addToggle(0, std::make_shared(Point(481, 483), "hsbtns6.def", std::make_pair(heroscrn[23], heroscrn[29]), 0, EShortcut::HERO_TIGHT_FORMATION)); diff --git a/config/schemas/settings.json b/config/schemas/settings.json index 20699af25..89a9a84f5 100644 --- a/config/schemas/settings.json +++ b/config/schemas/settings.json @@ -38,7 +38,8 @@ "autosaveCountLimit", "useSavePrefix", "savePrefix", - "startTurnAutosave" + "startTurnAutosave", + "enableUiEnhancements" ], "properties" : { "playerName" : { @@ -126,6 +127,10 @@ "startTurnAutosave" : { "type": "boolean", "default": false + }, + "enableUiEnhancements" : { + "type": "boolean", + "default": true } } }, From 3b99f09495b633c4505178372bcaafa621eab168 Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sun, 20 Aug 2023 18:25:57 +0200 Subject: [PATCH 09/20] Update backpack icons --- Mods/vcmi/Sprites/buttons/backpackNormal.png | Bin 3008 -> 4102 bytes Mods/vcmi/Sprites/buttons/backpackPressed.png | Bin 2848 -> 3900 bytes 2 files changed, 0 insertions(+), 0 deletions(-) diff --git a/Mods/vcmi/Sprites/buttons/backpackNormal.png b/Mods/vcmi/Sprites/buttons/backpackNormal.png index 541ec56c55f3481806c72726246a4a2ec2b1f30b..0b7691614c33db18a421e398bd70c8e6e77dd2ac 100644 GIT binary patch literal 4102 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 diff --git a/Mods/vcmi/Sprites/buttons/backpackPressed.png b/Mods/vcmi/Sprites/buttons/backpackPressed.png index 316ecbdf90c962cb2b4ee7d776e01b22a8e6773f..00471588efa38422f7fa576bf564c805232c1691 100644 GIT binary patch literal 3900 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 From b53894ac2d93c44460e52a6668fcc81fbf9554cf Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sun, 20 Aug 2023 18:57:53 +0200 Subject: [PATCH 10/20] Add artifact slots backgrounds --- .../Sprites/heroWindow/artifactSlotEmpty.png | Bin 0 -> 133 bytes client/widgets/CArtifactsOfHeroBackpack.cpp | 19 ++++++++++++++---- client/widgets/CArtifactsOfHeroBackpack.h | 1 + 3 files changed, 16 insertions(+), 4 deletions(-) create mode 100644 Mods/vcmi/Sprites/heroWindow/artifactSlotEmpty.png diff --git a/Mods/vcmi/Sprites/heroWindow/artifactSlotEmpty.png b/Mods/vcmi/Sprites/heroWindow/artifactSlotEmpty.png new file mode 100644 index 0000000000000000000000000000000000000000..f0dec09728fc1f413e050d6702087aee95298970 GIT binary patch literal 133 zcmeAS@N?(olHy`uVBq!ia0vp^Iv~u%3?!3ZZJGq6cmjMvT!Hk?+1)8#w#I7mhdkHY z1Nkf^L4LsvK#+Olf)|jl;_2cTQo)$)z_w^%!GQ%^x!A&tUmOT6;1~X;5iKfr_2G#^ aUWP9dWghHLS*r|G&*16m=d#Wzp$P!0i6>wH literal 0 HcmV?d00001 diff --git a/client/widgets/CArtifactsOfHeroBackpack.cpp b/client/widgets/CArtifactsOfHeroBackpack.cpp index 2bf968cdf..80aab5d67 100644 --- a/client/widgets/CArtifactsOfHeroBackpack.cpp +++ b/client/widgets/CArtifactsOfHeroBackpack.cpp @@ -14,6 +14,7 @@ #include "../gui/Shortcut.h" #include "Buttons.h" +#include "Images.h" #include "GameSettings.h" #include "IHandlerBase.h" #include "ObjectLists.h" @@ -29,12 +30,22 @@ CArtifactsOfHeroBackpack::CArtifactsOfHeroBackpack(const Point & position) pos += position; const auto backpackCap = VLC->settings()->getInteger(EGameSettings::HEROES_BACKPACK_CAP); - auto visibleCapasityMax = HERO_BACKPACK_WINDOW_SLOT_LINES * HERO_BACKPACK_WINDOW_SLOT_COLUMNS; + auto visibleCapacityMax = HERO_BACKPACK_WINDOW_SLOT_LINES * HERO_BACKPACK_WINDOW_SLOT_COLUMNS; if(backpackCap >= 0) - visibleCapasityMax = visibleCapasityMax > backpackCap ? backpackCap : visibleCapasityMax; + visibleCapacityMax = visibleCapacityMax > backpackCap ? backpackCap : visibleCapacityMax; - backpack.resize(visibleCapasityMax); + backpack.resize(visibleCapacityMax); + backpackSlotsBackgrounds.resize(visibleCapacityMax); size_t artPlaceIdx = 0; + + for(int i = 0; i < HERO_BACKPACK_WINDOW_SLOT_LINES * HERO_BACKPACK_WINDOW_SLOT_COLUMNS; i++) + { + auto artifactSlotBackground = std::make_shared("heroWindow/artifactSlotEmpty", + Point(46 * (i % HERO_BACKPACK_WINDOW_SLOT_COLUMNS), 46 * (i / HERO_BACKPACK_WINDOW_SLOT_COLUMNS))); + + backpackSlotsBackgrounds.emplace_back(artifactSlotBackground); + } + for(auto & artPlace : backpack) { artPlace = std::make_shared( @@ -45,7 +56,7 @@ CArtifactsOfHeroBackpack::CArtifactsOfHeroBackpack(const Point & position) artPlaceIdx++; } - if(backpackCap < 0 || visibleCapasityMax < backpackCap) + if(backpackCap < 0 || visibleCapacityMax < backpackCap) { auto onCreate = [](size_t index) -> std::shared_ptr { diff --git a/client/widgets/CArtifactsOfHeroBackpack.h b/client/widgets/CArtifactsOfHeroBackpack.h index f504ba62c..f3735795e 100644 --- a/client/widgets/CArtifactsOfHeroBackpack.h +++ b/client/widgets/CArtifactsOfHeroBackpack.h @@ -31,6 +31,7 @@ public: private: std::shared_ptr backpackListBox; + std::vector> backpackSlotsBackgrounds; const size_t HERO_BACKPACK_WINDOW_SLOT_COLUMNS = 8; const size_t HERO_BACKPACK_WINDOW_SLOT_LINES = 8; }; From 78f56df44faae891013f89a036425e4afd2efef1 Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sun, 20 Aug 2023 19:11:36 +0200 Subject: [PATCH 11/20] Comment out unused OH3 options so they do not clutter code suggestions Co-authored-by: Ivan Savenko --- lib/battle/AutocombatPreferences.h | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/battle/AutocombatPreferences.h b/lib/battle/AutocombatPreferences.h index da6224ead..0ca89c53e 100644 --- a/lib/battle/AutocombatPreferences.h +++ b/lib/battle/AutocombatPreferences.h @@ -13,9 +13,9 @@ struct AutocombatPreferences { bool enableSpellsUsage = true; //TODO: below options exist in original H3, consider usefulness of mixed human-AI combat when enabling autocombat inside battle - bool enableUnitsUsage = true; - bool enableCatapultUsage = true; - bool enableBallistaUsage = true; - bool enableFirstAidTendUsage = true; +// bool enableUnitsUsage = true; +// bool enableCatapultUsage = true; +// bool enableBallistaUsage = true; +// bool enableFirstAidTendUsage = true; }; From b73f9325ad763a0ddebbdbc4ac409b42026e3e15 Mon Sep 17 00:00:00 2001 From: Dydzio Date: Mon, 21 Aug 2023 16:56:50 +0200 Subject: [PATCH 12/20] Fixes from code review --- client/widgets/CArtifactsOfHeroBackpack.cpp | 17 +++++++++-------- client/widgets/CArtifactsOfHeroBackpack.h | 2 +- 2 files changed, 10 insertions(+), 9 deletions(-) diff --git a/client/widgets/CArtifactsOfHeroBackpack.cpp b/client/widgets/CArtifactsOfHeroBackpack.cpp index 80aab5d67..90ecd7567 100644 --- a/client/widgets/CArtifactsOfHeroBackpack.cpp +++ b/client/widgets/CArtifactsOfHeroBackpack.cpp @@ -28,20 +28,22 @@ CArtifactsOfHeroBackpack::CArtifactsOfHeroBackpack(const Point & position) { OBJECT_CONSTRUCTION_CAPTURING(255 - DISPOSE); pos += position; + setRedrawParent(true); const auto backpackCap = VLC->settings()->getInteger(EGameSettings::HEROES_BACKPACK_CAP); - auto visibleCapacityMax = HERO_BACKPACK_WINDOW_SLOT_LINES * HERO_BACKPACK_WINDOW_SLOT_COLUMNS; + auto visibleCapacityMax = HERO_BACKPACK_WINDOW_SLOT_ROWS * HERO_BACKPACK_WINDOW_SLOT_COLUMNS; if(backpackCap >= 0) visibleCapacityMax = visibleCapacityMax > backpackCap ? backpackCap : visibleCapacityMax; backpack.resize(visibleCapacityMax); - backpackSlotsBackgrounds.resize(visibleCapacityMax); size_t artPlaceIdx = 0; - for(int i = 0; i < HERO_BACKPACK_WINDOW_SLOT_LINES * HERO_BACKPACK_WINDOW_SLOT_COLUMNS; i++) + const int slotSizeWithMargin = 46; + + for(int i = 0; i < visibleCapacityMax; i++) { auto artifactSlotBackground = std::make_shared("heroWindow/artifactSlotEmpty", - Point(46 * (i % HERO_BACKPACK_WINDOW_SLOT_COLUMNS), 46 * (i / HERO_BACKPACK_WINDOW_SLOT_COLUMNS))); + Point(slotSizeWithMargin * (i % HERO_BACKPACK_WINDOW_SLOT_COLUMNS), slotSizeWithMargin * (i / HERO_BACKPACK_WINDOW_SLOT_COLUMNS))); backpackSlotsBackgrounds.emplace_back(artifactSlotBackground); } @@ -49,7 +51,7 @@ CArtifactsOfHeroBackpack::CArtifactsOfHeroBackpack(const Point & position) for(auto & artPlace : backpack) { artPlace = std::make_shared( - Point(46 * (artPlaceIdx % HERO_BACKPACK_WINDOW_SLOT_COLUMNS), 46 * (artPlaceIdx / HERO_BACKPACK_WINDOW_SLOT_COLUMNS))); + Point(slotSizeWithMargin * (artPlaceIdx % HERO_BACKPACK_WINDOW_SLOT_COLUMNS), slotSizeWithMargin * (artPlaceIdx / HERO_BACKPACK_WINDOW_SLOT_COLUMNS))); artPlace->setArtifact(nullptr); artPlace->leftClickCallback = std::bind(&CArtifactsOfHeroBase::leftClickArtPlace, this, _1); artPlace->rightClickCallback = std::bind(&CArtifactsOfHeroBase::rightClickArtPlace, this, _1); @@ -67,8 +69,8 @@ CArtifactsOfHeroBackpack::CArtifactsOfHeroBackpack(const Point & position) scrollBackpack(static_cast(pos) * HERO_BACKPACK_WINDOW_SLOT_COLUMNS - backpackPos); }; backpackListBox = std::make_shared( - posMoved, onCreate, Point(0, 0), Point(0, 0), HERO_BACKPACK_WINDOW_SLOT_LINES, 0, 0, 1, - Rect(HERO_BACKPACK_WINDOW_SLOT_COLUMNS * 46 + 10, 0, HERO_BACKPACK_WINDOW_SLOT_LINES * 46 - 5, 0)); + posMoved, onCreate, Point(0, 0), Point(0, 0), HERO_BACKPACK_WINDOW_SLOT_ROWS, 0, 0, 1, + Rect(HERO_BACKPACK_WINDOW_SLOT_COLUMNS * slotSizeWithMargin + 10, 0, HERO_BACKPACK_WINDOW_SLOT_ROWS * slotSizeWithMargin - 5, 0)); } } @@ -95,7 +97,6 @@ void CArtifactsOfHeroBackpack::scrollBackpack(int offset) slot = slot + 1; } redraw(); - setRedrawParent(true); } void CArtifactsOfHeroBackpack::updateBackpackSlots() diff --git a/client/widgets/CArtifactsOfHeroBackpack.h b/client/widgets/CArtifactsOfHeroBackpack.h index f3735795e..e6767a601 100644 --- a/client/widgets/CArtifactsOfHeroBackpack.h +++ b/client/widgets/CArtifactsOfHeroBackpack.h @@ -33,5 +33,5 @@ private: std::shared_ptr backpackListBox; std::vector> backpackSlotsBackgrounds; const size_t HERO_BACKPACK_WINDOW_SLOT_COLUMNS = 8; - const size_t HERO_BACKPACK_WINDOW_SLOT_LINES = 8; + const size_t HERO_BACKPACK_WINDOW_SLOT_ROWS = 8; }; From 28fe28adf59ef9130e6adf9eb2dabf9c7eae691f Mon Sep 17 00:00:00 2001 From: Dydzio Date: Mon, 21 Aug 2023 17:08:15 +0200 Subject: [PATCH 13/20] Fix player coloring --- client/windows/CHeroBackpackWindow.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/client/windows/CHeroBackpackWindow.cpp b/client/windows/CHeroBackpackWindow.cpp index 424388e5b..46bcfda40 100644 --- a/client/windows/CHeroBackpackWindow.cpp +++ b/client/windows/CHeroBackpackWindow.cpp @@ -17,6 +17,7 @@ #include "../widgets/Images.h" #include "CMessage.h" #include "render/Canvas.h" +#include "CPlayerInterface.h" CHeroBackpackWindow::CHeroBackpackWindow(const CGHeroInstance * hero) : CWindowObject((EOptions)0) @@ -41,5 +42,5 @@ CHeroBackpackWindow::CHeroBackpackWindow(const CGHeroInstance * hero) void CHeroBackpackWindow::showAll(Canvas &to) { CIntObject::showAll(to); - CMessage::drawBorder(PlayerColor(1), to.getInternalSurface(), pos.w+28, pos.h+29, pos.x-14, pos.y-15); + CMessage::drawBorder(PlayerColor(LOCPLINT->playerID), to.getInternalSurface(), pos.w+28, pos.h+29, pos.x-14, pos.y-15); } From e81cd4e0e6c5459b7ae42f49ea4fc26aeb0a74ff Mon Sep 17 00:00:00 2001 From: Dydzio Date: Mon, 21 Aug 2023 20:09:50 +0200 Subject: [PATCH 14/20] Delete empty file --- lib/battle/AutocombatPreferences.cpp | 11 ----------- 1 file changed, 11 deletions(-) delete mode 100644 lib/battle/AutocombatPreferences.cpp diff --git a/lib/battle/AutocombatPreferences.cpp b/lib/battle/AutocombatPreferences.cpp deleted file mode 100644 index 669a5f776..000000000 --- a/lib/battle/AutocombatPreferences.cpp +++ /dev/null @@ -1,11 +0,0 @@ -/* - * AutocombatPreferences.cpp, part of VCMI engine - * - * Authors: listed in file AUTHORS in main folder - * - * License: GNU General Public License v2.0 or later - * Full text of license available in license.txt file, in main folder - * - */ - -#include "AutocombatPreferences.h" From 988843c4ee57e642394ebacc2540e79a7cd16a38 Mon Sep 17 00:00:00 2001 From: Ivan Savenko Date: Fri, 25 Aug 2023 01:14:22 +0300 Subject: [PATCH 15/20] Update cmake_modules/VCMI_lib.cmake --- cmake_modules/VCMI_lib.cmake | 1 - 1 file changed, 1 deletion(-) diff --git a/cmake_modules/VCMI_lib.cmake b/cmake_modules/VCMI_lib.cmake index 8f6ccbdc1..15efa56c2 100644 --- a/cmake_modules/VCMI_lib.cmake +++ b/cmake_modules/VCMI_lib.cmake @@ -7,7 +7,6 @@ macro(add_main_lib TARGET_NAME LIBRARY_TYPE) ${MAIN_LIB_DIR}/StdInc.cpp ${MAIN_LIB_DIR}/battle/AccessibilityInfo.cpp - ${MAIN_LIB_DIR}/battle/AutocombatPreferences.cpp ${MAIN_LIB_DIR}/battle/BattleAction.cpp ${MAIN_LIB_DIR}/battle/BattleAttackInfo.cpp ${MAIN_LIB_DIR}/battle/BattleHex.cpp From 730ab449b6491cb5673dfd35bc127cbe58e8708a Mon Sep 17 00:00:00 2001 From: SoundSSGood <87084363+SoundSSGood@users.noreply.github.com> Date: Fri, 25 Aug 2023 10:08:08 +0300 Subject: [PATCH 16/20] backpack window fix --- client/widgets/CWindowWithArtifacts.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/client/widgets/CWindowWithArtifacts.cpp b/client/widgets/CWindowWithArtifacts.cpp index 5bd2a00a3..3a9c3156a 100644 --- a/client/widgets/CWindowWithArtifacts.cpp +++ b/client/widgets/CWindowWithArtifacts.cpp @@ -165,7 +165,7 @@ void CWindowWithArtifacts::leftClickArtPlaceHero(CArtifactsOfHeroBase & artsInst if constexpr(std::is_same_v>) { - if(!isTransferAllowed) + if(!isTransferAllowed && artPlace.getArt()) { if(closeCallback) closeCallback(); From e1eb245565d6b6b8a7305d735cc4f9b2196514e2 Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sun, 27 Aug 2023 17:33:10 +0200 Subject: [PATCH 17/20] Better default stack action handling + "F shortcut" mode fixes --- client/battle/BattleActionsController.cpp | 36 +++++++++++++++++++---- client/battle/BattleActionsController.h | 2 +- client/battle/BattleWindow.cpp | 4 +++ client/gui/ShortcutHandler.cpp | 2 +- 4 files changed, 36 insertions(+), 8 deletions(-) diff --git a/client/battle/BattleActionsController.cpp b/client/battle/BattleActionsController.cpp index 1ccdbf10f..4920bb79b 100644 --- a/client/battle/BattleActionsController.cpp +++ b/client/battle/BattleActionsController.cpp @@ -215,7 +215,7 @@ std::vector BattleActionsController::getPossibleActi return std::vector(allActions); } -void BattleActionsController::reorderPossibleActionsPriority(const CStack * stack, MouseHoveredHexContext context) +void BattleActionsController::reorderPossibleActionsPriority(const CStack * stack, const CStack * targetStack) { if(owner.tacticsMode || possibleActions.empty()) return; //this function is not supposed to be called in tactics mode or before getPossibleActionsForStack @@ -229,8 +229,17 @@ void BattleActionsController::reorderPossibleActionsPriority(const CStack * stac case PossiblePlayerBattleAction::NO_LOCATION: case PossiblePlayerBattleAction::FREE_LOCATION: case PossiblePlayerBattleAction::OBSTACLE: - if(!stack->hasBonusOfType(BonusType::NO_SPELLCAST_BY_DEFAULT) && context == MouseHoveredHexContext::OCCUPIED_HEX) - return 1; + if(!stack->hasBonusOfType(BonusType::NO_SPELLCAST_BY_DEFAULT) && targetStack != nullptr) + { + PlayerColor stackOwner = owner.curInt->cb->battleGetOwner(targetStack); + bool enemyTargetingPositiveSpellcast = item.spell().toSpell()->isPositive() && stackOwner != LOCPLINT->playerID; + bool friendTargetingNegativeSpellcast = item.spell().toSpell()->isNegative() && stackOwner == LOCPLINT->playerID; + + if(enemyTargetingPositiveSpellcast || friendTargetingNegativeSpellcast) + return 100; + else + return 1; + } else return 100; //bottom priority break; @@ -788,7 +797,7 @@ PossiblePlayerBattleAction BattleActionsController::selectAction(BattleHex targe const CStack * targetStack = getStackForHex(targetHex); - reorderPossibleActionsPriority(owner.stacksController->getActiveStack(), targetStack ? MouseHoveredHexContext::OCCUPIED_HEX : MouseHoveredHexContext::UNOCCUPIED_HEX); + reorderPossibleActionsPriority(owner.stacksController->getActiveStack(), targetStack); for (PossiblePlayerBattleAction action : possibleActions) { @@ -972,6 +981,11 @@ void BattleActionsController::activateStack() case PossiblePlayerBattleAction::AIMED_SPELL_CREATURE: actionsToSelect.push_back(possibleActions.front()); + actionsToSelect.push_back(PossiblePlayerBattleAction::ATTACK); + break; + case PossiblePlayerBattleAction::ANY_LOCATION: + actionsToSelect.push_back(possibleActions.front()); + actionsToSelect.push_back(PossiblePlayerBattleAction::ATTACK); break; } } @@ -981,8 +995,18 @@ void BattleActionsController::activateStack() void BattleActionsController::onHexRightClicked(BattleHex clickedHex) { - if (spellcastingModeActive()) + auto spellcastActionPredicate = [](PossiblePlayerBattleAction & action) + { + return action.spellcast(); + }; + + bool isCurrentStackInSpellcastMode = std::all_of(possibleActions.begin(), possibleActions.end(), spellcastActionPredicate); + + if (spellcastingModeActive() || isCurrentStackInSpellcastMode) + { endCastingSpell(); + return; + } auto selectedStack = owner.curInt->cb->battleGetStackByPos(clickedHex, true); @@ -998,7 +1022,7 @@ void BattleActionsController::onHexRightClicked(BattleHex clickedHex) bool BattleActionsController::spellcastingModeActive() const { - return heroSpellToCast != nullptr;; + return heroSpellToCast != nullptr; } bool BattleActionsController::currentActionSpellcasting(BattleHex hoveredHex) diff --git a/client/battle/BattleActionsController.h b/client/battle/BattleActionsController.h index 3010ac4e2..b686066bb 100644 --- a/client/battle/BattleActionsController.h +++ b/client/battle/BattleActionsController.h @@ -53,7 +53,7 @@ class BattleActionsController bool isCastingPossibleHere (const CSpell * spell, const CStack *shere, BattleHex myNumber); bool canStackMoveHere (const CStack *sactive, BattleHex MyNumber) const; //TODO: move to BattleState / callback std::vector getPossibleActionsForStack (const CStack *stack) const; //called when stack gets its turn - void reorderPossibleActionsPriority(const CStack * stack, MouseHoveredHexContext context); + void reorderPossibleActionsPriority(const CStack * stack, const CStack * targetStack); bool actionIsLegal(PossiblePlayerBattleAction action, BattleHex hoveredHex); diff --git a/client/battle/BattleWindow.cpp b/client/battle/BattleWindow.cpp index 36cf2441c..78a5f690c 100644 --- a/client/battle/BattleWindow.cpp +++ b/client/battle/BattleWindow.cpp @@ -450,6 +450,10 @@ void BattleWindow::showAlternativeActionIcon(PossiblePlayerBattleAction action) case PossiblePlayerBattleAction::AIMED_SPELL_CREATURE: iconName = variables["actionIconSpell"].String(); break; + + case PossiblePlayerBattleAction::ANY_LOCATION: + iconName = variables["actionIconSpell"].String(); + break; //TODO: figure out purpose of this icon //case PossiblePlayerBattleAction::???: diff --git a/client/gui/ShortcutHandler.cpp b/client/gui/ShortcutHandler.cpp index 9014d1fcf..13f4f7307 100644 --- a/client/gui/ShortcutHandler.cpp +++ b/client/gui/ShortcutHandler.cpp @@ -120,7 +120,7 @@ std::vector ShortcutHandler::translateKeycode(SDL_Keycode key) const {SDLK_KP_MINUS, EShortcut::ADVENTURE_ZOOM_OUT }, {SDLK_BACKSPACE, EShortcut::ADVENTURE_ZOOM_RESET }, {SDLK_q, EShortcut::BATTLE_TOGGLE_QUEUE }, - {SDLK_c, EShortcut::BATTLE_USE_CREATURE_SPELL }, + {SDLK_f, EShortcut::BATTLE_USE_CREATURE_SPELL }, {SDLK_s, EShortcut::BATTLE_SURRENDER }, {SDLK_r, EShortcut::BATTLE_RETREAT }, {SDLK_a, EShortcut::BATTLE_AUTOCOMBAT }, From 207a73b9debbf3bb8bca765bbe9bf060c5dd8d05 Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sun, 27 Aug 2023 18:58:07 +0200 Subject: [PATCH 18/20] Fix mana drain not refreshing battle hero window mana --- client/CPlayerInterface.cpp | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/client/CPlayerInterface.cpp b/client/CPlayerInterface.cpp index f95e31528..4d0e322c8 100644 --- a/client/CPlayerInterface.cpp +++ b/client/CPlayerInterface.cpp @@ -898,6 +898,12 @@ void CPlayerInterface::battleTriggerEffect (const BattleTriggerEffect & bte) RETURN_IF_QUICK_COMBAT; battleInt->effectsController->battleTriggerEffect(bte); + + if(bte.effect == vstd::to_underlying(BonusType::MANA_DRAIN)) + { + const CGHeroInstance * manaDrainedHero = LOCPLINT->cb->getHero(ObjectInstanceID(bte.additionalInfo)); + battleInt->windowObject->heroManaPointsChanged(manaDrainedHero); + } } void CPlayerInterface::battleStacksAttacked(const std::vector & bsa, bool ranged) { From 321c9c2ca6eacd2db54a193550683547201d1a7f Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sun, 27 Aug 2023 20:18:19 +0200 Subject: [PATCH 19/20] Remove now unused enum --- client/battle/BattleActionsController.h | 6 ------ 1 file changed, 6 deletions(-) diff --git a/client/battle/BattleActionsController.h b/client/battle/BattleActionsController.h index b686066bb..86acc8e44 100644 --- a/client/battle/BattleActionsController.h +++ b/client/battle/BattleActionsController.h @@ -23,12 +23,6 @@ VCMI_LIB_NAMESPACE_END class BattleInterface; -enum class MouseHoveredHexContext -{ - UNOCCUPIED_HEX, - OCCUPIED_HEX -}; - /// Class that controls actions that can be performed by player, e.g. moving stacks, attacking, etc /// As well as all relevant feedback for these actions in user interface class BattleActionsController From cba9ddd66af4a4d0767950b645b9660bdd686a1e Mon Sep 17 00:00:00 2001 From: Dydzio Date: Sun, 27 Aug 2023 23:01:04 +0200 Subject: [PATCH 20/20] Update client/battle/BattleActionsController.cpp Co-authored-by: Nordsoft91 --- client/battle/BattleActionsController.cpp | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/client/battle/BattleActionsController.cpp b/client/battle/BattleActionsController.cpp index 4920bb79b..3378140d0 100644 --- a/client/battle/BattleActionsController.cpp +++ b/client/battle/BattleActionsController.cpp @@ -235,13 +235,11 @@ void BattleActionsController::reorderPossibleActionsPriority(const CStack * stac bool enemyTargetingPositiveSpellcast = item.spell().toSpell()->isPositive() && stackOwner != LOCPLINT->playerID; bool friendTargetingNegativeSpellcast = item.spell().toSpell()->isNegative() && stackOwner == LOCPLINT->playerID; - if(enemyTargetingPositiveSpellcast || friendTargetingNegativeSpellcast) - return 100; - else + if(!enemyTargetingPositiveSpellcast && !friendTargetingNegativeSpellcast) return 1; } - else - return 100; //bottom priority + return 100; //bottom priority + break; case PossiblePlayerBattleAction::RANDOM_GENIE_SPELL: return 2;