/* #include "actor.h" #include "info.h" #include "m_random.h" #include "s_sound.h" #include "p_local.h" #include "a_action.h" #include "a_sharedglobal.h" #include "gstrings.h" #include "thingdef/thingdef.h" */ static FRandom pr_dripblood ("DripBlood"); static FRandom pr_knightatk ("KnightAttack"); //---------------------------------------------------------------------------- // // PROC A_DripBlood // //---------------------------------------------------------------------------- DEFINE_ACTION_FUNCTION(AActor, A_DripBlood) { PARAM_ACTION_PROLOGUE; AActor *mo; fixedvec3 pos = self->Vec3Offset( (pr_dripblood.Random2 () << 11), (pr_dripblood.Random2 () << 11), 0); mo = Spawn ("Blood", pos, ALLOW_REPLACE); mo->velx = pr_dripblood.Random2 () << 10; mo->vely = pr_dripblood.Random2 () << 10; mo->gravity = FRACUNIT/8; return 0; } //---------------------------------------------------------------------------- // // PROC A_KnightAttack // //---------------------------------------------------------------------------- DEFINE_ACTION_FUNCTION(AActor, A_KnightAttack) { PARAM_ACTION_PROLOGUE; if (!self->target) { return 0; } if (self->CheckMeleeRange ()) { int damage = pr_knightatk.HitDice (3); int newdam = P_DamageMobj (self->target, self, self, damage, NAME_Melee); P_TraceBleed (newdam > 0 ? newdam : damage, self->target, self); S_Sound (self, CHAN_BODY, "hknight/melee", 1, ATTN_NORM); return 0; } // Throw axe S_Sound (self, CHAN_BODY, self->AttackSound, 1, ATTN_NORM); if (self->flags & MF_SHADOW || pr_knightatk () < 40) { // Red axe P_SpawnMissileZ (self, self->Z() + 36*FRACUNIT, self->target, PClass::FindActor("RedAxe")); return; } // Green axe P_SpawnMissileZ (self, self->Z() + 36*FRACUNIT, self->target, PClass::FindActor("KnightAxe")); }