From: Rudolf Polzer Date: Mon, 10 May 2010 07:31:11 +0000 (+0200) Subject: new options for r_showbboxes: also show the player headshot box X-Git-Tag: xonotic-v0.1.0preview~635^2 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=943e3fc6100d9108c5a5f8bae0e71e16f4e4227d;p=xonotic%2Fxonotic-data.pk3dir.git new options for r_showbboxes: also show the player headshot box --- diff --git a/qcsrc/server/cl_client.qc b/qcsrc/server/cl_client.qc index ba363f0c0a..c5acd3ebf8 100644 --- a/qcsrc/server/cl_client.qc +++ b/qcsrc/server/cl_client.qc @@ -2836,6 +2836,18 @@ Called every frame for each client after the physics are run ============= */ .float idlekick_lasttimeleft; +.entity showheadshotbbox; +void showheadshotbbox_think() +{ + if(self.owner.showheadshotbbox != self) + { + remove(self); + return; + } + self.nextthink = time; + setorigin(self, self.owner.origin); + setsize(self, GetHeadshotMins(self.owner), GetHeadshotMaxs(self.owner)); +} void PlayerPostThink (void) { // Savage: Check for nameless players @@ -2937,6 +2949,26 @@ void PlayerPostThink (void) if(self.waypointsprite_attachedforcarrier) WaypointSprite_UpdateHealth(self.waypointsprite_attachedforcarrier, '1 0 0' * healtharmor_maxdamage(self.health, self.armorvalue, cvar("g_balance_armor_blockpercent"))); + if(self.classname == "player" && self.deadflag == DEAD_NO && cvar("r_showbboxes")) + { + if(!self.showheadshotbbox) + { + self.showheadshotbbox = spawn(); + self.showheadshotbbox.classname = "headshotbbox"; + self.showheadshotbbox.owner = self; + self.showheadshotbbox.think = showheadshotbbox_think; + self.showheadshotbbox.nextthink = time; + self = self.showheadshotbbox; + self.think(); + self = self.owner; + } + } + else + { + if(self.showheadshotbbox) + remove(self.showheadshotbbox); + } + playerdemo_write(); /* diff --git a/qcsrc/server/g_damage.qc b/qcsrc/server/g_damage.qc index 0c446484d2..505b2e7688 100644 --- a/qcsrc/server/g_damage.qc +++ b/qcsrc/server/g_damage.qc @@ -86,6 +86,15 @@ float IsFlying(entity a) return 1; } +vector GetHeadshotMins(entity targ) +{ + return '0.6 0 0' * targ.mins_x + '0 0.6 0' * targ.mins_y + '0 0 1' * (1.3 * targ.view_ofs_z - 0.3 * targ.maxs_z); +} +vector GetHeadshotMaxs(entity targ) +{ + return '0.6 0 0' * targ.maxs_x + '0 0.6 0' * targ.maxs_y + '0 0 1' * targ.maxs_z; +} + void UpdateFrags(entity player, float f) { PlayerTeamScore_AddScore(player, f); @@ -872,8 +881,8 @@ void Damage (entity targ, entity inflictor, entity attacker, float damage, float // if above view_ofs and below maxs, and also in the middle half of the bbox, it is head shot vector headmins, headmaxs, org; org = antilag_takebackorigin(targ, time - ANTILAG_LATENCY(attacker)); - headmins = org + '0.6 0 0' * targ.mins_x + '0 0.6 0' * targ.mins_y + '0 0 1' * (1.3 * targ.view_ofs_z - 0.3 * targ.maxs_z); - headmaxs = org + '0.6 0 0' * targ.maxs_x + '0 0.6 0' * targ.maxs_y + '0 0 1' * targ.maxs_z; + headmins = org + GetHeadshotMins(targ); + headmaxs = org + GetHeadshotMaxs(targ); if(trace_hits_box(railgun_start, railgun_end, headmins, headmaxs)) { deathtype |= HITTYPE_HEADSHOT;