Xonotic
teamradar.qc
Go to the documentation of this file.
1 #include "teamradar.qh"
2 
3 #include <client/hud/_mod.qh>
4 #include <client/view.qh>
7 
9 {
10  vector out;
11  out.x = (in.x - mi_picmin.x) / (mi_picmax.x - mi_picmin.x);
12  out.y = (in.y - mi_picmin.y) / (mi_picmax.y - mi_picmin.y);
13  out.z = 0;
14  return out;
15 }
16 
18 {
19  vector out;
21 
22  out = Rotate(in, teamradar_angle * DEG2RAD);
23  out.y = - out.y; // screen space is reversed
24 
25  out = out * teamradar_size;
26  if(v_flipped)
27  out.x = -out.x;
28  out += teamradar_origin2d;
29  return out;
30 }
31 
32 
34 {
35  vector out;
36  out = in;
37 
38  out -= teamradar_origin2d;
39  if(v_flipped)
40  out_x = -out_x;
41  out = out / teamradar_size;
42 
43  out_y = - out_y; // screen space is reversed
44  out = Rotate(out, -teamradar_angle * DEG2RAD);
45 
47 
48  return out;
49 }
50 
52 {
53  vector out;
54  out_x = in_x * (mi_picmax_x - mi_picmin_x) + mi_picmin_x;
55  out_y = in_y * (mi_picmax_y - mi_picmin_y) + mi_picmin_y;
56  out_z = oz;
57  return out;
58 }
59 
61 {
62  float fga;
63  vector fgc;
64 
65  if(fg > 0 && minimapname != "")
66  {
67  fga = 1;
68  fgc = '1 1 1' * fg;
69  R_BeginPolygon(minimapname, DRAWFLAG_SCREEN | DRAWFLAG_MIPMAP, true);
70  if(v_flipped)
71  {
72  R_PolygonVertex(teamradar_texcoord_to_2dcoord(mi_pictexcoord3), yinvert(mi_pictexcoord3), fgc, fga);
73  R_PolygonVertex(teamradar_texcoord_to_2dcoord(mi_pictexcoord2), yinvert(mi_pictexcoord2), fgc, fga);
74  R_PolygonVertex(teamradar_texcoord_to_2dcoord(mi_pictexcoord1), yinvert(mi_pictexcoord1), fgc, fga);
75  R_PolygonVertex(teamradar_texcoord_to_2dcoord(mi_pictexcoord0), yinvert(mi_pictexcoord0), fgc, fga);
76  }
77  else
78  {
79  R_PolygonVertex(teamradar_texcoord_to_2dcoord(mi_pictexcoord0), yinvert(mi_pictexcoord0), fgc, fga);
80  R_PolygonVertex(teamradar_texcoord_to_2dcoord(mi_pictexcoord1), yinvert(mi_pictexcoord1), fgc, fga);
81  R_PolygonVertex(teamradar_texcoord_to_2dcoord(mi_pictexcoord2), yinvert(mi_pictexcoord2), fgc, fga);
82  R_PolygonVertex(teamradar_texcoord_to_2dcoord(mi_pictexcoord3), yinvert(mi_pictexcoord3), fgc, fga);
83  }
84  R_EndPolygon();
85  }
86 }
87 
88 void draw_teamradar_player(vector coord3d, vector pangles, vector rgb)
89 {
90  vector coord, rgb2;
91 
93 
94  vector forward, right, up;
95  MAKE_VECTORS(pangles - '0 1 0' * teamradar_angle, forward, right, up);
96  if(v_flipped)
97  {
98  forward.x = -forward.x;
99  right.x = -right.x;
100  up.x = -up.x; // TODO: unused!
101  }
102  forward.z = 0;
103  forward = normalize(forward);
104  forward.y *= -1.0;
105  right.x = -forward.y;
106  right.y = forward.x;
107 
108  if(rgb == '1 1 1')
109  rgb2 = '0 0 0';
110  else
111  rgb2 = '1 1 1';
112 
113  R_BeginPolygon("", 0, true);
114  R_PolygonVertex(coord+forward*3, '0 0 0', rgb2, panel_fg_alpha);
115  R_PolygonVertex(coord+right*4-forward*2.5, '0 1 0', rgb2, panel_fg_alpha);
116  R_PolygonVertex(coord-forward*2, '1 0 0', rgb2, panel_fg_alpha);
117  R_PolygonVertex(coord-right*4-forward*2.5, '1 1 0', rgb2, panel_fg_alpha);
118  R_EndPolygon();
119 
120  R_BeginPolygon("", 0, true);
121  R_PolygonVertex(coord+forward*2, '0 0 0', rgb, panel_fg_alpha);
122  R_PolygonVertex(coord+right*3-forward*2, '0 1 0', rgb, panel_fg_alpha);
123  R_PolygonVertex(coord-forward, '1 0 0', rgb, panel_fg_alpha);
124  R_PolygonVertex(coord-right*3-forward*2, '1 1 0', rgb, panel_fg_alpha);
125  R_EndPolygon();
126 }
127 
128 void draw_teamradar_icon(vector coord, entity icon, entity pingdata, vector rgb, float a)
129 {
131  drawpic_builtin(coord - '4 4 0', strcat("gfx/teamradar_icon_", ftos(icon.m_radaricon)), '8 8 0', rgb, a, 0);
132 
133  if(pingdata)
134  {
135  for(int i = 0; i < MAX_TEAMRADAR_TIMES; ++i)
136  {
137  float dt = pingdata.(teamradar_times[i]);
138  if(dt == 0)
139  continue;
140  dt = time - dt;
141  if(dt >= 1 || dt <= 0)
142  continue;
143  vector v = '2 2 0' * teamradar_size * dt;
144  drawpic_builtin(coord - 0.5 * v, "gfx/teamradar_ping", v, '1 1 1', (1 - dt) * a, DRAWFLAG_ADDITIVE);
145  }
146  }
147 }
148 
149 void draw_teamradar_link(vector start, vector end, int colors)
150 {
151  TC(int, colors);
152  vector c0, c1, norm;
153 
156  norm = normalize(start - end);
157  norm.z = norm.x;
158  norm.x = -norm.y;
159  norm.y = norm.z;
160  norm.z = 0;
161 
162  c0 = colormapPaletteColor(colors & 0x0F, false);
163  c1 = colormapPaletteColor((colors & 0xF0) / 0x10, false);
164 
165  R_BeginPolygon("", 0, true);
166  R_PolygonVertex(start - norm, '0 0 0', c0, panel_fg_alpha);
167  R_PolygonVertex(start + norm, '0 1 0', c0, panel_fg_alpha);
168  R_PolygonVertex(end + norm, '1 1 0', c1, panel_fg_alpha);
169  R_PolygonVertex(end - norm, '1 0 0', c1, panel_fg_alpha);
170  R_EndPolygon();
171 }
172 
174 {
178  {
181  }
187 
188  // others default to 0
189  // match this to default hud cfg file!
194 }
195 
196 // radar links
197 
198 NET_HANDLE(ENT_CLIENT_RADARLINK, bool isnew)
199 {
200  int sendflags = ReadByte();
201 
203 
205  if (isnew) IL_PUSH(g_radarlinks, this);
206 
207  if(sendflags & 1)
208  {
209  this.origin = ReadVector();
210  setorigin(this, this.origin);
211  }
212 
213  if(sendflags & 2)
214  {
215  this.velocity = ReadVector();
216  }
217 
218  if(sendflags & 4)
219  {
220  this.team = ReadByte();
221  }
222 
223  return = true;
224 
226 }
const int MAX_TEAMRADAR_TIMES
Definition: teamradar.qh:3
void InterpolateOrigin_Note(entity this)
Definition: interpolate.qc:37
bool hud_panel_radar_maximized
Definition: hud.qh:69
float panel_fg_alpha
Definition: hud.qh:166
float DEG2RAD
Definition: csprogsdefs.qc:961
int iflags
Definition: interpolate.qh:26
void InterpolateOrigin_Undo(entity this)
snap origin to iorigin2 (actual origin)
Definition: interpolate.qc:159
int hud_panel_radar_zoommode
Definition: teamradar.qh:24
vector teamradar_3dcoord_to_texcoord(vector in)
Definition: teamradar.qc:8
float v_flipped
Definition: teamradar.qh:18
bool autocvar__hud_configure
Definition: hud_config.qh:3
int team
Definition: main.qh:157
float autocvar_hud_panel_radar_rotation
Definition: radar.qh:9
IntrusiveList g_radarlinks
Definition: main.qh:79
entity() spawn
float hud_panel_radar_foreground_alpha
Definition: teamradar.qh:21
const float DRAWFLAG_SCREEN
Definition: csprogsdefs.qc:321
float autocvar_hud_panel_radar_maximized_scale
Definition: radar.qh:7
const float DRAWFLAG_MIPMAP
Definition: csprogsdefs.qc:322
origin
Definition: ent_cs.qc:114
int hud_panel_radar_rotation
Definition: teamradar.qh:22
void teamradar_loadcvars()
Definition: teamradar.qc:173
vector teamradar_2dcoord_to_texcoord(vector in)
Definition: teamradar.qc:33
const int IFLAG_VELOCITY
Definition: interpolate.qh:27
float teamradar_angle
Definition: teamradar.qh:12
float autocvar_hud_panel_radar_foreground_alpha
Definition: radar.qh:6
const float DRAWFLAG_ADDITIVE
Definition: csprogsdefs.qc:318
vector teamradar_texcoord_to_2dcoord(vector in)
Definition: teamradar.qc:17
void draw_teamradar_link(vector start, vector end, int colors)
Definition: teamradar.qc:149
void draw_teamradar_icon(vector coord, entity icon, entity pingdata, vector rgb, float a)
Definition: teamradar.qc:128
ERASEABLE entity IL_PUSH(IntrusiveList this, entity it)
Push to tail.
int autocvar_hud_panel_radar_maximized_zoommode
Definition: radar.qh:13
float autocvar_hud_panel_radar_scale
Definition: radar.qh:10
spree_cen s1 spree_cen s1 spree_cen s1 spree_cen s1 spree_cen s1 spree_cen s1 spree_cen s1 f1 s1 strcat(_("Level %s: "), "^BG%s\3\, _("^BGPress ^F2%s^BG to enter the game"))
int autocvar_hud_panel_radar_zoommode
Definition: radar.qh:11
#define TC(T, sym)
Definition: _all.inc:82
void draw_teamradar_player(vector coord3d, vector pangles, vector rgb)
Definition: teamradar.qc:88
bool autocvar_v_flipped
Definition: view.qh:70
void draw_teamradar_background(float fg)
Definition: teamradar.qc:60
vector(float skel, float bonenum) _skel_get_boneabs_hidden
float teamradar_size
Definition: teamradar.qh:17
vector hud_panel_radar_size
Definition: teamradar.qh:23
const int IFLAG_ORIGIN
Definition: interpolate.qh:36
vector v
Definition: ent_cs.qc:116
vector teamradar_origin3d_in_texcoord
Definition: teamradar.qh:13
vector teamradar_origin2d
Definition: teamradar.qh:14
int hud_panel_radar_maximized_zoommode
Definition: teamradar.qh:25
vector teamradar_texcoord_to_3dcoord(vector in, float oz)
Definition: teamradar.qc:51
string minimapname
Definition: main.qh:27
float hud_panel_radar_scale
Definition: teamradar.qh:20
entity int sendflags
Definition: self.qh:96
setorigin(ent, v)
#define yinvert(v)
Definition: vector.qh:112
ERASEABLE vector Rotate(vector v, float a)
Definition: vector.qh:105
float autocvar_hud_panel_radar_maximized_rotation
Definition: radar.qh:12
NET_HANDLE(ENT_CLIENT_RADARLINK, bool isnew)
Definition: teamradar.qc:198
float time
Definition: csprogsdefs.qc:16
vector velocity
Definition: csprogsdefs.qc:103
#define colormapPaletteColor(c, isPants)
Definition: color.qh:5
int hud_panel_radar_maximized_rotation
Definition: teamradar.qh:26