]> de.git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/blob - qcsrc/common/turrets/turret/tesla.qc
Merge branch 'master' into Mirio/balance
[xonotic/xonotic-data.pk3dir.git] / qcsrc / common / turrets / turret / tesla.qc
1 #ifndef TURRET_TESLA_H
2 #define TURRET_TESLA_H
3
4 #include "tesla_weapon.qh"
5
6 CLASS(TeslaCoil, Turret)
7 /* spawnflags */ ATTRIB(TeslaCoil, spawnflags, int, TUR_FLAG_HITSCAN | TUR_FLAG_PLAYER | TUR_FLAG_MISSILE);
8 /* mins       */ ATTRIB(TeslaCoil, mins, vector, '-60 -60 0');
9 /* maxs       */ ATTRIB(TeslaCoil, maxs, vector, '60 60 128');
10 /* modelname  */ ATTRIB(TeslaCoil, mdl, string, "tesla_base.md3");
11 /* model      */ ATTRIB_STRZONE(TeslaCoil, model, string, strcat("models/turrets/", this.mdl));
12 /* head_model */ ATTRIB_STRZONE(TeslaCoil, head_model, string, strcat("models/turrets/", "tesla_head.md3"));
13 /* netname    */ ATTRIB(TeslaCoil, netname, string, "tesla");
14 /* fullname   */ ATTRIB(TeslaCoil, turret_name, string, _("Tesla Coil"));
15     ATTRIB(TeslaCoil, m_weapon, Weapon, WEP_TESLA);
16 ENDCLASS(TeslaCoil)
17 REGISTER_TURRET(TESLA, NEW(TeslaCoil));
18
19 #endif
20
21 #ifdef IMPLEMENTATION
22
23 #ifdef SVQC
24
25 spawnfunc(turret_tesla) { if (!turret_initialize(TUR_TESLA)) remove(self); }
26
27 METHOD(TeslaCoil, tr_think, void(TeslaCoil thistur, entity it))
28 {
29     SELFPARAM();
30     if(!self.active)
31     {
32         self.tur_head.avelocity = '0 0 0';
33         return;
34     }
35
36     if(self.ammo < self.shot_dmg)
37     {
38         self.tur_head.avelocity = '0 45 0' * (self.ammo / self.shot_dmg);
39     }
40     else
41     {
42         self.tur_head.avelocity = '0 180 0' * (self.ammo / self.shot_dmg);
43
44         if(self.attack_finished_single[0] > time)
45             return;
46
47         float f;
48         f = (self.ammo / self.ammo_max);
49         f = f * f;
50         if(f > random())
51             if(random() < 0.1)
52                 te_csqc_lightningarc(self.tur_shotorg,self.tur_shotorg + (randomvec() * 350));
53     }
54 }
55
56 float turret_tesla_firecheck();
57 METHOD(TeslaCoil, tr_setup, void(TeslaCoil this, entity it))
58 {
59     it.target_validate_flags = TFL_TARGETSELECT_PLAYERS | TFL_TARGETSELECT_MISSILES |
60                          TFL_TARGETSELECT_RANGELIMITS | TFL_TARGETSELECT_TEAMCHECK;
61
62     it.turret_firecheckfunc = turret_tesla_firecheck;
63     it.target_select_flags = TFL_TARGETSELECT_PLAYERS | TFL_TARGETSELECT_MISSILES |
64                        TFL_TARGETSELECT_RANGELIMITS | TFL_TARGETSELECT_TEAMCHECK;
65
66     it.firecheck_flags  = TFL_FIRECHECK_REFIRE | TFL_FIRECHECK_AMMO_OWN;
67     it.shoot_flags              = TFL_SHOOT_CUSTOM;
68     it.ammo_flags                       = TFL_AMMO_ENERGY | TFL_AMMO_RECHARGE | TFL_AMMO_RECIEVE;
69     it.aim_flags                        = TFL_AIM_NO;
70     it.track_flags              = TFL_TRACK_NO;
71 }
72
73 float turret_tesla_firecheck()
74 {SELFPARAM();
75     // g_turrets_targetscan_maxdelay forces a target re-scan at least this often
76     float do_target_scan = 0;
77
78     if((self.target_select_time + autocvar_g_turrets_targetscan_maxdelay) < time)
79         do_target_scan = 1;
80
81     // Old target (if any) invalid?
82     if(self.target_validate_time < time)
83     if (turret_validate_target(self, self.enemy, self.target_validate_flags) <= 0)
84     {
85         self.enemy = world;
86         self.target_validate_time = time + 0.5;
87         do_target_scan = 1;
88     }
89
90     // But never more often then g_turrets_targetscan_mindelay!
91     if (self.target_select_time + autocvar_g_turrets_targetscan_mindelay > time)
92         do_target_scan = 0;
93
94     if(do_target_scan)
95     {
96         self.enemy = turret_select_target();
97         self.target_select_time = time;
98     }
99
100     if(!turret_firecheck())
101         return 0;
102
103     if(self.enemy)
104         return 1;
105
106     return 0;
107 }
108
109 #endif
110 #endif