1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-12 02:28:11 +02:00

Fixed moving through garrisons & teleporters

This commit is contained in:
Ivan Savenko 2023-09-16 13:40:49 +03:00
parent 2355aab139
commit f08028a158
2 changed files with 17 additions and 26 deletions

View File

@ -48,8 +48,8 @@ std::optional<int3> HeroMovementController::getNextTile(const CGHeroInstance * h
bool HeroMovementController::isHeroMovingThroughGarrison(const CGHeroInstance * hero, const CArmedInstance * garrison) const bool HeroMovementController::isHeroMovingThroughGarrison(const CGHeroInstance * hero, const CArmedInstance * garrison) const
{ {
assert(LOCPLINT->localState->hasPath(hero)); if(!duringMovement)
assert(duringMovement); return false;
if (!LOCPLINT->localState->hasPath(hero)) if (!LOCPLINT->localState->hasPath(hero))
return false; return false;
@ -70,6 +70,7 @@ void HeroMovementController::onPlayerTurnStarted()
assert(duringMovement == false); assert(duringMovement == false);
assert(stoppingMovement == false); assert(stoppingMovement == false);
duringMovement = false; duringMovement = false;
currentlyMovingHero = nullptr;
} }
void HeroMovementController::onBattleStarted() void HeroMovementController::onBattleStarted()
@ -82,10 +83,12 @@ void HeroMovementController::onBattleStarted()
void HeroMovementController::showTeleportDialog(const CGHeroInstance * hero, TeleportChannelID channel, TTeleportExitsList exits, bool impassable, QueryID askID) void HeroMovementController::showTeleportDialog(const CGHeroInstance * hero, TeleportChannelID channel, TTeleportExitsList exits, bool impassable, QueryID askID)
{ {
assert(hero == currentlyMovingHero);
if (!LOCPLINT->localState->hasPath(hero)) if (!LOCPLINT->localState->hasPath(hero))
{ {
assert(exits.size() == 1); // select random? Let server select? // Hero enters teleporter without specifying exit - select it randomly
LOCPLINT->cb->selectionMade(0, askID); LOCPLINT->cb->selectionMade(-1, askID);
return; return;
} }
@ -103,8 +106,8 @@ void HeroMovementController::showTeleportDialog(const CGHeroInstance * hero, Tel
} }
} }
assert(0); // exit not found? How? select random? Let server select? assert(0); // exit not found? How?
LOCPLINT->cb->selectionMade(0, askID); LOCPLINT->cb->selectionMade(-1, askID);
return; return;
} }
@ -116,6 +119,7 @@ void HeroMovementController::updatePath(const CGHeroInstance * hero, const TryMo
if (!LOCPLINT->localState->hasPath(hero)) if (!LOCPLINT->localState->hasPath(hero))
return; // may happen when hero teleports return; // may happen when hero teleports
assert(hero == currentlyMovingHero);
assert(LOCPLINT->makingTurn); assert(LOCPLINT->makingTurn);
assert(getNextTile(hero).has_value()); assert(getNextTile(hero).has_value());
@ -148,8 +152,6 @@ void HeroMovementController::updatePath(const CGHeroInstance * hero, const TryMo
void HeroMovementController::heroMoved(const CGHeroInstance * hero, const TryMoveHero & details) void HeroMovementController::heroMoved(const CGHeroInstance * hero, const TryMoveHero & details)
{ {
//assert(duringMovement == true); // May be false if hero teleported
if (details.result == TryMoveHero::EMBARK || details.result == TryMoveHero::DISEMBARK) if (details.result == TryMoveHero::EMBARK || details.result == TryMoveHero::DISEMBARK)
{ {
if(hero->getRemovalSound() && hero->tempOwner == LOCPLINT->playerID) if(hero->getRemovalSound() && hero->tempOwner == LOCPLINT->playerID)
@ -195,16 +197,15 @@ void HeroMovementController::heroMoved(const CGHeroInstance * hero, const TryMov
void HeroMovementController::onMoveHeroApplied() void HeroMovementController::onMoveHeroApplied()
{ {
auto const * hero = LOCPLINT->localState->getCurrentHero();
assert(hero);
//check if user cancelled movement //check if user cancelled movement
if (GH.input().ignoreEventsUntilInput()) if (GH.input().ignoreEventsUntilInput())
stoppingMovement = true; stoppingMovement = true;
if (duringMovement) if (duringMovement)
{ {
assert(currentlyMovingHero);
auto const * hero = currentlyMovingHero;
bool canMove = LOCPLINT->localState->hasPath(hero) && LOCPLINT->localState->getPath(hero).nextNode().turns == 0; bool canMove = LOCPLINT->localState->hasPath(hero) && LOCPLINT->localState->getPath(hero).nextNode().turns == 0;
bool wantStop = stoppingMovement; bool wantStop = stoppingMovement;
bool canStop = !canMove || canHeroStopAtNode(LOCPLINT->localState->getPath(hero).currNode()); bool canStop = !canMove || canHeroStopAtNode(LOCPLINT->localState->getPath(hero).currNode());
@ -227,7 +228,7 @@ void HeroMovementController::onMoveHeroApplied()
void HeroMovementController::movementAbortRequested() void HeroMovementController::movementAbortRequested()
{ {
if(duringMovement) if(duringMovement)
endHeroMove(LOCPLINT->localState->getCurrentHero()); endHeroMove(currentlyMovingHero);
} }
void HeroMovementController::endHeroMove(const CGHeroInstance * hero) void HeroMovementController::endHeroMove(const CGHeroInstance * hero)
@ -235,6 +236,7 @@ void HeroMovementController::endHeroMove(const CGHeroInstance * hero)
assert(duringMovement == true); assert(duringMovement == true);
duringMovement = false; duringMovement = false;
stoppingMovement = false; stoppingMovement = false;
currentlyMovingHero = nullptr;
stopMovementSound(); stopMovementSound();
adventureInt->onHeroChanged(hero); adventureInt->onHeroChanged(hero);
CCS->curh->show(); CCS->curh->show();
@ -309,6 +311,7 @@ void HeroMovementController::movementStartRequested(const CGHeroInstance * h, co
{ {
assert(duringMovement == false); assert(duringMovement == false);
duringMovement = true; duringMovement = true;
currentlyMovingHero = h;
CCS->curh->show(); CCS->curh->show();
moveHeroOnce(h, path); moveHeroOnce(h, path);
@ -344,17 +347,4 @@ void HeroMovementController::moveHeroOnce(const CGHeroInstance * h, const CGPath
LOCPLINT->cb->moveHero(h, nextCoord, useTransit); LOCPLINT->cb->moveHero(h, nextCoord, useTransit);
return; return;
} }
// bool guarded = LOCPLINT->cb->isInTheMap(LOCPLINT->cb->getGuardingCreaturePosition(nextCoord - int3(1, 0, 0)));
// if ((!useTransit && guarded) || LOCPLINT->showingDialog->get() == true) // Abort movement if a guard was fought or there is a dialog to display (Mantis #1136)
// break;
// stopMovementSound();
//
// //Update cursor so icon can change if needed when it reappears; doesn;'t apply if a dialog box pops up at the end of the movement
// if (!LOCPLINT->showingDialog->get())
// GH.fakeMouseMove();
//
// CGI->mh->waitForOngoingAnimations();
// setMovementStatus(false);
} }

View File

@ -32,6 +32,7 @@ class HeroMovementController
/// movement was requested to be terminated, e.g. by player or due to inability to move /// movement was requested to be terminated, e.g. by player or due to inability to move
bool stoppingMovement = false; bool stoppingMovement = false;
const CGHeroInstance * currentlyMovingHero = nullptr;
AudioPath currentMovementSoundName; AudioPath currentMovementSoundName;
int currentMovementSoundChannel = -1; int currentMovementSoundChannel = -1;