1 void turret_ewheel_projectile_explode()
\r
5 org2 = findbetterlocation (self.origin, 8);
\r
6 pointparticles(particleeffectnum("laser_impact"), org2, trace_plane_normal * 1000, 1);
\r
7 //w_deathtypestring = "saw the eweel. to late.";
\r
11 d = RadiusDamage (self, self.owner, self.owner.shot_dmg, 0, self.owner.shot_radius, world, self.owner.shot_force, DEATH_TURRET, world);
\r
12 self.owner.tur_dbg_dmg_t_h = self.owner.tur_dbg_dmg_t_h + d; //self.owner.shot_dmg;
\r
13 self.owner.tur_dbg_dmg_t_f = self.owner.tur_dbg_dmg_t_f + self.owner.shot_dmg;
\r
15 RadiusDamage (self, self.owner, self.owner.shot_dmg, 0, self.owner.shot_radius, world, self.owner.shot_force, DEATH_TURRET, world);
\r
17 sound (self, CHAN_PROJECTILE, "weapons/electro_impact.wav", VOL_BASE, ATTN_NORM);
\r
23 void ewheel_attack()
\r
30 turret_do_updates(self);
\r
32 sound (self, CHAN_WEAPON, "weapons/lasergun_fire.wav", VOL_BASE, ATTN_NORM);
\r
33 pointparticles(particleeffectnum("laser_muzzleflash"), self.tur_shotorg, self.tur_shotdir_updated * 1000, 1);
\r
36 setorigin(proj, self.tur_shotorg);
\r
37 //setsize(proj, '-0.5 -0.5 -0.5', '0.5 0.5 0.5');
\r
38 //setmodel(proj, "models/laser.mdl"); // precision set above
\r
39 proj.classname = "ewheel bolt";
\r
41 proj.bot_dodge = FALSE;
\r
42 proj.bot_dodgerating = self.shot_dmg;
\r
43 proj.think = turret_ewheel_projectile_explode;
\r
44 proj.nextthink = time + 9;
\r
45 proj.solid = SOLID_BBOX;
\r
46 proj.movetype = MOVETYPE_FLYMISSILE;
\r
47 proj.velocity = normalize(self.tur_shotdir_updated + randomvec() * self.shot_spread) * self.shot_speed;
\r
48 proj.angles = vectoangles(proj.velocity);
\r
49 proj.touch = turret_ewheel_projectile_explode;
\r
50 //proj.effects = EF_LOWPRECISION | EF_BRIGHTFIELD;
\r
51 proj.enemy = self.enemy;
\r
52 proj.flags = FL_PROJECTILE | FL_NOTARGET;
\r
54 CSQCProjectile(proj, TRUE, PROJECTILE_LASER, TRUE);
\r
56 self.tur_head.frame += 2;
\r
58 if (self.tur_head.frame > 3)
\r
59 self.tur_head.frame = 0;
\r
64 float ewheel_moveverb_path(float eval)
\r
70 if (self.pathcurrent)
\r
71 return verb.verb_static_value;
\r
76 // Do we have a path?
\r
77 if not(self.pathcurrent)
\r
81 // Are we close enougth to a path node to switch to the next?
\r
82 if (vlen(self.origin - self.pathcurrent.origin) < 32)
\r
83 if (self.pathcurrent.path_next == world)
\r
85 // Path endpoint reached
\r
86 pathlib_deletepath(self.pathcurrent.owner);
\r
87 self.pathcurrent = world;
\r
91 if (self.pathgoal.use)
\r
92 self.pathgoal.use();
\r
94 if (self.pathgoal.enemy)
\r
96 self.pathcurrent = pathlib_astar(self.pathgoal.origin,self.pathgoal.enemy.origin);
\r
97 self.pathgoal = self.pathgoal.enemy;
\r
101 self.pathgoal = world;
\r
104 self.pathcurrent = self.pathcurrent.path_next;
\r
108 if (self.pathcurrent)
\r
110 switch (self.waterlevel)
\r
118 self.moveto = self.pathcurrent.origin;
\r
119 self.steerto = steerlib_attract2(self.moveto,0.5,500,0.95);
\r
122 movelib_move_simple(v_forward,cvar("g_turrets_unit_ewheel_speed_slow"),0.4);
\r
124 return VS_CALL_YES_DOING;
\r
127 return VS_CALL_YES_DONE;
\r
131 if (self.pathcurrent)
\r
132 pathlib_deletepath(self.pathcurrent.owner);
\r
134 self.pathcurrent = world;
\r
136 return VS_CALL_YES_DONE;
\r
139 return VS_CALL_YES_DONE;
\r
142 float ewheel_moveverb_enemy(float eval)
\r
148 return verb.verb_static_value;
\r
154 self.moveto = self.enemy.origin;
\r
155 self.steerto = steerlib_arrive(self.enemy.origin,self.target_range_optimal);
\r
157 if (self.tur_dist_enemy > self.target_range_optimal)
\r
159 if ( self.tur_head.spawnshieldtime < 1 )
\r
162 movelib_move_simple(v_forward ,cvar("g_turrets_unit_ewheel_speed_fast"),0.4);
\r
164 else if (self.tur_head.spawnshieldtime < 2)
\r
167 movelib_move_simple(v_forward,cvar("g_turrets_unit_ewheel_speed_slow"),0.4);
\r
172 movelib_move_simple(v_forward,cvar("g_turrets_unit_ewheel_speed_slower"),0.4);
\r
175 else if (self.tur_dist_enemy < self.target_range_min)
\r
178 movelib_move_simple(v_forward * -1,cvar("g_turrets_unit_ewheel_speed_slow"),0.4);
\r
182 movelib_beak_simple(cvar("g_turrets_unit_ewheel_speed_stop"));
\r
185 return VS_CALL_YES_DOING;
\r
189 return VS_CALL_YES_DONE;
\r
192 float ewheel_moveverb_runaway(float eval)
\r
198 if (self.health < 50)
\r
199 return verb.verb_static_value;
\r
204 self.steerto = (steerlib_push(self.enemy.origin) * 0.7) + (steerlib_traceavoid_flat(0.3, 500, '0 0 128') * 0.3);
\r
205 self.moveto = self.origin + self.steerto * 1000;
\r
208 movelib_move_simple(v_forward ,cvar("g_turrets_unit_ewheel_speed_fast"),0.4);
\r
210 return VS_CALL_YES_DOING;
\r
214 return VS_CALL_YES_DONE;
\r
217 float ewheel_moveverb_idle(float eval)
\r
225 return verb.verb_static_value;
\r
228 self.moveto = self.origin;
\r
230 if (vlen(self.velocity))
\r
231 movelib_beak_simple(cvar("g_turrets_unit_ewheel_speed_stop"));
\r
233 return VS_CALL_YES_DOING;
\r
236 return VS_CALL_YES_DONE;
\r
239 void ewheel_postthink()
\r
242 vector wish_angle,real_angle;
\r
244 vz = self.velocity_z;
\r
246 self.angles_x = anglemods(self.angles_x);
\r
247 self.angles_y = anglemods(self.angles_y);
\r
249 self.angles_x *= -1;
\r
250 makevectors(self.angles);
\r
251 self.angles_x *= -1;
\r
253 wish_angle = normalize(self.steerto);
\r
254 wish_angle = vectoangles(wish_angle);
\r
255 real_angle = wish_angle - self.angles;
\r
256 real_angle = shortangle_vxy(real_angle,self.tur_head.angles);
\r
258 self.tur_head.spawnshieldtime = fabs(real_angle_y);
\r
259 real_angle_y = bound(self.tur_head.aim_speed * -1,real_angle_y,self.tur_head.aim_speed);
\r
260 self.angles_y = (self.angles_y + real_angle_y);
\r
262 // Simulate banking
\r
263 self.angles_z = bound(-45,real_angle_y * -2.5,45);
\r
265 verbstack_pop(self.verbs_move);
\r
267 if (self.frame > 40)
\r
270 if (self.frame < 1)
\r
274 self.velocity_z = vz;
\r
277 void ewheel_respawnhook()
\r
281 setorigin(self,self.pos1);
\r
283 if (self.target != "")
\r
285 e = find(world,targetname,self.target);
\r
288 dprint("Initital waypoint for ewheel does NOT exsist, fix your map!\n");
\r
292 if (e.classname != "turret_checkpoint")
\r
293 dprint("Warning: not a turrret path\n");
\r
296 self.pathcurrent = WALKER_PATH(self.origin,e.origin);
\r
302 void ewheel_diehook()
\r
304 turret_trowgib2(self.origin,self.velocity + v_up * 400,'-0.6 -0.2 -02',self,time + random() * 2 +3);
\r
306 if (self.pathcurrent)
\r
307 pathlib_deletepath(self.pathcurrent.owner);
\r
309 self.pathcurrent = world;
\r
311 if (self.damage_flags & TFL_DMG_DEATH_NORESPAWN)
\r
313 verbstack_flush(self.verbs_move);
\r
314 remove(self.verbs_move);
\r
319 void turret_ewheel_dinit()
\r
323 if (self.netname == "") self.netname = "eWheel Turret";
\r
325 if (self.target != "")
\r
327 e = find(world,targetname,self.target);
\r
330 bprint("Warning! initital waypoint for ewheel does NOT exsist!\n");
\r
334 if (e.classname != "turret_checkpoint")
\r
335 dprint("Warning: not a turrret path\n");
\r
337 self.goalcurrent = e;
\r
340 self.ammo_flags = TFL_AMMO_ENERGY | TFL_AMMO_RECHARGE | TFL_AMMO_RECIVE;
\r
341 self.turrcaps_flags = TFL_TURRCAPS_PLAYERKILL | TFL_TURRCAPS_MOVE | TFL_TURRCAPS_ROAM | TFL_TURRCAPS_HEADATTACHED;
\r
342 //self.aim_flags = TFL_AIM_SIMPLE;// TFL_AIM_LEAD | TFL_AIM_ZEASE;
\r
344 self.turret_respawnhook = ewheel_respawnhook;
\r
345 self.turret_diehook = ewheel_diehook;
\r
347 if (turret_stdproc_init("ewheel_std") == 0)
\r
353 self.target_select_flags = TFL_TARGETSELECT_PLAYERS | TFL_TARGETSELECT_RANGELIMTS | TFL_TARGETSELECT_TEAMCHECK | TFL_TARGETSELECT_LOS;
\r
354 self.target_validate_flags = TFL_TARGETSELECT_PLAYERS | TFL_TARGETSELECT_RANGELIMTS | TFL_TARGETSELECT_TEAMCHECK | TFL_TARGETSELECT_LOS;
\r
355 self.damage_flags |= TFL_DMG_DEATH_NOGIBS;
\r
357 self.iscreature = TRUE;
\r
358 self.movetype = MOVETYPE_WALK;
\r
359 self.solid = SOLID_SLIDEBOX;
\r
360 self.takedamage = DAMAGE_AIM;
\r
362 setmodel(self,"models/turrets/ewheel-base.md3");
\r
363 setmodel(self.tur_head,"models/turrets/ewheel-gun1.md3");
\r
364 setattachment(self.tur_head,self,"tag_head");
\r
366 self.pos1 = self.origin;
\r
368 self.idle_aim = '0 0 0';
\r
370 // Our fire routine
\r
371 self.turret_firefunc = ewheel_attack;
\r
372 self.turret_postthink = ewheel_postthink;
\r
373 self.tur_head.frame = 1;
\r
375 self.verbs_move = spawn();
\r
376 verbstack_push(self.verbs_move, ewheel_moveverb_idle, WVM_IDLE, 0);
\r
377 verbstack_push(self.verbs_move, ewheel_moveverb_enemy, WVM_ENEMY, 0);
\r
378 verbstack_push(self.verbs_move, ewheel_moveverb_path, WVM_PATH, 0);
\r
379 verbstack_push(self.verbs_move, ewheel_moveverb_runaway,WVM_PANIC, 0);
\r
381 // Convert from dgr / sec to dgr / tic
\r
382 self.tur_head.aim_speed = cvar("g_turrets_unit_ewheel_turnrate");
\r
383 self.tur_head.aim_speed = self.tur_head.aim_speed / (1 / self.ticrate);
\r
385 if (self.target != "")
\r
387 e = find(world,targetname,self.target);
\r
390 dprint("Initital waypoint for ewheel does NOT exsist, fix your map!\n");
\r
394 if (e.classname != "turret_checkpoint")
\r
395 dprint("Warning: not a turrret path\n");
\r
398 self.pathcurrent = WALKER_PATH(self.origin,e.origin);
\r
404 void spawnfunc_turret_ewheel()
\r
406 precache_model ("models/turrets/ewheel-base.md3");
\r
407 precache_model ("models/turrets/ewheel-gun1.md3");
\r
409 self.think = turret_ewheel_dinit;
\r
410 self.nextthink = time + 0.5;
\r