3 #include "../antilag.qh"
4 #include "../g_subs.qh"
5 #include <common/weapons/_all.qh>
6 #include <common/state.qh>
8 vector W_HitPlotUnnormalizedUntransform(vector screenforward, vector screenright, vector screenup, vector v)
11 ret.x = screenright * v;
13 ret.z = screenforward * v;
17 vector W_HitPlotNormalizedUntransform(vector org, entity targ, vector screenforward, vector screenright, vector screenup, vector v)
20 vector mi, ma, thisv, myv, ret;
22 myv = W_HitPlotUnnormalizedUntransform(screenforward, screenright, screenup, org);
24 // x = 0..1 relative to hitbox; y = 0..1 relative to hitbox; z = distance
26 mi = ma = targ.origin + 0.5 * (targ.mins + targ.maxs);
27 for(i = 0; i < 2; ++i) for(j = 0; j < 2; ++j) for(k = 0; k < 2; ++k)
30 if(i) thisv.x += targ.maxs.x; else thisv.x += targ.mins.x;
31 if(j) thisv.y += targ.maxs.y; else thisv.y += targ.mins.y;
32 if(k) thisv.z += targ.maxs.z; else thisv.z += targ.mins.z;
33 thisv = W_HitPlotUnnormalizedUntransform(screenforward, screenright, screenup, thisv);
36 if(mi.x > thisv.x) mi.x = thisv.x; if(ma.x < thisv.x) ma.x = thisv.x;
37 if(mi.y > thisv.y) mi.y = thisv.y; if(ma.y < thisv.y) ma.y = thisv.y;
38 //if(mi_z > thisv_z) mi_z = thisv_z; if(ma_z < thisv_z) ma_y = thisv_z;
47 thisv = W_HitPlotUnnormalizedUntransform(screenforward, screenright, screenup, v);
48 ret.x = (thisv.x - mi.x) / (ma.x - mi.x);
49 ret.y = (thisv.y - mi.y) / (ma.y - mi.y);
50 ret.z = thisv.z - myv.z;
54 void W_HitPlotAnalysis(entity player, .entity weaponentity, vector screenforward, vector screenright, vector screenup)
60 if(player.hitplotfh >= 0)
62 lag = ANTILAG_LATENCY(player);
65 if(!IS_REAL_CLIENT(player))
66 lag = 0; // only antilag for clients
68 org = player.origin + player.view_ofs;
69 traceline_antilag_force(player, org, org + screenforward * MAX_SHOT_DISTANCE, MOVE_NORMAL, player, lag);
70 if(IS_CLIENT(trace_ent) || IS_MONSTER(trace_ent))
72 entity store = IS_CLIENT(trace_ent) ? CS(trace_ent) : trace_ent;
73 antilag_takeback(trace_ent, store, time - lag);
74 hitplot = W_HitPlotNormalizedUntransform(org, trace_ent, screenforward, screenright, screenup, trace_endpos);
75 antilag_restore(trace_ent, store);
76 fputs(player.hitplotfh, strcat(ftos(hitplot.x), " ", ftos(hitplot.y), " ", ftos(hitplot.z), " ", ftos(player.(weaponentity).m_switchweapon.m_id), "\n"));
77 //print(strcat(ftos(hitplot_x), " ", ftos(hitplot_y), " ", ftos(hitplot_z), "\n"));
82 void W_HitPlotOpen(entity player)
84 if(autocvar_g_hitplots || strhasword(autocvar_g_hitplots_individuals, player.netaddress))
86 player.hitplotfh = fopen(strcat("hits-", matchid, "-", player.netaddress, "-", ftos(player.playerid), ".plot"), FILE_WRITE);
87 fputs(player.hitplotfh, strcat("#name ", player.netname, "\n"));
89 else { player.hitplotfh = -1; }
92 void W_HitPlotClose(entity player)
94 if(player.hitplotfh >= 0)
96 fclose(player.hitplotfh);
97 player.hitplotfh = -1;