]> de.git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/blob - qcsrc/common/gamemodes/gamemode/keepaway/cl_keepaway.qc
Merge branch 'master' into Juhu/strafehud
[xonotic/xonotic-data.pk3dir.git] / qcsrc / common / gamemodes / gamemode / keepaway / cl_keepaway.qc
1 #include "cl_keepaway.qh"
2
3 #include <client/draw.qh>
4 #include <client/hud/panel/modicons.qh>
5
6 // Keepaway HUD mod icon
7 int kaball_prevstatus; // last remembered status
8 float kaball_statuschange_time; // time when the status changed
9
10 // we don't need to reset for keepaway since it immediately
11 // autocorrects prevstatus as to if the player has the ball or not
12
13 void HUD_Mod_Keepaway(vector pos, vector mySize)
14 {
15         mod_active = 1; // keepaway should always show the mod HUD
16
17         float kaball_alpha = blink(0.85, 0.15, 5);
18
19         int stat_items = STAT(ITEMS);
20         int kaball = (stat_items/IT_KEY1) & 1;
21
22         if(kaball != kaball_prevstatus)
23         {
24                 kaball_statuschange_time = time;
25                 kaball_prevstatus = kaball;
26         }
27
28         vector kaball_pos, kaball_size;
29
30         if(mySize.x > mySize.y) {
31                 kaball_pos = pos + eX * 0.25 * mySize.x;
32                 kaball_size = vec2(0.5 * mySize.x, mySize.y);
33         } else {
34                 kaball_pos = pos + eY * 0.25 * mySize.y;
35                 kaball_size = vec2(mySize.x, 0.5 * mySize.y);
36         }
37
38         float kaball_statuschange_elapsedtime = time - kaball_statuschange_time;
39         float f = bound(0, kaball_statuschange_elapsedtime*2, 1);
40
41         if(kaball_prevstatus && f < 1)
42                 drawpic_aspect_skin_expanding(kaball_pos, "keepawayball_carrying", kaball_size, '1 1 1', panel_fg_alpha * kaball_alpha, DRAWFLAG_NORMAL, f);
43
44         if(kaball)
45                 drawpic_aspect_skin(pos, "keepawayball_carrying", vec2(mySize.x, mySize.y), '1 1 1', panel_fg_alpha * kaball_alpha * f, DRAWFLAG_NORMAL);
46 }