X-Git-Url: https://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fclient%2Fprojectile.qc;h=fb4fdd5ef24e1fd245486a58d3a69ecf5fae33a8;hb=e14bb786305e05541496fb5b28c090e0ff1b5783;hp=4081bd8d1800c147a4867d2a6b6321bb11ed5e39;hpb=c5121d69899c57253362a5a8d98d6a1435a5fb47;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/client/projectile.qc b/qcsrc/client/projectile.qc index 4081bd8d1..fb4fdd5ef 100644 --- a/qcsrc/client/projectile.qc +++ b/qcsrc/client/projectile.qc @@ -4,10 +4,6 @@ .float trail_oldtime; .float fade_time, fade_rate; -void SUB_Null() -{ -} - void SUB_Stop() { self.move_velocity = self.move_avelocity = '0 0 0'; @@ -164,14 +160,11 @@ void loopsound(entity e, float ch, string samp, float vol, float attn) return; sound(e, ch, samp, vol, attn); - e.snd_looping = 1; + e.snd_looping = ch; } void Ent_RemoveProjectile() { - if(self.snd_looping) - sound(self, CH_SHOTS_SINGLE, "misc/null.wav", VOL_BASE, ATTN_NORM); - if(self.count & 0x80) { tracebox(self.origin, self.mins, self.maxs, self.origin + self.velocity * 0.05, MOVE_NORMAL, self); @@ -199,7 +192,7 @@ void Ent_Projectile() f = ReadByte(); self.count = (f & 0x80); - self.iflags = (self.iflags & IFLAG_INTERNALMASK) | IFLAG_AUTOANGLES | IFLAG_ANGLES; + self.iflags = (self.iflags & IFLAG_INTERNALMASK) | IFLAG_AUTOANGLES | IFLAG_ANGLES | IFLAG_ORIGIN; self.solid = SOLID_TRIGGER; //self.effects = EF_NOMODELFLAGS; @@ -229,6 +222,7 @@ void Ent_Projectile() self.origin_x = ReadCoord(); self.origin_y = ReadCoord(); self.origin_z = ReadCoord(); + setorigin(self, self.origin); if(self.count & 0x80) { self.velocity_x = ReadCoord(); @@ -327,7 +321,7 @@ void Ent_Projectile() self.mins = '0 0 -4'; self.maxs = '0 0 -4'; self.move_movetype = MOVETYPE_BOUNCE; - self.move_touch = SUB_Null; + self.move_touch = func_null; self.move_bounce_factor = g_balance_electro_secondary_bouncefactor; self.move_bounce_stopspeed = g_balance_electro_secondary_bouncestop; break; @@ -344,7 +338,7 @@ void Ent_Projectile() self.mins = '-3 -3 -3'; self.maxs = '3 3 3'; self.move_movetype = MOVETYPE_BOUNCE; - self.move_touch = SUB_Null; + self.move_touch = func_null; self.move_bounce_factor = g_balance_grenadelauncher_bouncefactor; self.move_bounce_stopspeed = g_balance_grenadelauncher_bouncestop; break; @@ -356,21 +350,21 @@ void Ent_Projectile() self.colormod = '2 1 1'; self.alphamod = 0.5; self.move_movetype = MOVETYPE_BOUNCE; - self.move_touch = SUB_Null; + self.move_touch = func_null; break; case PROJECTILE_PORTO_BLUE: self.colormod = '1 1 2'; self.alphamod = 0.5; self.move_movetype = MOVETYPE_BOUNCE; - self.move_touch = SUB_Null; + self.move_touch = func_null; break; case PROJECTILE_HAGAR_BOUNCING: self.move_movetype = MOVETYPE_BOUNCE; - self.move_touch = SUB_Null; + self.move_touch = func_null; break; case PROJECTILE_CRYLINK_BOUNCING: self.move_movetype = MOVETYPE_BOUNCE; - self.move_touch = SUB_Null; + self.move_touch = func_null; break; case PROJECTILE_FIREBALL: loopsound(self, CH_SHOTS_SINGLE, "weapons/fireball_fly2.wav", VOL_BASE, ATTN_NORM); @@ -380,7 +374,7 @@ void Ent_Projectile() case PROJECTILE_FIREMINE: loopsound(self, CH_SHOTS_SINGLE, "weapons/fireball_fly.wav", VOL_BASE, ATTN_NORM); self.move_movetype = MOVETYPE_BOUNCE; - self.move_touch = SUB_Null; + self.move_touch = func_null; self.mins = '-4 -4 -4'; self.maxs = '4 4 4'; break; @@ -420,7 +414,7 @@ void Ent_Projectile() self.mins = '0 0 -4'; self.maxs = '0 0 -4'; self.move_movetype = MOVETYPE_BOUNCE; - self.move_touch = SUB_Null; + self.move_touch = func_null; self.move_bounce_factor = g_balance_electro_secondary_bouncefactor; self.move_bounce_stopspeed = g_balance_electro_secondary_bouncestop; break; @@ -428,6 +422,7 @@ void Ent_Projectile() default: break; } + setsize(self, self.mins, self.maxs); } if(self.gravity)