morph.qc 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601
  1. /* Copyright (C) 1996-2022 id Software LLC
  2. This program is free software; you can redistribute it and/or modify
  3. it under the terms of the GNU General Public License as published by
  4. the Free Software Foundation; either version 2 of the License, or
  5. (at your option) any later version.
  6. This program is distributed in the hope that it will be useful,
  7. but WITHOUT ANY WARRANTY; without even the implied warranty of
  8. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  9. GNU General Public License for more details.
  10. You should have received a copy of the GNU General Public License
  11. along with this program; if not, write to the Free Software
  12. Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  13. See file, 'COPYING', for details.
  14. */
  15. // morph.qc
  16. $skin aztec
  17. $skin pharoah
  18. $skin roman
  19. $skin florskin
  20. $frame mfstand1
  21. //$frame mfup01 mfup02 mfup03 mfup04 mfup05 mfup06
  22. //$frame mfup07 mfup08 mfup09 mfup10 mfup11 mfup12
  23. $frame start01 start02 start03 start04 start05 start06
  24. $frame start07 start08 start09 start10 start11 start12
  25. $frame start13 start14 start15 start16 start17 start18
  26. $frame start19 start20 start21 start22 start23 start24
  27. $frame start25 start26 start27 start28 start29 start30 start31
  28. $frame mfrun01 mfrun02 mfrun03 mfrun04 mfrun05 mfrun06
  29. $frame mfrun07 mfrun08 mfrun09 mfrun10 mfrun11
  30. $frame mfwlk01 mfwlk02 mfwlk03 mfwlk04 mfwlk05 mfwlk06 mfwlk07 mfwlk08
  31. $frame mfwlk09 mfwlk10 mfwlk11 mfwlk12 mfwlk13
  32. $frame mfata01 mfata02 mfata03 mfata04 mfata05
  33. $frame mfata06 mfata07 mfata08 mfata09
  34. $frame mfatb01 mfatb02 mfatb03 mfatb04 mfatb05 mfatb06
  35. $frame mfatb07 mfatb08 mfatb09 mfatb10 mfatb11
  36. $frame mfatc01 mfatc02 mfatc03 mfatc04 mfatc05 mfatc06
  37. $frame mfatc07 mfatc08 mfatc09 mfatc10 mfatc11 mfatc12
  38. $frame mfatc13 mfatc14 mfatc15 mfatc16
  39. $frame mfknck01 mfknck02 mfknck03 mfknck04 mfknck05 mfknck06
  40. $frame mfknck07 mfknck08 mfknck09 mfknck10 mfknck11 mfknck12
  41. $frame mfpain01 mfpain02 mfpain03 mfpain04 mfpain05
  42. $frame mfpain06 mfpain07 mfpain08 mfpain09 mfpain10
  43. $frame mfpbin01 mfpbin02 mfpbin03 mfpbin04 mfpbin05
  44. $frame mfpbin06 mfpbin07
  45. $frame mfdth01 mfdth02 mfdth03 mfdth04 mfdth05
  46. $frame mfdth06 mfdth07 mfdth08 mfdth09 mfdth10
  47. $frame mfdth11 mfdth12 mfdth13 mfdth14 mfdth15
  48. $frame mfdth16 mfdth17 mfdth18 mfdth19 mfdth20
  49. $frame mfdth21
  50. float MORPH_AZTEC = 2;
  51. float MORPH_EGYPT = 4;
  52. float MORPH_GREEK = 8;
  53. void() morph_teleport;
  54. // ========================
  55. // standing
  56. // ========================
  57. void() morph_stand1 = [ $mfstand1, morph_stand1 ] { ai_stand(); };
  58. // ========================
  59. // movement
  60. // ========================
  61. // 3 2 1 1 0 1 2 3 4 5 4 2 1 0
  62. // 3 2 1 2 3 4 4 3 2 1 2 3 3
  63. // 2 4 4 4 3 3 2 2 4 4 3 2 1
  64. // 4 5 5 4 3 2 2 4 5 4 3 2 2
  65. void() morph_walk1 = [ $mfwlk01, morph_walk2 ] {ai_walk(3);};
  66. void() morph_walk2 = [ $mfwlk02, morph_walk3 ] {ai_walk(2);};
  67. void() morph_walk3 = [ $mfwlk03, morph_walk4 ] {ai_walk(4);};
  68. void() morph_walk4 = [ $mfwlk04, morph_walk5 ] {ai_walk(5);};
  69. void() morph_walk5 = [ $mfwlk05, morph_walk6 ] {ai_walk(5);};
  70. void() morph_walk6 = [ $mfwlk06, morph_walk7 ] {ai_walk(4);};
  71. //1
  72. void() morph_walk7 = [ $mfwlk07, morph_walk8 ] {ai_walk(2);};
  73. //1
  74. void() morph_walk8 = [ $mfwlk08, morph_walk9 ] {ai_walk(3);};
  75. void() morph_walk9 = [ $mfwlk09, morph_walk10 ] {ai_walk(4);};
  76. void() morph_walk10 = [ $mfwlk10, morph_walk11 ] {ai_walk(5);};
  77. void() morph_walk11 = [ $mfwlk11, morph_walk12 ] {ai_walk(5);};
  78. void() morph_walk12 = [ $mfwlk12, morph_walk13 ] {ai_walk(4);};
  79. void() morph_walk13 = [ $mfwlk13, morph_walk1 ] {ai_walk(3);};
  80. // 1
  81. // 8 6 4 10 13 13 11 10
  82. // 11 15 10 10 8 15 10 8 8 8 8
  83. // 6 9 13 13 9 6 9 13 15 13 9
  84. void() morph_run1 = [ $mfrun01, morph_run2 ] { ai_run( 7);};
  85. // 33
  86. void() morph_run2 = [ $mfrun02, morph_run3 ] { ai_run(11);};
  87. void() morph_run3 = [ $mfrun03, morph_run4 ] { ai_run(16);};
  88. void() morph_run4 = [ $mfrun04, morph_run5 ] { ai_run(16);};
  89. // 36
  90. void() morph_run5 = [ $mfrun05, morph_run6 ] { ai_run(11);};
  91. void() morph_run6 = [ $mfrun06, morph_run7 ] { ai_run( 7);};
  92. // 38
  93. void() morph_run7 = [ $mfrun07, morph_run8 ] { ai_run(11);};
  94. void() morph_run8 = [ $mfrun08, morph_run9 ] { ai_run(15);};
  95. // 40
  96. void() morph_run9 = [ $mfrun09, morph_run10 ] {ai_run(19);};
  97. void() morph_run10 =[ $mfrun10, morph_run11 ] {ai_run(15);};
  98. void() morph_run11 =[ $mfrun11, morph_run1 ] { ai_run(11);};
  99. // 43
  100. // ========================
  101. // new attack code
  102. // ========================
  103. void() morph_stab2 =
  104. {
  105. local float dist;
  106. local float attackDamage;
  107. local vector org, dir;
  108. if (!self.enemy)
  109. return;
  110. if (!CanDamage (self.enemy, self))
  111. return;
  112. ai_face();
  113. dir = self.enemy.origin - self.origin + self.enemy.view_ofs;
  114. dist = vlen ( dir );
  115. dir = normalize ( dir );
  116. makevectors (self.angles);
  117. if ( dist <= 90 )
  118. {
  119. sound (self, CHAN_WEAPON, "enforcer/enfstop.wav", 1, ATTN_STATIC);
  120. attackDamage = (random() * 10) + 20;
  121. T_Damage (self.enemy, self, self, attackDamage);
  122. SpawnBlood ( self.enemy.origin, v_forward * 150, 14);
  123. }
  124. else
  125. {
  126. self.effects = self.effects | EF_MUZZLEFLASH;
  127. org = self.origin + v_forward * 80 + v_right * 4 + '0 0 4';
  128. LaunchLaser(org, dir);
  129. if ( dist )
  130. {
  131. LaunchLaser(org, (dir + v_right * 0.04));
  132. LaunchLaser(org, (dir - v_right * 0.04));
  133. }
  134. else
  135. {
  136. LaunchLaser(org, (dir + v_right * 0.10));
  137. LaunchLaser(org, (dir - v_right * 0.10));
  138. }
  139. }
  140. };
  141. // ========================
  142. // hand to hand attack
  143. // ========================
  144. void() morph_attack01 = [ $mfatb01, morph_attack02 ] {ai_face();};
  145. void() morph_attack02 = [ $mfatb02, morph_attack03 ] {ai_face();};
  146. void() morph_attack03 = [ $mfatb03, morph_attack04 ] {ai_face();};
  147. void() morph_attack04 = [ $mfatb04, morph_attack05 ] {ai_face();};
  148. void() morph_attack05 = [ $mfatb05, morph_attack06 ] {ai_face();};
  149. void() morph_attack06 = [ $mfatb06, morph_attack07 ] {ai_face();};
  150. void() morph_attack07 = [ $mfatb07, morph_attack08 ] {morph_stab2();};
  151. void() morph_attack08 = [ $mfatb08, morph_attack09 ] {ai_face();};
  152. void() morph_attack09 = [ $mfatb09, morph_attack10 ] {ai_face();};
  153. void() morph_attack10 = [ $mfatb10, morph_attack11 ] {ai_face();};
  154. void() morph_attack11 = [ $mfatb11, morph_attack12 ] {ai_face();};
  155. void() morph_attack12 = [ $mfatb01, morph_run1 ] {ai_face();};
  156. void() morph_bigattack01 = [ $mfatc01, morph_bigattack02 ] { ai_face(); };
  157. void() morph_bigattack02 = [ $mfatc02, morph_bigattack03 ] { ai_face(); };
  158. void() morph_bigattack03 = [ $mfatc03, morph_bigattack04 ] { ai_face(); };
  159. void() morph_bigattack04 = [ $mfatc04, morph_bigattack05 ] { ai_face(); };
  160. void() morph_bigattack05 = [ $mfatc05, morph_bigattack06 ] { ai_face(); };
  161. void() morph_bigattack06 = [ $mfatc06, morph_bigattack07 ] { ai_face(); };
  162. void() morph_bigattack07 = [ $mfatc07, morph_bigattack08 ] { ai_face(); };
  163. void() morph_bigattack08 = [ $mfatc08, morph_bigattack09 ] { ai_face(); };
  164. void() morph_bigattack09 = [ $mfatc09, morph_bigattack10 ] { ai_face(); };
  165. void() morph_bigattack10 = [ $mfatc10, morph_bigattack11 ] { morph_stab2();};
  166. void() morph_bigattack11 = [ $mfatc11, morph_bigattack12 ] { ai_face(); };
  167. void() morph_bigattack12 = [ $mfatc12, morph_bigattack13 ] { ai_face(); };
  168. void() morph_bigattack13 = [ $mfatc13, morph_bigattack14 ] { ai_face(); };
  169. void() morph_bigattack14 = [ $mfatc14, morph_bigattack15 ] { ai_face(); };
  170. void() morph_bigattack15 = [ $mfatc15, morph_bigattack16 ] { ai_face(); };
  171. void() morph_bigattack16 = [ $mfatc16, morph_bigattack17 ] { ai_face(); };
  172. void() morph_bigattack17 = [ $mfatc01, morph_run1 ] { ai_face(); };
  173. void() morph_smack =
  174. {
  175. local vector delta;
  176. local float ldmg;
  177. if (!self.enemy)
  178. return;
  179. if (!CanDamage (self.enemy, self))
  180. return;
  181. ai_face();
  182. delta = self.enemy.origin - self.origin;
  183. if (vlen(delta) > 100)
  184. return;
  185. ldmg = (random() * 10) + 10;
  186. T_Damage (self.enemy, self, self, ldmg);
  187. makevectors (self.angles);
  188. self.enemy.velocity = v_forward * 100 + '0 0 100';
  189. };
  190. void() morph_knockback01 = [ $mfknck01, morph_knockback02 ] { ai_face(); };
  191. void() morph_knockback02 = [ $mfknck02, morph_knockback03 ] { ai_face(); };
  192. void() morph_knockback03 = [ $mfknck03, morph_knockback04 ] { ai_face(); };
  193. void() morph_knockback04 = [ $mfknck04, morph_knockback05 ] { ai_face(); };
  194. void() morph_knockback05 = [ $mfknck05, morph_knockback06 ] { ai_face(); };
  195. void() morph_knockback06 = [ $mfknck06, morph_knockback07 ] { ai_face(); };
  196. void() morph_knockback07 = [ $mfknck07, morph_knockback08 ] { ai_face(); };
  197. void() morph_knockback08 = [ $mfknck08, morph_knockback09 ] { ai_face(); };
  198. void() morph_knockback09 = [ $mfknck09, morph_knockback10 ] { morph_smack(); };
  199. void() morph_knockback10 = [ $mfknck10, morph_knockback11 ] { ai_face(); };
  200. void() morph_knockback11 = [ $mfknck11, morph_knockback12 ] { ai_face(); };
  201. void() morph_knockback12 = [ $mfknck12, morph_run1 ] { ai_face(); };
  202. void() morph_attack =
  203. {
  204. local float attackChoice;
  205. attackChoice = random();
  206. if (attackChoice < 0.50)
  207. morph_bigattack01();
  208. else if (attackChoice < 0.75)
  209. morph_attack01();
  210. else
  211. morph_knockback01();
  212. };
  213. // ========================
  214. // ranged attack
  215. // ========================
  216. void() morph_fire =
  217. {
  218. local vector org, dir;
  219. ai_face();
  220. self.effects = self.effects | EF_MUZZLEFLASH;
  221. makevectors (self.angles);
  222. org = self.origin + v_forward * 30 + v_right * 8.5 + '0 0 16';
  223. dir = normalize ( self.enemy.origin - self.origin ) ;
  224. LaunchLaser(org, dir);
  225. if ( vlen (self.enemy.origin - self.origin) > 400 )
  226. {
  227. LaunchLaser(org, (dir + v_right * 0.04));
  228. LaunchLaser(org, (dir - v_right * 0.04));
  229. }
  230. else
  231. {
  232. LaunchLaser(org, (dir + v_right * 0.10));
  233. LaunchLaser(org, (dir - v_right * 0.10));
  234. }
  235. };
  236. void() morph_fire1 = [ $mfata01, morph_fire2 ] {ai_face();};
  237. void() morph_fire2 = [ $mfata02, morph_fire3 ] {ai_face();};
  238. void() morph_fire3 = [ $mfata03, morph_fire4 ] {ai_face();};
  239. void() morph_fire4 = [ $mfata04, morph_fire5 ] {morph_fire();};
  240. void() morph_fire5 = [ $mfata05, morph_fire6 ] {ai_face();};
  241. void() morph_fire6 = [ $mfata06, morph_fire7 ] {ai_face();};
  242. void() morph_fire7 = [ $mfata07, morph_fire8 ] {ai_face();};
  243. void() morph_fire8 = [ $mfata08, morph_fire9] {ai_face();};
  244. void() morph_fire9 = [ $mfata09, morph_run1 ] {ai_face();};
  245. // ========================
  246. // pain
  247. // ========================
  248. void() morph_painA1 = [ $mfpain01, morph_painA2 ] {};
  249. void() morph_painA2 = [ $mfpain02, morph_painA3 ] {};
  250. void() morph_painA3 = [ $mfpain03, morph_painA4 ] {};
  251. void() morph_painA4 = [ $mfpain04, morph_painA5 ] {};
  252. void() morph_painA5 = [ $mfpain05, morph_painA6 ] {};
  253. void() morph_painA6 = [ $mfpain06, morph_painA7 ] {};
  254. void() morph_painA7 = [ $mfpain07, morph_painA8 ] {};
  255. void() morph_painA8 = [ $mfpain08, morph_painA9 ] {};
  256. void() morph_painA9 = [ $mfpain09, morph_painA10 ] {};
  257. void() morph_painA10 = [ $mfpain10, morph_run1 ] {morph_teleport();};
  258. void() morph_painB1 = [ $mfpbin01, morph_painB2 ] {};
  259. void() morph_painB2 = [ $mfpbin02, morph_painB3 ] {};
  260. void() morph_painB3 = [ $mfpbin03, morph_painB4 ] {};
  261. void() morph_painB4 = [ $mfpbin04, morph_painB5 ] {};
  262. void() morph_painB5 = [ $mfpbin05, morph_painB6 ] {};
  263. void() morph_painB6 = [ $mfpbin06, morph_painB7 ] {};
  264. void() morph_painB7 = [ $mfpbin07, morph_run1 ] {morph_teleport();};
  265. void() morph_pain =
  266. {
  267. local float painChoice;
  268. if (skill == 3)
  269. {
  270. if (random() > 0.5)
  271. morph_teleport();
  272. return;
  273. }
  274. if (self.pain_finished > time)
  275. return;
  276. if (random() > 0.25)
  277. return;
  278. painChoice = random();
  279. self.pain_finished = time + 2;
  280. sound (self, CHAN_VOICE, "guard/pain1.wav", 1, ATTN_NORM );
  281. if ( painChoice > 0.6)
  282. self.think = morph_painB1;
  283. else
  284. self.think = morph_painA1;
  285. self.nextthink = time + 0.1;
  286. };
  287. // ========================
  288. // die
  289. // ========================
  290. void() morph_die1 = [ $mfdth01, morph_die2 ] {}; // 122
  291. void() morph_die2 = [ $mfdth02, morph_die3 ] {};
  292. void() morph_die3 = [ $mfdth03, morph_die4 ] {};
  293. void() morph_die4 = [ $mfdth04, morph_die5 ] {};
  294. void() morph_die5 = [ $mfdth05, morph_die6 ] {}; // 126
  295. void() morph_die6 = [ $mfdth06, morph_die7 ] {};
  296. void() morph_die7 = [ $mfdth07, morph_die8 ] {};
  297. void() morph_die8 = [ $mfdth08, morph_die9 ] {}; // 129
  298. void() morph_die9 = [ $mfdth09, morph_die10 ] { self.skin = self.skin + 1; };
  299. void() morph_die10 = [ $mfdth10, morph_die11 ] {};
  300. void() morph_die11 = [ $mfdth11, morph_die12 ] {};
  301. void() morph_die12 = [ $mfdth12, morph_die13 ] {}; // 132
  302. void() morph_die13 = [ $mfdth13, morph_die14 ] {};
  303. void() morph_die14 = [ $mfdth14, morph_die15 ] {};
  304. void() morph_die15 = [ $mfdth15, morph_die16 ] {};
  305. void() morph_die16 = [ $mfdth16, morph_die17 ] {}; // 136
  306. void() morph_die17 = [ $mfdth17, morph_die18 ] {};
  307. void() morph_die18 = [ $mfdth18, morph_die19 ] {};
  308. void() morph_die19 = [ $mfdth19, morph_die20 ] {};
  309. void() morph_die20 = [ $mfdth20, morph_die21 ] {}; // 140
  310. void() morph_die21 = [ $mfdth21, morph_die21 ]
  311. {
  312. remove(self);
  313. };
  314. void() morph_die =
  315. {
  316. sound ( self, CHAN_VOICE, "guard/death.wav", 1, ATTN_NORM);
  317. self.solid = SOLID_NOT;
  318. self.think = morph_die1;
  319. self.nextthink = time + 0.1;
  320. };
  321. // ========================
  322. // hide in floor
  323. // ========================
  324. void() morph_wake1 = [ $start01, morph_wake2 ]
  325. {
  326. sound ( self, CHAN_VOICE, "guard/see1.wav", 1, ATTN_NORM );
  327. if(self.owner)
  328. {
  329. // self.solid = SOLID_SLIDEBOX;
  330. // self.takedamage = DAMAGE_NO;
  331. total_monsters = total_monsters + 1;
  332. self.owner.childrenSpawned = self.owner.childrenSpawned + 1;
  333. WriteByte (MSG_BROADCAST, SVC_UPDATESTAT);
  334. WriteByte (MSG_BROADCAST, STAT_TOTALMONSTERS);
  335. WriteLong (MSG_BROADCAST, total_monsters);
  336. }
  337. };
  338. void() morph_wake2 = [ $start02, morph_wake3 ] {};
  339. void() morph_wake3 = [ $start03, morph_wake4 ] {};
  340. void() morph_wake4 = [ $start04, morph_wake5 ] {};
  341. void() morph_wake5 = [ $start05, morph_wake6 ] {};
  342. void() morph_wake6 = [ $start06, morph_wake7 ] {};
  343. void() morph_wake7 = [ $start07, morph_wake8 ] {};
  344. void() morph_wake8 = [ $start08, morph_wake9 ] {};
  345. void() morph_wake9 = [ $start09, morph_wake10 ] {};
  346. void() morph_wake10 = [ $start10, morph_wake11 ] {};
  347. void() morph_wake11 = [ $start11, morph_wake12 ] {};
  348. void() morph_wake12 = [ $start12, morph_wake13 ] {};
  349. void() morph_wake13 = [ $start13, morph_wake14 ] {};
  350. void() morph_wake14 = [ $start14, morph_wake15 ] {};
  351. void() morph_wake15 = [ $start15, morph_wake16 ]
  352. { self.skin = 1; };
  353. void() morph_wake16 = [ $start16, morph_wake17 ] {};
  354. void() morph_wake17 = [ $start17, morph_wake18 ] {};
  355. void() morph_wake18 = [ $start18, morph_wake20 ] {};
  356. //void() morph_wake18 = [ $start18, morph_wake19 ] {};
  357. //void() morph_wake19 = [ $start19, morph_wake20 ] {};
  358. void() morph_wake20 = [ $start20, morph_wake21 ] {};
  359. void() morph_wake21 = [ $start21, morph_wake22 ] {};
  360. void() morph_wake22 = [ $start22, morph_wake23 ] {};
  361. void() morph_wake23 = [ $start23, morph_wake24 ] {};
  362. void() morph_wake24 = [ $start24, morph_wake25 ] {};
  363. void() morph_wake25 = [ $start25, morph_wake26 ] {};
  364. void() morph_wake26 = [ $start26, morph_wake27 ] {};
  365. void() morph_wake27 = [ $start27, morph_wake28 ] {};
  366. void() morph_wake28 = [ $start28, morph_wake29 ] {};
  367. void() morph_wake29 = [ $start29, morph_wake30 ] {};
  368. void() morph_wake30 = [ $start30, morph_wake31 ] {};
  369. void() morph_wake31 = [ $start31, morph_stand1 ]
  370. {
  371. self.solid = SOLID_SLIDEBOX;
  372. self.takedamage = DAMAGE_AIM;
  373. self.skin = self.skin - 1;
  374. if ( self.owner )
  375. {
  376. self.think = morph_run1;
  377. self.nextthink = time + 0.1;
  378. }
  379. };
  380. void(entity theMorph) morph_setup =
  381. {
  382. theMorph.solid = SOLID_SLIDEBOX;
  383. theMorph.movetype = MOVETYPE_STEP;
  384. theMorph.takedamage = DAMAGE_NO;
  385. theMorph.flags = theMorph.flags | FL_MONSTER;
  386. theMorph.ideal_yaw = theMorph.angles * '0 1 0';
  387. if (!theMorph.yaw_speed)
  388. theMorph.yaw_speed = 20;
  389. theMorph.view_ofs = '0 0 25';
  390. theMorph.frame = $start01;
  391. setmodel (theMorph, theMorph.model);
  392. setsize (theMorph, VEC_HULL_MIN, VEC_HULL_MAX);
  393. theMorph.th_stand = morph_stand1;
  394. theMorph.th_walk = morph_walk1;
  395. theMorph.th_run = morph_run1;
  396. theMorph.th_missile = morph_fire1;
  397. theMorph.th_melee = morph_attack;
  398. theMorph.th_pain = morph_pain;
  399. theMorph.th_die = morph_die;
  400. if ( theMorph.owner )
  401. {
  402. theMorph.effects = 0;
  403. theMorph.health = 200;
  404. theMorph.spawnflags = theMorph.owner.spawnflags;
  405. }
  406. else
  407. {
  408. theMorph.effects = theMorph.effects | EF_DIMLIGHT;
  409. theMorph.health = 2000;
  410. }
  411. // theMorph.frame = $start01;
  412. theMorph.skin = 2;
  413. };
  414. void() morph_wake =
  415. {
  416. if (isSpawnPointEmpty(self))
  417. {
  418. morph_setup(self);
  419. self.think = morph_wake1;
  420. }
  421. else
  422. {
  423. self.think = morph_wake;
  424. }
  425. self.nextthink = time + 0.1;
  426. };
  427. void() morph_use =
  428. {
  429. // self.enemy = activator;
  430. if ( self.delay )
  431. {
  432. self.think = morph_wake;
  433. self.nextthink = time + self.delay;
  434. }
  435. else
  436. {
  437. self.think = morph_wake;
  438. self.nextthink = time + 0.1;
  439. }
  440. };
  441. void() morph_teleport =
  442. {
  443. local entity theDest;
  444. local entity theChild;
  445. local entity selfTemp;
  446. if (self.owner)
  447. return;
  448. if (self.childrenSpawned > (1+skill))
  449. return;
  450. theDest = overlord_find_dest3();
  451. if (theDest == world)
  452. return;
  453. theChild = spawn();
  454. theChild.model = self.model;
  455. theChild.angles = theDest.mangle;
  456. theChild.owner = self;
  457. theChild.enemy = self.enemy;
  458. theChild.movetarget = self.movetarget;
  459. theChild.goalentity = self.goalentity;
  460. theChild.mangle = theDest.mangle;
  461. theChild.classname = "monster_morph";
  462. morph_setup (theChild);
  463. setorigin (theChild, theDest.origin);
  464. droptofloor();
  465. theChild.think = morph_wake1;
  466. theChild.nextthink = time + 0.3;
  467. };
  468. /*QUAKED monster_morph (1 0 0) (-16 -16 -24) (16 16 32) Ambush Aztec Egyptian Greek
  469. The morphing monster.
  470. Select the look of the monster (Aztec,Greek,Egyptian).
  471. If the monster has a targetname (triggered by something) he will rise up out of the floor when triggered.
  472. */
  473. void() monster_morph =
  474. {
  475. if (deathmatch)
  476. {
  477. remove(self);
  478. return;
  479. }
  480. if (self.spawnflags & MORPH_AZTEC) // Aztec
  481. {
  482. precache_model ("progs/morph_az.mdl");
  483. self.model = "progs/morph_az.mdl";
  484. }
  485. else if (self.spawnflags & MORPH_EGYPT)
  486. // Egyptian
  487. {
  488. precache_model ("progs/morph_eg.mdl");
  489. self.model = "progs/morph_eg.mdl";
  490. }
  491. else if (self.spawnflags & MORPH_GREEK) // greek
  492. {
  493. precache_model ("progs/morph_gr.mdl");
  494. self.model = "progs/morph_gr.mdl";
  495. }
  496. else
  497. objerror ( "monster_morph: no skin selection!");
  498. precache_model2 ("progs/laser.mdl");
  499. precache_sound2 ("enforcer/enfire.wav");
  500. precache_sound2 ("guard/death.wav");
  501. precache_sound2 ("guard/pain1.wav");
  502. precache_sound2 ("guard/see1.wav");
  503. total_monsters = total_monsters + 1;
  504. if(self.targetname)
  505. {
  506. self.use = morph_use;
  507. }
  508. else
  509. {
  510. morph_wake ();
  511. }
  512. };