mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-27 03:35:27 +00:00
Make unsuccessful magic teleportation attempts detectable (bug #3765)
This commit is contained in:
parent
cb5a57e41b
commit
7a7e390099
@ -5,6 +5,7 @@
|
|||||||
Bug #2987: Editor: some chance and AI data fields can overflow
|
Bug #2987: Editor: some chance and AI data fields can overflow
|
||||||
Bug #3623: Fix HiDPI on Windows
|
Bug #3623: Fix HiDPI on Windows
|
||||||
Bug #3733: Normal maps are inverted on mirrored UVs
|
Bug #3733: Normal maps are inverted on mirrored UVs
|
||||||
|
Bug #3765: DisableTeleporting makes Mark/Recall/Intervention effects undetectable
|
||||||
Bug #4329: Removed birthsign abilities are restored after reloading the save
|
Bug #4329: Removed birthsign abilities are restored after reloading the save
|
||||||
Bug #4383: Bow model obscures crosshair when arrow is drawn
|
Bug #4383: Bow model obscures crosshair when arrow is drawn
|
||||||
Bug #4411: Reloading a saved game while falling prevents damage in some cases
|
Bug #4411: Reloading a saved game while falling prevents damage in some cases
|
||||||
|
@ -295,17 +295,6 @@ namespace MWMechanics
|
|||||||
return true; // must still apply to get visual effect and have target regard it as attack
|
return true; // must still apply to get visual effect and have target regard it as attack
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case ESM::MagicEffect::AlmsiviIntervention:
|
|
||||||
case ESM::MagicEffect::DivineIntervention:
|
|
||||||
case ESM::MagicEffect::Mark:
|
|
||||||
case ESM::MagicEffect::Recall:
|
|
||||||
if (!MWBase::Environment::get().getWorld()->isTeleportingEnabled())
|
|
||||||
{
|
|
||||||
if (castByPlayer)
|
|
||||||
MWBase::Environment::get().getWindowManager()->messageBox("#{sTeleportDisabled}");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case ESM::MagicEffect::WaterWalking:
|
case ESM::MagicEffect::WaterWalking:
|
||||||
if (target.getClass().isPureWaterCreature(target) && MWBase::Environment::get().getWorld()->isSwimming(target))
|
if (target.getClass().isPureWaterCreature(target) && MWBase::Environment::get().getWorld()->isSwimming(target))
|
||||||
return false;
|
return false;
|
||||||
@ -747,21 +736,19 @@ namespace MWMechanics
|
|||||||
else if (target.getClass().isActor() && target == getPlayer())
|
else if (target.getClass().isActor() && target == getPlayer())
|
||||||
{
|
{
|
||||||
MWRender::Animation* anim = MWBase::Environment::get().getWorld()->getAnimation(mCaster);
|
MWRender::Animation* anim = MWBase::Environment::get().getWorld()->getAnimation(mCaster);
|
||||||
|
bool teleportingEnabled = MWBase::Environment::get().getWorld()->isTeleportingEnabled();
|
||||||
|
|
||||||
if (effectId == ESM::MagicEffect::DivineIntervention)
|
if (effectId == ESM::MagicEffect::DivineIntervention || effectId == ESM::MagicEffect::AlmsiviIntervention)
|
||||||
{
|
{
|
||||||
MWBase::Environment::get().getWorld()->teleportToClosestMarker(target, "divinemarker");
|
if (!teleportingEnabled)
|
||||||
anim->removeEffect(ESM::MagicEffect::DivineIntervention);
|
{
|
||||||
const ESM::Static* fx = MWBase::Environment::get().getWorld()->getStore().get<ESM::Static>()
|
if (caster == getPlayer())
|
||||||
.search("VFX_Summon_end");
|
MWBase::Environment::get().getWindowManager()->messageBox("#{sTeleportDisabled}");
|
||||||
if (fx)
|
return true;
|
||||||
anim->addEffect("meshes\\" + fx->mModel, -1);
|
}
|
||||||
return true;
|
std::string marker = (effectId == ESM::MagicEffect::DivineIntervention) ? "divinemarker" : "templemarker";
|
||||||
}
|
MWBase::Environment::get().getWorld()->teleportToClosestMarker(target, marker);
|
||||||
else if (effectId == ESM::MagicEffect::AlmsiviIntervention)
|
anim->removeEffect(effectId);
|
||||||
{
|
|
||||||
MWBase::Environment::get().getWorld()->teleportToClosestMarker(target, "templemarker");
|
|
||||||
anim->removeEffect(ESM::MagicEffect::AlmsiviIntervention);
|
|
||||||
const ESM::Static* fx = MWBase::Environment::get().getWorld()->getStore().get<ESM::Static>()
|
const ESM::Static* fx = MWBase::Environment::get().getWorld()->getStore().get<ESM::Static>()
|
||||||
.search("VFX_Summon_end");
|
.search("VFX_Summon_end");
|
||||||
if (fx)
|
if (fx)
|
||||||
@ -770,12 +757,26 @@ namespace MWMechanics
|
|||||||
}
|
}
|
||||||
else if (effectId == ESM::MagicEffect::Mark)
|
else if (effectId == ESM::MagicEffect::Mark)
|
||||||
{
|
{
|
||||||
MWBase::Environment::get().getWorld()->getPlayer().markPosition(
|
if (teleportingEnabled)
|
||||||
target.getCell(), target.getRefData().getPosition());
|
{
|
||||||
|
MWBase::Environment::get().getWorld()->getPlayer().markPosition(
|
||||||
|
target.getCell(), target.getRefData().getPosition());
|
||||||
|
}
|
||||||
|
else if (caster == getPlayer())
|
||||||
|
{
|
||||||
|
MWBase::Environment::get().getWindowManager()->messageBox("#{sTeleportDisabled}");
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (effectId == ESM::MagicEffect::Recall)
|
else if (effectId == ESM::MagicEffect::Recall)
|
||||||
{
|
{
|
||||||
|
if (!teleportingEnabled)
|
||||||
|
{
|
||||||
|
if (caster == getPlayer())
|
||||||
|
MWBase::Environment::get().getWindowManager()->messageBox("#{sTeleportDisabled}");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
MWWorld::CellStore* markedCell = nullptr;
|
MWWorld::CellStore* markedCell = nullptr;
|
||||||
ESM::Position markedPosition;
|
ESM::Position markedPosition;
|
||||||
|
|
||||||
@ -785,7 +786,7 @@ namespace MWMechanics
|
|||||||
MWWorld::ActionTeleport action(markedCell->isExterior() ? "" : markedCell->getCell()->mName,
|
MWWorld::ActionTeleport action(markedCell->isExterior() ? "" : markedCell->getCell()->mName,
|
||||||
markedPosition, false);
|
markedPosition, false);
|
||||||
action.execute(target);
|
action.execute(target);
|
||||||
anim->removeEffect(ESM::MagicEffect::Recall);
|
anim->removeEffect(effectId);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user