From: Samual Lenks Date: Wed, 26 Feb 2014 22:50:30 +0000 (-0500) Subject: Only interpolate when not local beam X-Git-Tag: xonotic-v0.8.0~152^2~55 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=6279335669b53131cac5c08e70b7438da8feb1c3;p=xonotic%2Fxonotic-data.pk3dir.git Only interpolate when not local beam --- diff --git a/qcsrc/client/particles.qc b/qcsrc/client/particles.qc index 3a52f85e26..695ed5c3cb 100644 --- a/qcsrc/client/particles.qc +++ b/qcsrc/client/particles.qc @@ -469,7 +469,10 @@ void Draw_ArcBeam_callback(vector start, vector hit, vector end) void Draw_ArcBeam() { - InterpolateOrigin_Do(); + if(!self.beam_usevieworigin) + { + InterpolateOrigin_Do(); + } // origin = beam starting origin // v_angle = wanted/aim direction @@ -739,11 +742,6 @@ void Ent_ReadArcBeam(float isnew) float sf = ReadByte(); entity flash; - // self.iflags = IFLAG_ORIGIN | IFLAG_ANGLES | IFLAG_V_ANGLE; // why doesn't this work? - self.iflags = IFLAG_ORIGIN; - - InterpolateOrigin_Undo(); - if(isnew) { // calculate shot origin offset from gun alignment @@ -794,6 +792,14 @@ void Ent_ReadArcBeam(float isnew) } } + if(!self.beam_usevieworigin) + { + // self.iflags = IFLAG_ORIGIN | IFLAG_ANGLES | IFLAG_V_ANGLE; // why doesn't this work? + self.iflags = IFLAG_ORIGIN; + + InterpolateOrigin_Undo(); + } + if(sf & 2) // starting location { self.origin_x = ReadCoord(); @@ -1047,7 +1053,10 @@ void Ent_ReadArcBeam(float isnew) } } - InterpolateOrigin_Note(); + if(!self.beam_usevieworigin) + { + InterpolateOrigin_Note(); + } #if 0 printf(