From fed15c3e7d6bb300c56a3c0c554cc342e804350d Mon Sep 17 00:00:00 2001 From: Mario Date: Sun, 14 Apr 2013 02:18:21 +1000 Subject: [PATCH] Fix scrag not falling when killed --- qcsrc/client/monsters.qc | 11 ++++++-- qcsrc/server/monsters/lib/monsters.qc | 8 ++++-- qcsrc/server/monsters/monster/wizard.qc | 37 +++++++++++++------------ 3 files changed, 35 insertions(+), 21 deletions(-) diff --git a/qcsrc/client/monsters.qc b/qcsrc/client/monsters.qc index 516700de00..ec1919d62a 100644 --- a/qcsrc/client/monsters.qc +++ b/qcsrc/client/monsters.qc @@ -262,6 +262,14 @@ void monster_changeteam() self.colormap = 1024 + (self.team - 1) * 17; } +void monster_die() +{ + if(self.monsterid == MONSTER_SPIDER) + self.angles += '180 0 0'; + + self.solid = SOLID_CORPSE; +} + void monster_draw() { float dt; @@ -383,8 +391,7 @@ void ent_monster() _tmp = ReadByte(); if(_tmp == 0 && self.health != 0) - if(self.monsterid == MONSTER_SPIDER) - self.angles += '180 0 0'; + monster_die(); self.health = _tmp; } diff --git a/qcsrc/server/monsters/lib/monsters.qc b/qcsrc/server/monsters/lib/monsters.qc index 083f07ac90..bf12cb4e8a 100644 --- a/qcsrc/server/monsters/lib/monsters.qc +++ b/qcsrc/server/monsters/lib/monsters.qc @@ -833,8 +833,6 @@ void monsters_damage (entity inflictor, entity attacker, float damage, float dea frag_target = self; MUTATOR_CALLHOOK(MonsterDies); - self.SendFlags |= MSF_MOVE; - if(self.health <= -100) // check if we're already gibbed { Violence_GibSplash(self, 1, 0.5, attacker); @@ -874,6 +872,12 @@ void monster_hook_death() self.takedamage = DAMAGE_AIM; self.enemy = world; self.movetype = MOVETYPE_TOSS; + self.moveto = self.origin; + + if not(self.flags & FL_FLY) + self.velocity = '0 0 0'; + + self.SendFlags |= MSF_MOVE; totalspawned -= 1; } diff --git a/qcsrc/server/monsters/monster/wizard.qc b/qcsrc/server/monsters/monster/wizard.qc index cc9374807f..e87555f8b7 100644 --- a/qcsrc/server/monsters/monster/wizard.qc +++ b/qcsrc/server/monsters/monster/wizard.qc @@ -37,14 +37,10 @@ void Wiz_FastExplode() void Wiz_FastTouch () { - PROJECTILE_TOUCH; - if(other == self.owner) return; - if(teamplay) - if(other.team == self.owner.team) - return; + PROJECTILE_TOUCH; pointparticles(particleeffectnum("TE_WIZSPIKE"), self.origin, '0 0 0', 1); @@ -53,17 +49,10 @@ void Wiz_FastTouch () void Wiz_StartFast () { - local entity missile; - local vector dir = '0 0 0'; - local float dist = 0, flytime = 0; + entity missile; + vector dir = normalize((self.enemy.origin + '0 0 10') - self.origin); self.attack_finished_single = time + 0.2; - - dir = normalize((self.enemy.origin + '0 0 10') - self.origin); - dist = vlen (self.enemy.origin - self.origin); - flytime = dist * 0.002; - if (flytime < 0.1) - flytime = 0.1; self.v_angle = self.angles; makevectors (self.angles); @@ -112,13 +101,27 @@ void wizard_fastattack () Wiz_StartFast(); } +void wizard_dead_think() +{ + self.think = wizard_dead_think; + self.nextthink = time + self.ticrate; + + if(time >= self.ltime) + { + Monster_Fade(); + return; + } + + self.SendFlags |= MSF_MOVE; // keep up to date on the monster's location +} + void wizard_die () { Monster_CheckDropCvars ("wizard"); - self.think = Monster_Fade; - self.nextthink = time + 5; - self.flags = FL_ONGROUND; + self.think = wizard_dead_think; // exception for wizard, as it needs to keep moving + self.ltime = time + 5; + self.nextthink = time + self.ticrate; self.velocity_x = -200 + 400 * random(); self.velocity_y = -200 + 400 * random(); self.velocity_z = 100 + 100 * random(); -- 2.39.5