mirror of
https://github.com/vcmi/vcmi.git
synced 2024-11-24 08:32:34 +02:00
Fix crash on defeating hero in boat
This commit is contained in:
parent
bb03abdce6
commit
a78f7de9cd
@ -251,6 +251,26 @@ void MapViewController::fadeInObject(const CGObjectInstance * obj)
|
||||
|
||||
void MapViewController::removeObject(const CGObjectInstance * obj)
|
||||
{
|
||||
if (obj->ID == Obj::BOAT)
|
||||
{
|
||||
auto * boat = dynamic_cast<const CGBoat*>(obj);
|
||||
if (boat->hero)
|
||||
{
|
||||
view->invalidate(context, boat->hero->id);
|
||||
state->removeObject(boat->hero);
|
||||
}
|
||||
}
|
||||
|
||||
if (obj->ID == Obj::HERO)
|
||||
{
|
||||
auto * hero = dynamic_cast<const CGHeroInstance*>(obj);
|
||||
if (hero->boat)
|
||||
{
|
||||
view->invalidate(context, hero->boat->id);
|
||||
state->removeObject(hero->boat);
|
||||
}
|
||||
}
|
||||
|
||||
view->invalidate(context, obj->id);
|
||||
state->removeObject(obj);
|
||||
}
|
||||
@ -265,7 +285,7 @@ void MapViewController::onBeforeHeroEmbark(const CGHeroInstance * obj, const int
|
||||
{
|
||||
if(isEventVisible(obj, from, dest))
|
||||
{
|
||||
onObjectFadeOut(obj);
|
||||
fadeOutObject(obj);
|
||||
setViewCenter(obj->getSightCenter());
|
||||
}
|
||||
else
|
||||
@ -288,7 +308,7 @@ void MapViewController::onAfterHeroDisembark(const CGHeroInstance * obj, const i
|
||||
{
|
||||
if(isEventVisible(obj, from, dest))
|
||||
{
|
||||
onObjectFadeIn(obj);
|
||||
fadeInObject(obj);
|
||||
setViewCenter(obj->getSightCenter());
|
||||
}
|
||||
addObject(obj);
|
||||
|
Loading…
Reference in New Issue
Block a user