From: Samual Lenks Date: Mon, 17 Feb 2014 04:43:38 +0000 (-0500) Subject: Working on Arc attack calculation X-Git-Tag: xonotic-v0.8.0~152^2~104 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=2380d290ee83610f2001d7806416c25e4c81433d;p=xonotic%2Fxonotic-data.pk3dir.git Working on Arc attack calculation --- diff --git a/qcsrc/common/weapons/w_arc.qc b/qcsrc/common/weapons/w_arc.qc index b492b24317..2c7d64d730 100644 --- a/qcsrc/common/weapons/w_arc.qc +++ b/qcsrc/common/weapons/w_arc.qc @@ -195,24 +195,27 @@ void W_Arc_Beam_Think(void) #ifdef ARC_DEBUG printf("segment count: %d\n", segments); #endif - float segmentdist = distance_to_want_pos * (1/segments); + float segmentdist;// = vlen(self.beam_endpos - last_origin) * (1/segments); float segmentblend;// = (1/segments); vector last_origin = w_shotorg; for(i = 1; i <= segments; ++i) { segmentblend = (i/segments); - vector blended = normalize((direction_to_want_pos * (1 - segmentblend)) + (newdir * segmentblend)); + segmentdist = vlen(self.beam_endpos - last_origin) * (i/segments); + //direction_to_want_pos = normalize(self.beam_endpos - last_origin); + vector blended = normalize((direction_to_want_pos * (1 - segmentblend)) + (normalize(self.beam_endpos - last_origin) * segmentblend)); vector new_origin = last_origin + (blended * segmentdist); WarpZone_traceline_antilag(self.owner, last_origin, new_origin, MOVE_NORMAL, self.owner, ANTILAG_LATENCY(self.owner)); if(trace_ent) { + vector attackend = (last_origin * (1 - trace_fraction) + new_origin * trace_fraction); // trace_endpos jumps weirdly with playermodels... float falloff = ExponentialFalloff( WEP_CVAR_PRI(arc, falloff_mindist), WEP_CVAR_PRI(arc, falloff_maxdist), WEP_CVAR_PRI(arc, falloff_halflifedist), - vlen(WarpZone_UnTransformOrigin(WarpZone_trace_transform, trace_endpos) - w_shotorg) + vlen(WarpZone_UnTransformOrigin(WarpZone_trace_transform, attackend) - w_shotorg) ); if(accuracy_isgooddamage(self.owner, trace_ent)) @@ -224,13 +227,13 @@ void W_Arc_Beam_Think(void) self.owner, WEP_CVAR_PRI(arc, damage) * dt * falloff, WEP_ARC, - trace_endpos, + attackend, (blended * WEP_CVAR_PRI(arc, force)) * dt * falloff ); #ifdef ARC_DEBUG - te_lightning1(self.lg_ents[i - 1], last_origin, trace_endpos); - te_customflash(trace_endpos, 80, 5, '1 0 0'); + te_lightning1(self.lg_ents[i - 1], last_origin, attackend); + te_customflash(attackend, 80, 5, '1 0 0'); #endif break;