X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fxonotic-data.pk3dir.git;a=blobdiff_plain;f=qcsrc%2Fserver%2Ftturrets%2Funits%2Funit_flac.qc;h=975abbd4c928254ec566a3d8858df8ad67b3f28a;hp=113dce46bcd737b0e946746c30e60cc9c976d148;hb=a7b24450e4c7ca75636df1375d01d2266bd00c8c;hpb=a484319f89b4267fa8bbb631b060df92e2eddbaf diff --git a/qcsrc/server/tturrets/units/unit_flac.qc b/qcsrc/server/tturrets/units/unit_flac.qc index 113dce46bc..975abbd4c9 100644 --- a/qcsrc/server/tturrets/units/unit_flac.qc +++ b/qcsrc/server/tturrets/units/unit_flac.qc @@ -1,86 +1,50 @@ void spawnfunc_turret_flac(); void turret_flac_dinit(); void turret_flac_attack(); -void turret_flac_projectile_explode(); -void turret_flac_attack() +void turret_flac_projectile_think_explode() { - local entity proj; - - turret_tag_fire_update(); - - sound (self, CHAN_WEAPON, "weapons/hagar_fire.wav", VOL_BASE, ATTN_NORM); - proj = spawn (); - setorigin(proj, self.tur_shotorg); - setsize(proj, '0 0 0', '0 0 0'); - proj.classname = "flac_projectile"; - proj.owner = self; - proj.bot_dodge = TRUE; - proj.bot_dodgerating = self.shot_dmg; - proj.solid = SOLID_BBOX; - proj.movetype = MOVETYPE_FLYMISSILE; - proj.flags = FL_PROJECTILE; - proj.takedamage = DAMAGE_NO; - proj.velocity = normalize(self.tur_shotdir_updated + randomvec() * self.shot_spread) * self.shot_speed; - proj.angles = vectoangles(proj.velocity); - proj.touch = turret_flac_projectile_explode; - proj.think = turret_flac_projectile_explode; - proj.nextthink = time + max(self.tur_impacttime,(self.shot_radius * 3) / self.shot_speed); - proj.enemy = self.enemy; - proj.cnt = time + 5; - - CSQCProjectile(proj, TRUE, PROJECTILE_HAGAR, TRUE); - - self.tur_head.frame = self.tur_head.frame + 1; - if (self.tur_head.frame >= 4) self.tur_head.frame = 0; - + if(self.enemy != world) + if(vlen(self.origin - self.enemy.origin) < self.owner.shot_radius * 3) + setorigin(self,self.enemy.origin + randomvec() * self.owner.shot_radius); + +#ifdef TURRET_DEBUG + float d; + d = RadiusDamage (self, self.owner, self.owner.shot_dmg, self.owner.shot_dmg, self.owner.shot_radius, self, self.owner.shot_force, self.totalfrags, world); + self.owner.tur_dbg_dmg_t_h = self.owner.tur_dbg_dmg_t_h + d; + self.owner.tur_dbg_dmg_t_f = self.owner.tur_dbg_dmg_t_f + self.owner.shot_dmg; +#else + RadiusDamage (self, self.realowner, self.owner.shot_dmg, self.owner.shot_dmg, self.owner.shot_radius, self, self.owner.shot_force, self.totalfrags, world); +#endif + remove(self); } -void turret_flac_projectile_explode() +void turret_flac_attack() { - float ftmp; + entity proj; - if( (self.enemy != world) && - (vlen(self.origin - self.enemy.origin) < self.owner.shot_radius * 3) ) - { - // OMG HAXX! - setorigin(self,self.enemy.origin + randomvec() * self.owner.shot_radius); - } + turret_tag_fire_update(); - te_explosion (self.origin); - - ftmp = crandom(); - if (ftmp<-0.7) - sound (self, CHAN_PROJECTILE, "weapons/hagexp1.wav", VOL_BASE, ATTN_NORM); - else if (ftmp<0.4) - sound (self, CHAN_PROJECTILE, "weapons/hagexp2.wav", VOL_BASE, ATTN_NORM); - else if (ftmp<1) - sound (self, CHAN_PROJECTILE, "weapons/hagexp3.wav", VOL_BASE, ATTN_NORM); - - - self.event_damage = SUB_Null; + proj = turret_projectile("weapons/hagar_fire.wav", 5, 0, DEATH_TURRET_FLAC, PROJECTILE_HAGAR, TRUE, TRUE); + pointparticles(particleeffectnum("laser_muzzleflash"), self.tur_shotorg, self.tur_shotdir_updated * 1000, 1); + proj.think = turret_flac_projectile_think_explode; + proj.nextthink = time + self.tur_impacttime + (random() * 0.01 - random() * 0.01); + self.tur_head.frame = self.tur_head.frame + 1; + if (self.tur_head.frame >= 4) + self.tur_head.frame = 0; -#ifdef TURRET_DEBUG - ftmp = RadiusDamage (self, self.owner, self.owner.shot_dmg, 0, self.owner.shot_radius, world, self.owner.shot_force, DEATH_TURRET, world); - self.owner.tur_dbg_dmg_t_h = self.owner.tur_dbg_dmg_t_h + ftmp; //self.owner.shot_dmg; - self.owner.tur_dbg_dmg_t_f = self.owner.tur_dbg_dmg_t_f + self.owner.shot_dmg; -#else - RadiusDamage (self, self.owner, self.owner.shot_dmg, self.owner.shot_dmg * 0.5, self.owner.shot_radius, world, self.owner.shot_force, DEATH_TURRET, world); -#endif - - remove (self); } - void turret_flac_dinit() { - if (self.netname == "") self.netname = "FLAC Cannon"; + if (self.netname == "") + self.netname = "FLAC Cannon"; self.turrcaps_flags = TFL_TURRCAPS_RADIUSDMG | TFL_TURRCAPS_FASTPROJ | TFL_TURRCAPS_MISSILEKILL; self.ammo_flags = TFL_AMMO_ROCKETS | TFL_AMMO_RECHARGE; self.aim_flags = TFL_AIM_LEAD | TFL_AIM_SHOTTIMECOMPENSATE; - + if (turret_stdproc_init("flac_std", "models/turrets/base.md3", "models/turrets/flac.md3", TID_FLAC) == 0) { remove(self); @@ -90,8 +54,7 @@ void turret_flac_dinit() self.damage_flags |= TFL_DMG_HEADSHAKE; self.target_select_flags |= TFL_TARGETSELECT_NOTURRETS | TFL_TARGETSELECT_MISSILESONLY; - - + // Our fire routine self.turret_firefunc = turret_flac_attack;