Ancordia_PRC8/_removed/x2_s0_crumble.nss
2024-06-14 00:06:09 -04:00

119 lines
4.8 KiB
Plaintext

//::///////////////////////////////////////////////
//:: Crumble
//:: X2_S0_Crumble
//:: Copyright (c) 2001 Bioware Corp.
//:://////////////////////////////////////////////
/*
// This spell inflicts 1d6 points of damage per
// caster level to Constructs to a maximum of 15d6.
// This spell does not affect living creatures.
*/
//:://////////////////////////////////////////////
//:: Created By: Georg Zoeller
//:: Created On: Oct 2003/
//:: 2004-01-02: GZ: Removed Spell resistance check
//:://////////////////////////////////////////////
/*
Patch 1.70, fix by Shadooow
- was missing target check and could affect friendly tarets at no-pvp area
*/
#include "70_inc_spells"
#include "x0_i0_spells"
#include "x2_inc_spellhook"
void DoCrumble (int nDam, object oCaster, object oTarget);
void main()
{
/*
Spellcast Hook Code
Added 2003-07-07 by Georg Zoeller
If you want to make changes to all spells,
check x2_inc_spellhook.nss to find out more
*/
if (!X2PreSpellCastCode())
{
// If code within the PreSpellCastHook (i.e. UMD) reports FALSE, do not run this spell
return;
}
// End of Spell Cast Hook
spellsDeclareMajorVariables();
int nCasterLvl = spell.Level;
int nType = GetObjectType(spell.Target);
int nRacial = GetRacialType(spell.Target);
//Maximum caster level of 15. //minimum safety check is handled in new engine
if (nCasterLvl > 12)
{
nCasterLvl = 12;
}
if(spellsIsTarget(spell.Target, SPELL_TARGET_SINGLETARGET, spell.Caster) &&
(nType == OBJECT_TYPE_CREATURE || nType == OBJECT_TYPE_PLACEABLE || nType == OBJECT_TYPE_DOOR) &&
(GetRacialType(spell.Target) == RACIAL_TYPE_CONSTRUCT || GetLevelByClass(CLASS_TYPE_CONSTRUCT,spell.Target)))
{
SignalEvent(spell.Target, EventSpellCastAt(spell.Caster, spell.Id));
effect eCrumb = EffectVisualEffect(VFX_FNF_SCREEN_SHAKE);
ApplyEffectToObject(DURATION_TYPE_INSTANT, eCrumb, spell.Target);
int nDam = MaximizeOrEmpower(6,nCasterLvl,spell.Meta);
nDam = FloatToInt(nDam * 1.5);
if (nDam>0)//can't happen anyway
{
//----------------------------------------------------------------------
// * Sever the tie between spellId and effect, allowing it to
// * bypass any magic resistance
//----------------------------------------------------------------------
/*DelayCommand(0.1,*/DoCrumble(nDam, spell.Caster, spell.Target);//);
}
}
//Make it work on non-constructs
else if (spellsIsTarget(spell.Target, SPELL_TARGET_SINGLETARGET, spell.Caster) &&
(nType == OBJECT_TYPE_CREATURE || nType == OBJECT_TYPE_PLACEABLE || nType == OBJECT_TYPE_DOOR))
{
SignalEvent(spell.Target, EventSpellCastAt(spell.Caster, spell.Id));
effect eCrumb = EffectVisualEffect(VFX_FNF_SCREEN_SHAKE);
ApplyEffectToObject(DURATION_TYPE_INSTANT, eCrumb, spell.Target);
int nDam = MaximizeOrEmpower(6,nCasterLvl,spell.Meta);
if (nDam>0)//can't happen anyway
{
//----------------------------------------------------------------------
// * Sever the tie between spellId and effect, allowing it to
// * bypass any magic resistance
//----------------------------------------------------------------------
/*DelayCommand(0.1,*/DoCrumble(nDam, spell.Caster, spell.Target);//);
}
}
}
//------------------------------------------------------------------------------
// This part is moved into a delayed function in order to alllow it to bypass
// Golem Spell Immunity. Magic works by rendering all effects applied
// from within a spellscript useless. Delaying the creation and application of
// an effect causes it to loose it's SpellId, making it possible to ignore
// Magic Immunity. Hacktastic! //shadooow: BS, useless, it does work without delay
//------------------------------------------------------------------------------
void DoCrumble (int nDam, object oCaster, object oTarget)
{
float fDist = GetDistanceBetween(oCaster, oTarget);
float fDelay = fDist/(3.0 * log(fDist) + 2.0);
effect eDam = EffectDamage(nDam, DAMAGE_TYPE_SONIC);
effect eMissile = EffectVisualEffect(VFX_FNF_MYSTICAL_EXPLOSION);
effect eCrumb = EffectVisualEffect(VFX_FNF_SCREEN_SHAKE);
effect eVis = EffectVisualEffect(135);
ApplyEffectToObject(DURATION_TYPE_INSTANT, eCrumb, oTarget);
if (GetRacialType(oTarget) == RACIAL_TYPE_CONSTRUCT || GetLevelByClass(CLASS_TYPE_CONSTRUCT,oTarget))
{
DelayCommand(fDelay, ApplyEffectToObject(DURATION_TYPE_TEMPORARY, eVis, oTarget));
}
DelayCommand(fDelay, ApplyEffectToObject(DURATION_TYPE_INSTANT, eDam, oTarget));
DelayCommand(0.5, ApplyEffectToObject(DURATION_TYPE_INSTANT, eMissile, oTarget));
}