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:
parent
2355aab139
commit
f08028a158
@ -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);
|
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user