]> git.rm.cloudns.org Git - xonotic/xonotic-data.pk3dir.git/commitdiff
make shownames use its own set of entities
authorRudolf Polzer <divverent@alientrap.org>
Sun, 15 May 2011 18:55:55 +0000 (20:55 +0200)
committerRudolf Polzer <divverent@alientrap.org>
Sun, 15 May 2011 18:58:31 +0000 (20:58 +0200)
qcsrc/client/Main.qc
qcsrc/client/View.qc
qcsrc/client/shownames.qc
qcsrc/server/cl_client.qc
qcsrc/server/ent_cs.qc

index d7cb0ce629a814894cdba4c23ca8278ff9bf5f88..8820c06d7ea2597fb3d9e993d85de89d177e227c 100644 (file)
@@ -667,7 +667,7 @@ void Ent_ReadEntCS()
        sf = ReadByte();
 
        if(sf & 1)
-               self.sv_entnum = ReadByte() - 1;
+               self.sv_entnum = ReadByte();
        if(sf & 2)
        {
                self.origin_x = ReadShort();
@@ -690,7 +690,6 @@ void Ent_ReadEntCS()
 
        entcs_receiver[self.sv_entnum] = self;
        self.entremove = Ent_RemoveEntCS;
-       self.draw2d = Draw_ShowNames;
 
        InterpolateOrigin_Note();
 }
index f582f33a3ab9fec0be98673778d3d17fd8f7f9f8..029b9460f6f7f7209727efc0019b039fbd9ff77d 100644 (file)
@@ -861,6 +861,7 @@ void CSQC_UpdateView(float w, float h)
                if(self.draw2d)
                        self.draw2d();
        self = e;
+       Draw_ShowNames_All();
 
        scoreboard_active = HUD_WouldDrawScoreboard();
 
index c467ea6873cbdba95687c7a8dcafa66068b8988c..a87404cf3444e299811da2ed46a9bc847a90b799 100644 (file)
 // self.sameteam = player is on same team as local client
 //
 const float SHOWNAMES_FADESPEED = 4;
-void Draw_ShowNames()
+void Draw_ShowNames(entity ent)
 {
-    if(!autocvar_hud_shownames)
-        return;
-
-    if(self.sv_entnum == player_localentnum && !autocvar_chase_active)
-        return;
-
-    if(self.sameteam || (!self.sameteam && autocvar_hud_shownames_enemies))
-    {
-        self.origin = getplayerorigin(self.sv_entnum-1);
-        self.origin_z += autocvar_hud_shownames_offset;
-
-        if(!self.sameteam)
-        {
-            /* WIP, why does trace_ent != self not work as intended here?
-            if(autocvar_hud_shownames_enemies != 2) // player has to point at enemy if so
-            {
-                traceline(view_origin, view_origin + view_forward * MAX_SHOT_DISTANCE, MOVETYPE_FLY, world);
-                print("trace_endpos: ", vtos(trace_endpos), " view_origin: ", vtos(view_origin), "\n");
-                if(trace_ent != self)
-                    return;
-            }*/
-
-            traceline(self.origin, view_origin, 1, self);
-        }
-
-        vector o, eo;
-        o = project_3d_to_2d(self.origin);
-        float overlap;
-
-        if(autocvar_hud_shownames_antioverlap)
-        {
-            // fade tag out if another tag that is closer to you overlaps
-            entity e;
-            for(e = world; (e = find(e, classname, "shownames_tag")); )
-            {
-                if(e == self)
-                    continue;
-                eo = project_3d_to_2d(e.origin);
-                if not(eo_z < 0 || eo_x < 0 || eo_y < 0 || eo_x > vid_conwidth || eo_y > vid_conheight)
-                {
-                    eo_z = 0;
-                    if(vlen((eX * o_x + eY * o_y) - eo) < autocvar_hud_shownames_antioverlap_distance && vlen(self.origin - view_origin) > vlen(e.origin - view_origin))
-                    {
-                        overlap = TRUE;
-                        break;
-                    }
-                }
-            }
-        }
-
-        if(!self.sameteam && trace_endpos != view_origin) // out of view, fade out
-            self.alpha = max(0, self.alpha - SHOWNAMES_FADESPEED * frametime);
-        else if(!self.healthvalue) // dead player, fade out slowly
-            self.alpha = max(0, self.alpha - SHOWNAMES_FADESPEED * 0.25 * frametime);
-        else if(overlap) // tag overlap detected, fade out
-            self.alpha = max(0, self.alpha - SHOWNAMES_FADESPEED * frametime);
-        else // fade in
-            self.alpha = min(1, self.alpha + SHOWNAMES_FADESPEED * frametime);
-
-        if(!self.alpha)
-            return;
-
-        float dist;
-        dist = vlen(self.origin - view_origin);
-
-        float a;
-        a = autocvar_hud_shownames_alpha;
-        a *= self.alpha;
-        if(autocvar_hud_shownames_maxdistance)
-        {
-            if(dist >= autocvar_hud_shownames_maxdistance)
-                return;
-            a *= ((autocvar_hud_shownames_maxdistance - autocvar_hud_shownames_mindistance) - max(0, dist - autocvar_hud_shownames_mindistance)) / (autocvar_hud_shownames_maxdistance - autocvar_hud_shownames_mindistance);
-        }
-
-        if(!a)
-            return;
-
-        float resize;
-        resize = 1;
-        if(autocvar_hud_shownames_resize) // limit resize so its never smaller than 0.5... gets unreadable
-            resize = 0.5 + 0.5 * ((autocvar_hud_shownames_maxdistance - autocvar_hud_shownames_mindistance) - max(0, dist - autocvar_hud_shownames_mindistance)) / (autocvar_hud_shownames_maxdistance - autocvar_hud_shownames_mindistance);
-
-        // draw the sprite image
-        if not(o_z < 0 || o_x < 0 || o_y < 0 || o_x > vid_conwidth || o_y > vid_conheight)
-        {
-            o_z = 0;
-
-            vector myPos, mySize;
-            mySize = (eX * autocvar_hud_shownames_aspect + eY) * autocvar_hud_shownames_fontsize;
-            myPos = o - '0.5 0 0' * mySize_x - '0 1 0' * mySize_y;
-
-            // size scaling
-            mySize_x *= resize;
-            mySize_y *= resize;
-
-            myPos_x += 0.5 * (mySize_x / resize - mySize_x);
-            myPos_y += (mySize_y / resize - mySize_y);
-
-            vector namepos; // this is where the origin of the string
-            float namewidth;
-
-            namepos = myPos;
-            namewidth = mySize_x;
-
-            if(autocvar_hud_shownames_status && teamplay)
-            {
-                if(self.sameteam)
-                {
-                    if(self.healthvalue > 0)
-                    {
-                        HUD_Panel_DrawProgressBar(namepos + '0 1 0' * autocvar_hud_shownames_fontsize * resize, eX * 0.5 * mySize_x + eY * resize * autocvar_hud_shownames_statusbar_height, "nametag_statusbar", self.healthvalue/autocvar_hud_panel_healtharmor_maxhealth, 0, 1, '1 0 0', a, DRAWFLAG_NORMAL);
-
-                        if(self.armorvalue > 0)
-                            HUD_Panel_DrawProgressBar(namepos + '0 1 0' * autocvar_hud_shownames_fontsize * resize + eX * 0.5 * mySize_x, eX * 0.5 * mySize_x + eY * resize * autocvar_hud_shownames_statusbar_height, "nametag_statusbar", self.armorvalue/autocvar_hud_panel_healtharmor_maxarmor, 0, 0, '0 1 0', a, DRAWFLAG_NORMAL);
-                    }
-                }
-            }
-
-            string s;
-            s = GetPlayerName(self.sv_entnum-1);
-            if((autocvar_hud_shownames_decolorize == 1 && teamplay) || autocvar_hud_shownames_decolorize == 2)
-                s = playername(s, GetPlayerColor(self.sv_entnum-1));
-
-            drawfontscale = '1 1 0' * resize;
-            s = textShortenToWidth(s, namewidth, '1 1 0' * autocvar_hud_shownames_fontsize, stringwidth_colors);
-
-            float width;
-            width = stringwidth(s, TRUE, '1 1 0' * autocvar_hud_shownames_fontsize);
-
-            if (width != namewidth)
-                namepos_x += (namewidth - width) / 2;
-            drawcolorcodedstring(namepos, s, '1 1 0' * autocvar_hud_shownames_fontsize, a, DRAWFLAG_NORMAL);
-            drawfontscale = '1 1 0';
-        }
-    }
+       if(!autocvar_hud_shownames)
+               return;
+
+       if(ent.sv_entnum == player_localentnum && !autocvar_chase_active)
+               return;
+
+       if(ent.sameteam || (!ent.sameteam && autocvar_hud_shownames_enemies))
+       {
+               ent.origin_z += autocvar_hud_shownames_offset;
+
+               if(!ent.sameteam)
+               {
+                       /* WIP, why does trace_ent != ent not work as intended here?
+                          if(autocvar_hud_shownames_enemies != 2) // player has to point at enemy if so
+                          {
+                          traceline(view_origin, view_origin + view_forward * MAX_SHOT_DISTANCE, MOVETYPE_FLY, world);
+                          print("trace_endpos: ", vtos(trace_endpos), " view_origin: ", vtos(view_origin), "\n");
+                          if(trace_ent != ent)
+                          return;
+                          }*/
+
+                       traceline(ent.origin, view_origin, 1, ent);
+               }
+
+               vector o, eo;
+               o = project_3d_to_2d(ent.origin);
+               float overlap;
+
+               if(autocvar_hud_shownames_antioverlap)
+               {
+                       // fade tag out if another tag that is closer to you overlaps
+                       entity e;
+                       for(e = world; (e = find(e, classname, "shownames_tag")); )
+                       {
+                               if(e == ent)
+                                       continue;
+                               eo = project_3d_to_2d(e.origin);
+                               if not(eo_z < 0 || eo_x < 0 || eo_y < 0 || eo_x > vid_conwidth || eo_y > vid_conheight)
+                               {
+                                       eo_z = 0;
+                                       if(vlen((eX * o_x + eY * o_y) - eo) < autocvar_hud_shownames_antioverlap_distance && vlen(ent.origin - view_origin) > vlen(e.origin - view_origin))
+                                       {
+                                               overlap = TRUE;
+                                               break;
+                                       }
+                               }
+                       }
+               }
+
+               if(!ent.sameteam && trace_endpos != view_origin) // out of view, fade out
+                       ent.alpha = max(0, ent.alpha - SHOWNAMES_FADESPEED * frametime);
+               else if(ent.healthvalue < 1) // dead player, fade out slowly
+                       ent.alpha = max(0, ent.alpha - SHOWNAMES_FADESPEED * 0.25 * frametime);
+               else if(overlap) // tag overlap detected, fade out
+                       ent.alpha = max(0, ent.alpha - SHOWNAMES_FADESPEED * frametime);
+               else // fade in
+                       ent.alpha = min(1, ent.alpha + SHOWNAMES_FADESPEED * frametime);
+
+               if(!ent.alpha)
+                       return;
+
+               float dist;
+               dist = vlen(ent.origin - view_origin);
+
+               float a;
+               a = autocvar_hud_shownames_alpha;
+               a *= ent.alpha;
+               if(autocvar_hud_shownames_maxdistance)
+               {
+                       if(dist >= autocvar_hud_shownames_maxdistance)
+                               return;
+                       a *= ((autocvar_hud_shownames_maxdistance - autocvar_hud_shownames_mindistance) - max(0, dist - autocvar_hud_shownames_mindistance)) / (autocvar_hud_shownames_maxdistance - autocvar_hud_shownames_mindistance);
+               }
+
+               if(!a)
+                       return;
+
+               float resize;
+               resize = 1;
+               if(autocvar_hud_shownames_resize) // limit resize so its never smaller than 0.5... gets unreadable
+                       resize = 0.5 + 0.5 * ((autocvar_hud_shownames_maxdistance - autocvar_hud_shownames_mindistance) - max(0, dist - autocvar_hud_shownames_mindistance)) / (autocvar_hud_shownames_maxdistance - autocvar_hud_shownames_mindistance);
+
+               // draw the sprite image
+               if not(o_z < 0 || o_x < 0 || o_y < 0 || o_x > vid_conwidth || o_y > vid_conheight)
+               {
+                       o_z = 0;
+
+                       vector myPos, mySize;
+                       mySize = (eX * autocvar_hud_shownames_aspect + eY) * autocvar_hud_shownames_fontsize;
+                       myPos = o - '0.5 0 0' * mySize_x - '0 1 0' * mySize_y;
+
+                       // size scaling
+                       mySize_x *= resize;
+                       mySize_y *= resize;
+
+                       myPos_x += 0.5 * (mySize_x / resize - mySize_x);
+                       myPos_y += (mySize_y / resize - mySize_y);
+
+                       vector namepos; // this is where the origin of the string
+                       float namewidth;
+
+                       namepos = myPos;
+                       namewidth = mySize_x;
+
+                       if(autocvar_hud_shownames_status && teamplay)
+                       {
+                               if(ent.sameteam)
+                               {
+                                       if(ent.healthvalue > 0)
+                                       {
+                                               HUD_Panel_DrawProgressBar(namepos + '0 1 0' * autocvar_hud_shownames_fontsize * resize, eX * 0.5 * mySize_x + eY * resize * autocvar_hud_shownames_statusbar_height, "nametag_statusbar", ent.healthvalue/autocvar_hud_panel_healtharmor_maxhealth, 0, 1, '1 0 0', a, DRAWFLAG_NORMAL);
+
+                                               if(ent.armorvalue > 0)
+                                                       HUD_Panel_DrawProgressBar(namepos + '0 1 0' * autocvar_hud_shownames_fontsize * resize + eX * 0.5 * mySize_x, eX * 0.5 * mySize_x + eY * resize * autocvar_hud_shownames_statusbar_height, "nametag_statusbar", ent.armorvalue/autocvar_hud_panel_healtharmor_maxarmor, 0, 0, '0 1 0', a, DRAWFLAG_NORMAL);
+                                       }
+                               }
+                       }
+
+                       string s;
+                       s = GetPlayerName(ent.sv_entnum-1);
+                       if((autocvar_hud_shownames_decolorize == 1 && teamplay) || autocvar_hud_shownames_decolorize == 2)
+                               s = playername(s, GetPlayerColor(ent.sv_entnum-1));
+
+                       drawfontscale = '1 1 0' * resize;
+                       s = textShortenToWidth(s, namewidth, '1 1 0' * autocvar_hud_shownames_fontsize, stringwidth_colors);
+
+                       float width;
+                       width = stringwidth(s, TRUE, '1 1 0' * autocvar_hud_shownames_fontsize);
+
+                       if (width != namewidth)
+                               namepos_x += (namewidth - width) / 2;
+                       drawcolorcodedstring(namepos, s, '1 1 0' * autocvar_hud_shownames_fontsize, a, DRAWFLAG_NORMAL);
+                       drawfontscale = '1 1 0';
+               }
+       }
+}
+
+entity shownames_ent[255];
+void Draw_ShowNames_All()
+{
+       float i;
+       for(i = 0; i < maxclients; ++i)
+       {
+               vector o;
+               float t;
+               t = GetPlayerColor(i);
+               if(t == COLOR_SPECTATOR)
+                       continue;
+
+               entity e;
+               e = shownames_ent[i];
+               if(!e)
+               {
+                       e = spawn();
+                       e.classname = "shownames_tag";
+                       e.sv_entnum = i+1;
+                       shownames_ent[i] = e;
+               }
+
+               entity entcs;
+               entcs = entcs_receiver[i];
+               if(entcs)
+               {
+                       e.healthvalue = entcs.healthvalue;
+                       e.armorvalue = entcs.armorvalue;
+                       e.sameteam = (teamplay && (t == myteam));
+               }
+               else
+               {
+                       e.healthvalue = 2342;
+                       e.armorvalue = 0;
+                       e.sameteam = 0;
+               }
+
+               e.origin = getplayerorigin(i);
+               if(e.origin == GETPLAYERORIGIN_ERROR)
+                       continue;
+
+               Draw_ShowNames(e);
+       }
 }
index f699e6db2f3e1733ebb87e708d60c6fc84b91919..e7acd7f8c91b39f5f46961122e6146bd2d364182 100644 (file)
@@ -1701,8 +1701,7 @@ void ClientConnect (void)
                ctf_clientconnect();
        }*/
 
-       if(teams_matter || radar_showennemies)
-               attach_entcs();
+       attach_entcs();
 
        bot_relinkplayerlist();
 
index 0a477b1b4d5298738f52c5c778cc7cdf3d8aa839..0763785bc0cd996a6ffb1b7551ec442e18fb4413 100644 (file)
@@ -31,7 +31,7 @@ float entcs_customize()
        if(other == o)
                return FALSE;
        if(other.classname == "player")
-               if(o.team != other.team)
+               if(!teams_matter || o.team != other.team)
                        if not (radar_showennemies)
                                return FALSE;
        return TRUE;
@@ -39,6 +39,7 @@ float entcs_customize()
 
 float entcs_send(entity to, float sf)
 {
+       // a simple safeguard, should not REALLY be needed
        sf |= 128;
        if(teams_matter && !radar_showennemies)
                if(to.team != self.team)
@@ -47,7 +48,7 @@ float entcs_send(entity to, float sf)
        WriteByte(MSG_ENTITY, ENT_CLIENT_ENTCS);
        WriteByte(MSG_ENTITY, sf);
        if(sf & 1)
-               WriteByte(MSG_ENTITY, num_for_edict(self.owner));
+               WriteByte(MSG_ENTITY, num_for_edict(self.owner)-1);
        if(sf & 2)
        {
                WriteShort(MSG_ENTITY, self.origin_x);