mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 11:26:37 +00:00 
			
		
		
		
	Merge pull request #1067 from Allofich/intervention
Use correct vfx for teleport spells
This commit is contained in:
		
						commit
						acd0a5ea01
					
				
					 1 changed files with 15 additions and 0 deletions
				
			
		|  | @ -646,14 +646,28 @@ namespace MWMechanics | |||
|             if (target != getPlayer()) | ||||
|                 return false; | ||||
| 
 | ||||
|             MWRender::Animation* anim = MWBase::Environment::get().getWorld()->getAnimation(mCaster); | ||||
| 
 | ||||
|             if (effectId == ESM::MagicEffect::DivineIntervention) | ||||
|             { | ||||
|                 MWBase::Environment::get().getWorld()->teleportToClosestMarker(target, "divinemarker"); | ||||
|                 anim->removeEffect(ESM::MagicEffect::DivineIntervention); | ||||
|                 const ESM::Static* fx = MWBase::Environment::get().getWorld()->getStore().get<ESM::Static>() | ||||
|                     .search("VFX_Summon_end"); | ||||
|                 if (fx) | ||||
|                     MWBase::Environment::get().getWorld()->spawnEffect("meshes\\" + fx->mModel, | ||||
|                         "", mCaster.getRefData().getPosition().asVec3()); | ||||
|                 return true; | ||||
|             } | ||||
|             else if (effectId == ESM::MagicEffect::AlmsiviIntervention) | ||||
|             { | ||||
|                 MWBase::Environment::get().getWorld()->teleportToClosestMarker(target, "templemarker"); | ||||
|                 anim->removeEffect(ESM::MagicEffect::AlmsiviIntervention); | ||||
|                 const ESM::Static* fx = MWBase::Environment::get().getWorld()->getStore().get<ESM::Static>() | ||||
|                     .search("VFX_Summon_end"); | ||||
|                 if (fx) | ||||
|                     MWBase::Environment::get().getWorld()->spawnEffect("meshes\\" + fx->mModel, | ||||
|                         "", mCaster.getRefData().getPosition().asVec3()); | ||||
|                 return true; | ||||
|             } | ||||
| 
 | ||||
|  | @ -674,6 +688,7 @@ namespace MWMechanics | |||
|                     MWWorld::ActionTeleport action(markedCell->isExterior() ? "" : markedCell->getCell()->mName, | ||||
|                                             markedPosition, false); | ||||
|                     action.execute(target); | ||||
|                     anim->removeEffect(ESM::MagicEffect::Recall); | ||||
|                 } | ||||
|                 return true; | ||||
|             } | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue