123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- void(entity destEnt, float radius, vector offset) ai_orbit =
- {
- local vector dir;
- local float dist;
- if (self.orbitPosition > 3)
- self.orbitPosition = 0;
- else if (self.orbitPosition < 0)
- self.orbitPosition = 0;
-
- traceline ( self.origin, destEnt.origin + offset, TRUE, world);
- if ( trace_fraction < 1 )
- {
- setorigin (self, destEnt.origin + offset);
- self.orbitPosition = self.orbitPosition + 1;
- return;
- }
-
- if ( self.orbitPosition == 0)
- {
- dir = (destEnt.origin + offset) - self.origin;
- dir_x = dir_x + radius;
- }
- else if ( self.orbitPosition == 1)
- {
- dir = (destEnt.origin + offset) - self.origin;
- dir_y = dir_y + radius;
- }
- else if ( self.orbitPosition == 2)
- {
- dir = (destEnt.origin + offset) - self.origin;
- dir_x = dir_x - radius;
- }
- else
- {
- dir = (destEnt.origin + offset) - self.origin;
- dir_y = dir_y - radius;
- }
- dist = vlen(dir);
- if( dist < 8 )
- {
- self.orbitPosition = self.orbitPosition + 1;
- }
- else if( dist < 50 )
- {
- self.velocity = normalize(dir);
- self.velocity = self.velocity * 150;
- }
- else
- {
- self.velocity = normalize(dir);
- self.velocity = self.velocity * 500;
- }
- };
- void(entity destEnt, float trackSpeed) ai_track =
- {
- local vector dir;
-
- dir = destEnt.origin + destEnt.view_ofs;
- dir = normalize(dir - self.origin);
- self.velocity = dir * trackSpeed;
- };
- void(string gibname, float dm) AccelerateGib =
- {
- local entity new;
- local float offset1;
- new = spawn();
- new.origin = self.origin;
- setmodel (new, gibname);
- setsize (new, '-8 -8 -8', '8 8 8');
-
- new.velocity = -1.25 * self.velocity;
- makevectors ( new.velocity );
- offset1 = random() * 300 - 150;
- new.velocity = new.velocity + v_right * offset1;
- offset1 = random() * 300 - 150;
- new.velocity = new.velocity + v_up * offset1;
-
- new.movetype = MOVETYPE_BOUNCE;
- new.solid = SOLID_NOT;
- new.avelocity_x = random()*600;
- new.avelocity_y = random()*600;
- new.avelocity_z = random()*600;
- new.think = SUB_Remove;
- new.ltime = time;
- new.nextthink = time + 10 + random()*10;
- new.frame = 0;
- new.flags = 0;
- };
- void(float gibCount) ViolentDeath =
- {
- while(gibCount > 0)
- {
- AccelerateGib ("progs/gib1.mdl", (-4 * gibCount));
- AccelerateGib ("progs/gib2.mdl", (-6 * gibCount));
- AccelerateGib ("progs/gib3.mdl", (-8 * gibCount));
- gibCount = gibCount - 3;
- }
- };
- entity(string gibname) StartGib =
- {
- local entity new;
- new = spawn();
- new.origin = self.origin;
- setmodel (new, gibname);
- setsize (new, '0 0 0', '0 0 0');
-
- new.movetype = MOVETYPE_BOUNCE;
- new.solid = SOLID_NOT;
- new.think = SUB_Remove;
- new.ltime = time;
- new.nextthink = time + 10 + random()*10;
- new.frame = 0;
- new.flags = 0;
-
- return new;
- };
|