mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-28 03:57:02 +02:00
small fix
This commit is contained in:
parent
f54b84ead9
commit
f0435d8b8e
@ -44,6 +44,7 @@
|
|||||||
#include "../render/CAnimation.h"
|
#include "../render/CAnimation.h"
|
||||||
#include "../render/IRenderHandler.h"
|
#include "../render/IRenderHandler.h"
|
||||||
#include "../adventureMap/CInGameConsole.h"
|
#include "../adventureMap/CInGameConsole.h"
|
||||||
|
#include "../eventsSDL/InputHandler.h"
|
||||||
|
|
||||||
#include "../../CCallback.h"
|
#include "../../CCallback.h"
|
||||||
#include "../../lib/CStack.h"
|
#include "../../lib/CStack.h"
|
||||||
@ -470,6 +471,7 @@ void QuickSpellPanel::create()
|
|||||||
});
|
});
|
||||||
button->setOverlay(std::make_shared<CAnimImage>(AnimationPath::builtin("spellint"), !spellIdentifier.empty() ? id.num + 1 : 0));
|
button->setOverlay(std::make_shared<CAnimImage>(AnimationPath::builtin("spellint"), !spellIdentifier.empty() ? id.num + 1 : 0));
|
||||||
button->addPopupCallback([this, i, hero](){
|
button->addPopupCallback([this, i, hero](){
|
||||||
|
GH.input().hapticFeedback();
|
||||||
GH.windows().createAndPushWindow<CSpellWindow>(hero, owner.curInt.get(), true, [this, i](SpellID spell){
|
GH.windows().createAndPushWindow<CSpellWindow>(hero, owner.curInt.get(), true, [this, i](SpellID spell){
|
||||||
Settings configID = persistentStorage.write["quickSpell"][std::to_string(i)];
|
Settings configID = persistentStorage.write["quickSpell"][std::to_string(i)];
|
||||||
configID->String() = spell.toSpell()->identifier;
|
configID->String() = spell.toSpell()->identifier;
|
||||||
@ -479,7 +481,7 @@ void QuickSpellPanel::create()
|
|||||||
|
|
||||||
if(!id.hasValue() || !id.toSpell()->canBeCast(owner.getBattle().get(), spells::Mode::HERO, hero))
|
if(!id.hasValue() || !id.toSpell()->canBeCast(owner.getBattle().get(), spells::Mode::HERO, hero))
|
||||||
{
|
{
|
||||||
buttonsDisabled.push_back(std::make_shared<TransparentFilledRectangle>(Rect(2, 5 + 37 * i, 48, 36), ColorRGBA(0, 0, 0, 172)));
|
buttonsDisabled.push_back(std::make_shared<TransparentFilledRectangle>(Rect(2, 5 + 37 * i, 48, 36), ColorRGBA(0, 0, 0, 128)));
|
||||||
}
|
}
|
||||||
labels.push_back(std::make_shared<CLabel>(7, 8 + 37 * i, EFonts::FONT_TINY, ETextAlignment::TOPLEFT, Colors::WHITE, config["keyboard"]["battleSpellShortcut" + std::to_string(i)].String()));
|
labels.push_back(std::make_shared<CLabel>(7, 8 + 37 * i, EFonts::FONT_TINY, ETextAlignment::TOPLEFT, Colors::WHITE, config["keyboard"]["battleSpellShortcut" + std::to_string(i)].String()));
|
||||||
|
|
||||||
|
@ -160,6 +160,8 @@ private:
|
|||||||
|
|
||||||
BattleInterface & owner;
|
BattleInterface & owner;
|
||||||
public:
|
public:
|
||||||
|
bool isEnabled; // isActive() is not working on multiple conditions, because of this we need a seperate flag
|
||||||
|
|
||||||
QuickSpellPanel(BattleInterface & owner);
|
QuickSpellPanel(BattleInterface & owner);
|
||||||
|
|
||||||
void create();
|
void create();
|
||||||
|
@ -226,6 +226,7 @@ void BattleWindow::hideStickyQuickSpellWindow()
|
|||||||
showStickyQuickSpellWindow->Bool() = false;
|
showStickyQuickSpellWindow->Bool() = false;
|
||||||
|
|
||||||
quickSpellWindow->disable();
|
quickSpellWindow->disable();
|
||||||
|
quickSpellWindow->isEnabled = false;
|
||||||
|
|
||||||
setPositionInfoWindow();
|
setPositionInfoWindow();
|
||||||
createTimerInfoWindows();
|
createTimerInfoWindows();
|
||||||
@ -238,9 +239,15 @@ void BattleWindow::showStickyQuickSpellWindow()
|
|||||||
showStickyQuickSpellWindow->Bool() = true;
|
showStickyQuickSpellWindow->Bool() = true;
|
||||||
|
|
||||||
if(GH.screenDimensions().x >= 1050)
|
if(GH.screenDimensions().x >= 1050)
|
||||||
|
{
|
||||||
quickSpellWindow->enable();
|
quickSpellWindow->enable();
|
||||||
|
quickSpellWindow->isEnabled = true;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
quickSpellWindow->disable();
|
quickSpellWindow->disable();
|
||||||
|
quickSpellWindow->isEnabled = false;
|
||||||
|
}
|
||||||
|
|
||||||
setPositionInfoWindow();
|
setPositionInfoWindow();
|
||||||
createTimerInfoWindows();
|
createTimerInfoWindows();
|
||||||
@ -251,7 +258,7 @@ void BattleWindow::createTimerInfoWindows()
|
|||||||
{
|
{
|
||||||
OBJ_CONSTRUCTION_CAPTURING_ALL_NO_DISPOSE;
|
OBJ_CONSTRUCTION_CAPTURING_ALL_NO_DISPOSE;
|
||||||
|
|
||||||
int xOffsetAttacker = quickSpellWindow->isActive() ? -53 : 0;
|
int xOffsetAttacker = quickSpellWindow->isEnabled ? -53 : 0;
|
||||||
|
|
||||||
if(LOCPLINT->cb->getStartInfo()->turnTimerInfo.battleTimer != 0 || LOCPLINT->cb->getStartInfo()->turnTimerInfo.unitTimer != 0)
|
if(LOCPLINT->cb->getStartInfo()->turnTimerInfo.battleTimer != 0 || LOCPLINT->cb->getStartInfo()->turnTimerInfo.unitTimer != 0)
|
||||||
{
|
{
|
||||||
@ -373,7 +380,7 @@ void BattleWindow::updateQueue()
|
|||||||
|
|
||||||
void BattleWindow::setPositionInfoWindow()
|
void BattleWindow::setPositionInfoWindow()
|
||||||
{
|
{
|
||||||
int xOffsetAttacker = quickSpellWindow->isActive() ? -53 : 0;
|
int xOffsetAttacker = quickSpellWindow->isEnabled ? -53 : 0;
|
||||||
if(defenderHeroWindow)
|
if(defenderHeroWindow)
|
||||||
{
|
{
|
||||||
Point position = (GH.screenDimensions().x >= 1000)
|
Point position = (GH.screenDimensions().x >= 1000)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user