From 585617698c2018c22a521b5d7ea9d2b725d80c17 Mon Sep 17 00:00:00 2001 From: Samual Lenks Date: Wed, 26 Feb 2014 21:13:31 -0500 Subject: [PATCH] Enable calculation of segment counts on client now --- qcsrc/client/particles.qc | 36 ++++++++++++++++------------------- qcsrc/common/weapons/w_arc.qc | 4 +++- 2 files changed, 19 insertions(+), 21 deletions(-) diff --git a/qcsrc/client/particles.qc b/qcsrc/client/particles.qc index 7cd88650e5..b28c687957 100644 --- a/qcsrc/client/particles.qc +++ b/qcsrc/client/particles.qc @@ -374,6 +374,8 @@ void Net_ReadShockwaveParticle() .entity beam_muzzleentity; +.float beam_degreespersegment; +.float beam_distancepersegment; .float beam_usevieworigin; .float beam_initialized; .float beam_maxangle; @@ -539,8 +541,6 @@ void Draw_ArcBeam() self.beam_initialized = TRUE; } - // WEAPONTODO: Calculate segments dyanmically similarly to the server code - segments = 20; if(self.beam_dir != wantdir) { // calculate how much we're going to move the end of the beam to the want position @@ -571,40 +571,36 @@ void Draw_ArcBeam() self.beam_dir = normalize((wantdir * (1 - blendfactor)) + (self.beam_dir * blendfactor)); } - #if 0 // calculate how many segments are needed float max_allowed_segments; - if(WEP_CVAR(arc, beam_distancepersegment)) + if(self.beam_distancepersegment) { max_allowed_segments = min( ARC_MAX_SEGMENTS, - 1 + (vlen(w_shotdir / WEP_CVAR(arc, beam_distancepersegment))) + 1 + (vlen(wantdir / self.beam_distancepersegment)) ); } else { max_allowed_segments = ARC_MAX_SEGMENTS; } - if(WEP_CVAR(arc, beam_degreespersegment)) + if(self.beam_degreespersegment) { segments = bound( 1, ( min( angle, - WEP_CVAR(arc, beam_maxangle) + self.beam_maxangle ) / - WEP_CVAR(arc, beam_degreespersegment) + self.beam_degreespersegment ), max_allowed_segments ); } else { segments = 1; } - #endif } - #if 0 else { segments = 1; } - #endif // set the beam direction which the rest of the code will refer to beamdir = self.beam_dir; @@ -619,34 +615,33 @@ void Draw_ArcBeam() wantdir = self.v_angle; beamdir = self.angles; - // WEAPONTODO: Calculate segments dyanmically similarly to the server code - segments = 20; - #if 0 if(beamdir != wantdir) { + float angle = vlen(wantdir - beamdir) * RAD2DEG; + // calculate how many segments are needed float max_allowed_segments; - if(WEP_CVAR(arc, beam_distancepersegment)) + if(self.beam_distancepersegment) { max_allowed_segments = min( ARC_MAX_SEGMENTS, - 1 + (vlen(w_shotdir / WEP_CVAR(arc, beam_distancepersegment))) + 1 + (vlen(wantdir / self.beam_distancepersegment)) ); } else { max_allowed_segments = ARC_MAX_SEGMENTS; } - if(WEP_CVAR(arc, beam_degreespersegment)) + if(self.beam_degreespersegment) { segments = bound( 1, ( min( angle, - WEP_CVAR(arc, beam_maxangle) + self.beam_maxangle ) / - WEP_CVAR(arc, beam_degreespersegment) + self.beam_degreespersegment ), max_allowed_segments ); @@ -654,7 +649,6 @@ void Draw_ArcBeam() else { segments = 1; } } else { segments = 1; } - #endif } setorigin(self, start_pos); @@ -830,6 +824,8 @@ void Ent_ReadArcBeam(float isnew) if(sf & 1) // settings information { + self.beam_degreespersegment = ReadShort(); + self.beam_distancepersegment = ReadShort(); self.beam_maxangle = ReadShort(); self.beam_range = ReadCoord(); self.beam_returnspeed = ReadShort(); diff --git a/qcsrc/common/weapons/w_arc.qc b/qcsrc/common/weapons/w_arc.qc index 7aa67b3393..39f65a36b5 100644 --- a/qcsrc/common/weapons/w_arc.qc +++ b/qcsrc/common/weapons/w_arc.qc @@ -50,6 +50,7 @@ REGISTER_WEAPON( w_prop(id, sn, float, weaponthrowable, weaponthrowable) #ifndef MENUQC +#define ARC_MAX_SEGMENTS 20 vector arc_shotorigin[4]; .vector beam_start; .vector beam_dir; @@ -66,7 +67,6 @@ vector arc_shotorigin[4]; #define ARC_BT_BURSTMASK 10 #endif #ifdef SVQC -#define ARC_MAX_SEGMENTS 20 ARC_SETTINGS(WEP_ADD_CVAR, WEP_ADD_PROP) .entity arc_beam; .float BUTTON_ATCK_prev; // for better animation control @@ -102,6 +102,8 @@ float W_Arc_Beam_Send(entity to, float sf) if(sf & 1) // settings information { + WriteShort(MSG_ENTITY, WEP_CVAR(arc, beam_degreespersegment)); + WriteShort(MSG_ENTITY, WEP_CVAR(arc, beam_distancepersegment)); WriteShort(MSG_ENTITY, WEP_CVAR(arc, beam_maxangle)); WriteCoord(MSG_ENTITY, WEP_CVAR(arc, beam_range)); WriteShort(MSG_ENTITY, WEP_CVAR(arc, beam_returnspeed)); -- 2.39.2