mirror of
https://github.com/open-goal/jak-project
synced 2026-06-03 18:36:52 -04:00
66e395d547
* detect `seek!` and `seekl!` * fancy struct instead of pair mess * fixes * i think this was wrong? * update refs * update source * More logical branching * even better branching
1798 lines
60 KiB
Common Lisp
Vendored
Generated
1798 lines
60 KiB
Common Lisp
Vendored
Generated
;;-*-Lisp-*-
|
|
(in-package goal)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpartgroup group-kermit-charging-up
|
|
:id 298
|
|
:bounds (static-bspherem 0 5 0 5)
|
|
:parts
|
|
((sp-item 1359 :fade-after (meters 140) :falloff-to (meters 140) :binding 1356)
|
|
(sp-item 1359 :fade-after (meters 140) :falloff-to (meters 140) :binding 1357)
|
|
(sp-item 1359 :fade-after (meters 140) :falloff-to (meters 140) :binding 1358)
|
|
(sp-item 1360)
|
|
(sp-item 1361 :fade-after (meters 120) :falloff-to (meters 120))
|
|
(sp-item 1362 :fade-after (meters 120) :falloff-to (meters 120))
|
|
(sp-item 1363 :fade-after (meters 120) :falloff-to (meters 120))
|
|
(sp-item 1358 :fade-after (meters 30) :falloff-to (meters 30) :flags (start-dead))
|
|
(sp-item 1357 :fade-after (meters 60) :falloff-to (meters 60) :flags (start-dead))
|
|
(sp-item 1356 :fade-after (meters 80) :falloff-to (meters 80) :flags (start-dead))
|
|
(sp-item 1358 :fade-after (meters 90) :falloff-to (meters 90) :flags (start-dead))
|
|
(sp-item 1357 :fade-after (meters 100) :falloff-to (meters 100) :flags (start-dead))
|
|
(sp-item 1356 :fade-after (meters 110) :falloff-to (meters 110) :flags (start-dead))
|
|
(sp-item 1358 :fade-after (meters 120) :falloff-to (meters 120) :flags (start-dead))
|
|
(sp-item 1357 :fade-after (meters 120) :falloff-to (meters 120) :flags (start-dead))
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1360
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #x4 :page #x2))
|
|
(sp-rnd-flt spt-num 0.1 1.0 1.0)
|
|
(sp-rnd-flt spt-x (meters -0.75) (meters 1.5) 1.0)
|
|
(sp-flt spt-y (meters 0.5))
|
|
(sp-rnd-flt spt-z (meters -0.75) (meters 1.5) 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 1.5) (meters 1.4) 1.0)
|
|
(sp-copy-from-other spt-scale-y -4)
|
|
(sp-flt spt-r 32.0)
|
|
(sp-flt spt-g 32.0)
|
|
(sp-flt spt-b 192.0)
|
|
(sp-flt spt-a 64.0)
|
|
(sp-rnd-flt spt-vel-y (meters 0.016666668) (meters 0.016666668) 1.0)
|
|
(sp-flt spt-fade-a -0.2)
|
|
(sp-int spt-timer 300)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1359
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #x12 :page #x2))
|
|
(sp-rnd-flt spt-num 0.05 0.1 1.0)
|
|
(sp-rnd-flt spt-x (meters -0.75) (meters 1.5) 1.0)
|
|
(sp-flt spt-y (meters 0.5))
|
|
(sp-rnd-flt spt-z (meters -0.75) (meters 1.5) 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 1.5) (meters 0.4) 1.0)
|
|
(sp-copy-from-other spt-scale-y -4)
|
|
(sp-flt spt-r 64.0)
|
|
(sp-flt spt-g 64.0)
|
|
(sp-flt spt-b 192.0)
|
|
(sp-flt spt-a 96.0)
|
|
(sp-rnd-flt spt-vel-y (meters 0.01) (meters 0.01) 1.0)
|
|
(sp-flt spt-fade-a 0.0)
|
|
(sp-int spt-timer 300)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1356
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #x1f :page #x2))
|
|
(sp-flt spt-num 1.0)
|
|
(sp-sound (new 'static 'sound-spec
|
|
:mask #x1
|
|
:num 0.05
|
|
:group #x1
|
|
:sound-name (static-sound-name "eco-blue-spark1")
|
|
:volume #x2cc
|
|
)
|
|
)
|
|
(sp-rnd-flt spt-scale-x (meters 0.5) (meters 1.5) 1.0)
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 0.2) (meters 0.1) 1.0)
|
|
(sp-flt spt-r 64.0)
|
|
(sp-flt spt-g 64.0)
|
|
(sp-flt spt-b 128.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-flt spt-fade-a -1.6)
|
|
(sp-int spt-timer 90)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 10)
|
|
(sp-launcher-by-id spt-next-launcher 1364)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1357
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #x23 :page #x2))
|
|
(sp-flt spt-num 1.0)
|
|
(sp-sound (new 'static 'sound-spec
|
|
:mask #x1
|
|
:num 0.075
|
|
:group #x1
|
|
:sound-name (static-sound-name "eco-blue-spark2")
|
|
:volume #x400
|
|
)
|
|
)
|
|
(sp-rnd-flt spt-scale-x (meters 0.5) (meters 1.5) 1.0)
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 0.2) (meters 0.1) 1.0)
|
|
(sp-flt spt-r 64.0)
|
|
(sp-flt spt-g 64.0)
|
|
(sp-flt spt-b 128.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-flt spt-fade-a -1.6)
|
|
(sp-int spt-timer 90)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 10)
|
|
(sp-launcher-by-id spt-next-launcher 1364)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1358
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #x24 :page #x2))
|
|
(sp-flt spt-num 1.0)
|
|
(sp-sound (new 'static 'sound-spec
|
|
:mask #x1
|
|
:num 0.05
|
|
:group #x1
|
|
:sound-name (static-sound-name "eco-blue-spark3")
|
|
:volume #x2cc
|
|
)
|
|
)
|
|
(sp-rnd-flt spt-scale-x (meters 0.5) (meters 1.5) 1.0)
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 0.2) (meters 0.1) 1.0)
|
|
(sp-flt spt-r 64.0)
|
|
(sp-flt spt-g 64.0)
|
|
(sp-flt spt-b 128.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-flt spt-fade-a -1.6)
|
|
(sp-int spt-timer 90)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 10)
|
|
(sp-launcher-by-id spt-next-launcher 1364)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1361
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #x1f :page #x2))
|
|
(sp-rnd-flt spt-num 0.1 0.5 1.0)
|
|
(sp-rnd-flt spt-x (meters -0.5) (meters 1) 1.0)
|
|
(sp-flt spt-y (meters 0.5))
|
|
(sp-rnd-flt spt-z (meters -0.5) (meters 1) 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 1.5) (meters 1.5) 1.0)
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees 10.0) (degrees 160.0) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 0.2) (meters 0.1) 1.0)
|
|
(sp-flt spt-r 128.0)
|
|
(sp-flt spt-g 128.0)
|
|
(sp-flt spt-b 255.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-flt spt-fade-a -1.6)
|
|
(sp-int spt-timer 91)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 10)
|
|
(sp-launcher-by-id spt-next-launcher 1364)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1362
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #x23 :page #x2))
|
|
(sp-rnd-flt spt-num 0.2 0.4 1.0)
|
|
(sp-rnd-flt spt-x (meters -0.5) (meters 1) 1.0)
|
|
(sp-flt spt-y (meters 0.5))
|
|
(sp-rnd-flt spt-z (meters -0.5) (meters 1) 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 1.5) (meters 1.5) 1.0)
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees 10.0) (degrees 160.0) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 0.2) (meters 0.1) 1.0)
|
|
(sp-flt spt-r 128.0)
|
|
(sp-flt spt-g 128.0)
|
|
(sp-flt spt-b 255.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-flt spt-fade-a -1.6)
|
|
(sp-int spt-timer 91)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 10)
|
|
(sp-launcher-by-id spt-next-launcher 1364)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1363
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #x24 :page #x2))
|
|
(sp-rnd-flt spt-num 0.3 0.1 1.0)
|
|
(sp-rnd-flt spt-x (meters -0.5) (meters 1) 1.0)
|
|
(sp-flt spt-y (meters 0.5))
|
|
(sp-rnd-flt spt-z (meters -0.5) (meters 1) 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 1.5) (meters 1.5) 1.0)
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees 10.0) (degrees 160.0) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 0.2) (meters 0.1) 1.0)
|
|
(sp-flt spt-r 128.0)
|
|
(sp-flt spt-g 128.0)
|
|
(sp-flt spt-b 255.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-flt spt-fade-a -1.6)
|
|
(sp-int spt-timer 91)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 10)
|
|
(sp-launcher-by-id spt-next-launcher 1364)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1364
|
|
:init-specs
|
|
((sp-flt spt-r 64.0)
|
|
(sp-flt spt-g 64.0)
|
|
(sp-flt spt-fade-r -1.0)
|
|
(sp-flt spt-fade-g -1.0)
|
|
(sp-flt spt-fade-a -2.0)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpartgroup group-kermit-charged-up
|
|
:id 299
|
|
:flags (use-local-clock)
|
|
:bounds (static-bspherem 0 0 0 8)
|
|
:parts
|
|
((sp-item 1365 :period 15 :length 5))
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1365
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #x12 :page #x2))
|
|
(sp-rnd-flt spt-num 1.0 1.0 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 0.1) (meters 0.3) 1.0)
|
|
(sp-rnd-flt spt-rot-z (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-copy-from-other spt-scale-y -4)
|
|
(sp-rnd-flt spt-r 70.0 16.0 1.0)
|
|
(sp-rnd-flt spt-g 70.0 16.0 1.0)
|
|
(sp-flt spt-b 70.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-rnd-flt spt-vel-y (meters 0.04) (meters 0.04) 1.0)
|
|
(sp-rnd-flt spt-rotvel-z (degrees -1.2) (degrees 2.4) 1.0)
|
|
(sp-flt spt-accel-y -10.922667)
|
|
(sp-flt spt-friction 0.99)
|
|
(sp-int spt-timer 75)
|
|
(sp-cpuinfo-flags bit2)
|
|
(sp-flt spt-userdata 0.0)
|
|
(sp-rnd-flt spt-conerot-x (degrees 20.0) (degrees 50.000004) 1.0)
|
|
(sp-rnd-flt spt-conerot-y (degrees 0.0) (degrees 360.0) 1.0)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpartgroup group-kermit-pulse
|
|
:id 300
|
|
:bounds (static-bspherem 0 0 0 8)
|
|
:parts
|
|
((sp-item 1368 :flags (launch-asap) :binding 1366)
|
|
(sp-item 1366 :flags (start-dead launch-asap) :binding 1367)
|
|
(sp-item 1367 :flags (start-dead))
|
|
(sp-item 1367 :flags (start-dead))
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1368
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #xf :page #x2))
|
|
(sp-flt spt-num 1.0)
|
|
(sp-flt spt-scale-x (meters 3))
|
|
(sp-copy-from-other spt-scale-y -4)
|
|
(sp-rnd-flt spt-r 32.0 32.0 1.0)
|
|
(sp-rnd-flt spt-g 96.0 32.0 1.0)
|
|
(sp-rnd-flt spt-b 128.0 64.0 1.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-int spt-timer 3000)
|
|
(sp-cpuinfo-flags bit3)
|
|
(sp-func spt-func 'sparticle-track-root)
|
|
(sp-int spt-next-time 5)
|
|
(sp-launcher-by-id spt-next-launcher 1369)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1369
|
|
:init-specs
|
|
((sp-rnd-flt spt-scale-x (meters 2.5) (meters 1.5) 1.0)
|
|
(sp-copy-from-other spt-scale-y -4)
|
|
(sp-rnd-flt spt-a 100.0 28.0 1.0)
|
|
(sp-int spt-next-time 5)
|
|
(sp-launcher-by-id spt-next-launcher 1369)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1366
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #xf :page #x2))
|
|
(sp-flt spt-num 2.0)
|
|
(sp-rnd-flt spt-y (meters 4) (meters 16) 1.0)
|
|
(sp-flt spt-z (meters 0))
|
|
(sp-flt spt-scale-x (meters 1.5))
|
|
(sp-copy-from-other spt-scale-y -4)
|
|
(sp-rnd-flt spt-r 32.0 32.0 1.0)
|
|
(sp-rnd-flt spt-g 96.0 32.0 1.0)
|
|
(sp-rnd-flt spt-b 128.0 64.0 1.0)
|
|
(sp-flt spt-a 64.0)
|
|
(sp-rnd-flt spt-omega 0.0 65536.0 1.0)
|
|
(sp-flt spt-vel-x (meters 0.053333335))
|
|
(sp-flt spt-vel-y (meters 0.053333335))
|
|
(sp-flt spt-vel-z (meters 0.002))
|
|
(sp-int spt-timer 3000)
|
|
(sp-cpuinfo-flags bit2 bit3 bit7)
|
|
(sp-int spt-next-time 300)
|
|
(sp-launcher-by-id spt-next-launcher 1370)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1370
|
|
:init-specs
|
|
((sp-flt spt-vel-z (meters 0)))
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1367
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #xf :page #x2))
|
|
(sp-flt spt-num 1.0)
|
|
(sp-flt spt-scale-x (meters 0.85))
|
|
(sp-copy-from-other spt-scale-y -4)
|
|
(sp-flt spt-r 32.0)
|
|
(sp-rnd-flt spt-g 96.0 32.0 1.0)
|
|
(sp-rnd-flt spt-b 96.0 64.0 1.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-flt spt-scalevel-x (meters -0.00075757573))
|
|
(sp-copy-from-other spt-scalevel-y -4)
|
|
(sp-flt spt-fade-g -0.16)
|
|
(sp-flt spt-fade-a -0.14222223)
|
|
(sp-int spt-timer 1500)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpartgroup group-kermit-pulse-impact
|
|
:id 301
|
|
:duration 5
|
|
:bounds (static-bspherem 0 0 0 3)
|
|
:parts
|
|
((sp-item 1371) (sp-item 1372))
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1371
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :page #x2))
|
|
(sp-flt spt-num 8.0)
|
|
(sp-rnd-flt spt-x (meters -0.1) (meters 0.2) 1.0)
|
|
(sp-rnd-flt spt-y (meters -0.1) (meters 0.2) 1.0)
|
|
(sp-rnd-flt spt-z (meters -0.1) (meters 0.2) 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 1.2) (meters 0.9) 1.0)
|
|
(sp-rnd-flt spt-rot-z (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-copy-from-other spt-scale-y -4)
|
|
(sp-flt spt-r 64.0)
|
|
(sp-rnd-flt spt-g 192.0 64.0 1.0)
|
|
(sp-rnd-flt spt-b 192.0 64.0 1.0)
|
|
(sp-rnd-flt spt-a 64.0 64.0 1.0)
|
|
(sp-rnd-flt spt-vel-y (meters 0.011666667) (meters 0.00083333335) 1.0)
|
|
(sp-flt spt-scalevel-x (meters 0.01))
|
|
(sp-rnd-flt spt-rotvel-z (degrees -0.2) (degrees 0.4) 1.0)
|
|
(sp-copy-from-other spt-scalevel-y -4)
|
|
(sp-flt spt-fade-g -2.1333334)
|
|
(sp-flt spt-fade-a -0.64)
|
|
(sp-flt spt-friction 0.96)
|
|
(sp-int spt-timer 150)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 30)
|
|
(sp-launcher-by-id spt-next-launcher 1373)
|
|
(sp-rnd-flt spt-launchrot-x (degrees 0.0) (degrees 180.0) 1.0)
|
|
(sp-rnd-flt spt-launchrot-y (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-flt spt-rotate-y (degrees 0.0))
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1373
|
|
:init-specs
|
|
((sp-flt spt-fade-r -3.2)
|
|
(sp-flt spt-fade-g 1.0)
|
|
(sp-flt spt-fade-b 1.0)
|
|
(sp-int spt-next-time 30)
|
|
(sp-launcher-by-id spt-next-launcher 1374)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1374
|
|
:init-specs
|
|
((sp-flt spt-fade-r 0.0) (sp-flt spt-fade-g 0.0) (sp-flt spt-fade-b 0.0))
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defpart 1372
|
|
:init-specs
|
|
((sp-tex spt-texture (new 'static 'texture-id :index #x4 :page #x2))
|
|
(sp-flt spt-num 32.0)
|
|
(sp-rnd-flt spt-x (meters -0.1) (meters 0.2) 1.0)
|
|
(sp-rnd-flt spt-y (meters -0.1) (meters 0.2) 1.0)
|
|
(sp-rnd-flt spt-z (meters -0.1) (meters 0.2) 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 0.1) (meters 0.1) 1.0)
|
|
(sp-rnd-flt spt-rot-z (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-copy-from-other spt-scale-y -4)
|
|
(sp-flt spt-r 64.0)
|
|
(sp-rnd-flt spt-g 192.0 64.0 1.0)
|
|
(sp-rnd-flt spt-b 192.0 64.0 1.0)
|
|
(sp-rnd-flt spt-a 64.0 64.0 1.0)
|
|
(sp-rnd-flt spt-vel-y (meters 0.006666667) (meters 0.06666667) 1.0)
|
|
(sp-rnd-flt spt-rotvel-z (degrees -1.9999999) (degrees 3.9999998) 1.0)
|
|
(sp-flt spt-fade-g -2.1333334)
|
|
(sp-flt spt-fade-a -1.4222223)
|
|
(sp-flt spt-accel-y -2.7306666)
|
|
(sp-flt spt-friction 0.93)
|
|
(sp-int spt-timer 90)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 30)
|
|
(sp-launcher-by-id spt-next-launcher 1373)
|
|
(sp-rnd-flt spt-launchrot-x (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-rnd-flt spt-launchrot-y (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-flt spt-rotate-y (degrees 0.0))
|
|
)
|
|
)
|
|
|
|
;; definition of type joint-mod-tracker
|
|
(deftype joint-mod-tracker (basic)
|
|
((target-pos vector :inline :offset-assert 16)
|
|
(target-pos-func (function vector vector) :offset-assert 32)
|
|
(inv-forward-scale-factor float :offset-assert 36)
|
|
(forward-scale-control float :offset-assert 40)
|
|
(forward-scale-max float :offset-assert 44)
|
|
(process kermit :offset-assert 48)
|
|
(enable symbol :offset-assert 52)
|
|
(up-axis int8 :offset-assert 56)
|
|
(forward-axis int8 :offset-assert 57)
|
|
)
|
|
:method-count-assert 9
|
|
:size-assert #x3a
|
|
:flag-assert #x90000003a
|
|
(:methods
|
|
(new (symbol type kermit int function int int) _type_ 0)
|
|
)
|
|
)
|
|
|
|
;; definition for method 3 of type joint-mod-tracker
|
|
(defmethod inspect joint-mod-tracker ((obj joint-mod-tracker))
|
|
(format #t "[~8x] ~A~%" obj (-> obj type))
|
|
(format #t "~Ttarget-pos: #<vector @ #x~X>~%" (-> obj target-pos))
|
|
(format #t "~Ttarget-pos-func: ~A~%" (-> obj target-pos-func))
|
|
(format #t "~Tinv-forward-scale-factor: ~f~%" (-> obj inv-forward-scale-factor))
|
|
(format #t "~Tforward-scale-control: ~f~%" (-> obj forward-scale-control))
|
|
(format #t "~Tforward-scale-max: ~f~%" (-> obj forward-scale-max))
|
|
(format #t "~Tprocess: ~A~%" (-> obj process))
|
|
(format #t "~Tenable: ~A~%" (-> obj enable))
|
|
(format #t "~Tup-axis: ~D~%" (-> obj up-axis))
|
|
(format #t "~Tforward-axis: ~D~%" (-> obj forward-axis))
|
|
obj
|
|
)
|
|
|
|
;; definition for method 7 of type joint-mod-tracker
|
|
(defmethod relocate joint-mod-tracker ((obj joint-mod-tracker) (arg0 int))
|
|
(&+! (-> obj process) arg0)
|
|
obj
|
|
)
|
|
|
|
;; definition for function build-matrix-from-up-and-forward-axes!
|
|
;; Used lq/sq
|
|
(defun build-matrix-from-up-and-forward-axes! ((arg0 matrix) (arg1 vector) (arg2 int) (arg3 vector) (arg4 int))
|
|
(let ((s1-0 (new 'stack-no-clear 'vector))
|
|
(s5-0 (new 'stack-no-clear 'vector))
|
|
)
|
|
(let ((s3-0 (vector-normalize-copy! (new 'stack-no-clear 'vector) arg3 1.0)))
|
|
(vector-cross! s1-0 arg1 s3-0)
|
|
(vector-normalize! s1-0 1.0)
|
|
(vector-cross! s5-0 s3-0 s1-0)
|
|
(if (!= (mod (+ arg2 1) 3) arg4)
|
|
(vector-negate-in-place! s1-0)
|
|
)
|
|
(set! (-> arg0 vector 0 quad) (-> s1-0 quad))
|
|
(set! (-> arg0 vector 1 quad) (-> s1-0 quad))
|
|
(set! (-> arg0 vector 2 quad) (-> s1-0 quad))
|
|
(set! (-> arg0 vector arg4 quad) (-> s3-0 quad))
|
|
)
|
|
(set! (-> arg0 vector arg2 quad) (-> s5-0 quad))
|
|
)
|
|
(set! (-> arg0 vector 0 w) 0.0)
|
|
(set! (-> arg0 vector 1 w) 0.0)
|
|
(set! (-> arg0 vector 2 w) 0.0)
|
|
(set! (-> arg0 vector 3 quad) (-> *null-vector* quad))
|
|
arg0
|
|
)
|
|
|
|
;; definition for function joint-mod-tracker-callback
|
|
;; Used lq/sq
|
|
(defun joint-mod-tracker-callback ((arg0 cspace) (arg1 transformq))
|
|
(let ((s4-0 (the-as joint-mod-tracker (-> arg0 param1))))
|
|
(cond
|
|
((-> s4-0 enable)
|
|
(let ((t9-0 (-> s4-0 target-pos-func)))
|
|
(if t9-0
|
|
(t9-0 (-> s4-0 target-pos))
|
|
)
|
|
)
|
|
(let ((s3-0 (-> s4-0 target-pos))
|
|
(s5-1 (vector-matrix*! (new 'stack-no-clear 'vector) (-> arg1 trans) (-> arg0 parent bone transform)))
|
|
)
|
|
(let* ((s2-1 (vector-! (new 'stack-no-clear 'vector) s3-0 s5-1))
|
|
(f30-0 (vector-length s2-1))
|
|
)
|
|
(build-matrix-from-up-and-forward-axes!
|
|
(-> arg0 bone transform)
|
|
*y-vector*
|
|
(-> s4-0 up-axis)
|
|
s2-1
|
|
(-> s4-0 forward-axis)
|
|
)
|
|
(let ((f0-3 (fmin
|
|
(* f30-0 (-> s4-0 inv-forward-scale-factor) (-> s4-0 forward-scale-control))
|
|
(-> s4-0 forward-scale-max)
|
|
)
|
|
)
|
|
(v1-10 (-> arg0 bone transform vector (-> s4-0 forward-axis)))
|
|
)
|
|
(vector-float*! v1-10 v1-10 f0-3)
|
|
(set! (-> v1-10 w) 0.0)
|
|
)
|
|
)
|
|
(set! (-> arg0 bone transform vector 3 quad) (-> s5-1 quad))
|
|
)
|
|
(set-vector! (-> arg0 bone scale) 1.0 1.0 1.0 1.0)
|
|
)
|
|
(else
|
|
(set! (-> arg1 scale data (-> s4-0 forward-axis)) (-> s4-0 forward-scale-control))
|
|
(cspace<-parented-transformq-joint! arg0 arg1)
|
|
)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
|
|
;; definition for method 0 of type joint-mod-tracker
|
|
(defmethod new joint-mod-tracker ((allocation symbol) (type-to-make type) (arg0 kermit) (arg1 int) (arg2 function) (arg3 int) (arg4 int))
|
|
(let ((v0-0 (object-new allocation type-to-make (the-as int (-> type-to-make size)))))
|
|
(set! (-> v0-0 process) arg0)
|
|
(set! (-> v0-0 target-pos-func) (the-as (function vector vector) arg2))
|
|
(set! (-> v0-0 up-axis) arg3)
|
|
(set! (-> v0-0 forward-axis) arg4)
|
|
(set! (-> v0-0 inv-forward-scale-factor) 0.0)
|
|
(set! (-> v0-0 forward-scale-control) 1.0)
|
|
(set! (-> v0-0 forward-scale-max) 1.0)
|
|
(set! (-> v0-0 enable) #t)
|
|
(let ((v1-5 (-> arg0 node-list data arg1)))
|
|
(set! (-> v1-5 param0) joint-mod-tracker-callback)
|
|
(set! (-> v1-5 param1) v0-0)
|
|
)
|
|
v0-0
|
|
)
|
|
)
|
|
|
|
;; definition of type kermit-pulse
|
|
(deftype kermit-pulse (process-drawable)
|
|
((parent-override (pointer kermit) :offset 12)
|
|
(self-override kermit-pulse :offset 28)
|
|
(root-override collide-shape-moving :offset 112)
|
|
(sound-id sound-id :offset-assert 176)
|
|
)
|
|
:heap-base #x50
|
|
:method-count-assert 20
|
|
:size-assert #xb4
|
|
:flag-assert #x14005000b4
|
|
(:states
|
|
kermit-pulse-idle
|
|
kermit-pulse-impact
|
|
)
|
|
)
|
|
|
|
;; definition for method 3 of type kermit-pulse
|
|
(defmethod inspect kermit-pulse ((obj kermit-pulse))
|
|
(let ((t9-0 (method-of-type process-drawable inspect)))
|
|
(t9-0 obj)
|
|
)
|
|
(format #t "~T~Tsound-id: ~D~%" (-> obj sound-id))
|
|
obj
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-pulse-idle (kermit-pulse)
|
|
:event
|
|
(behavior ((arg0 process) (arg1 int) (arg2 symbol) (arg3 event-message-block))
|
|
(case arg2
|
|
(('touch 'attack)
|
|
(send-event arg0 'attack (-> arg3 param 0) (new 'static 'attack-info))
|
|
(go kermit-pulse-impact)
|
|
)
|
|
)
|
|
)
|
|
:enter
|
|
(behavior ()
|
|
(set! (-> self state-time) (-> *display* base-frame-counter))
|
|
(none)
|
|
)
|
|
:exit
|
|
(behavior ()
|
|
(sound-stop (-> self sound-id))
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(while (< (- (-> *display* base-frame-counter) (-> self state-time)) (seconds 4))
|
|
(sound-play-by-name
|
|
(static-sound-name "kermit-loop")
|
|
(-> self sound-id)
|
|
1024
|
|
0
|
|
0
|
|
1
|
|
(the-as symbol (-> self root-override trans))
|
|
)
|
|
(spawn (-> self part) (-> self root-override trans))
|
|
(find-ground-and-draw-shadow
|
|
(-> self root-override trans)
|
|
(the-as vector #f)
|
|
8192.0
|
|
(collide-kind background)
|
|
(the-as process-drawable #f)
|
|
0.0
|
|
81920.0
|
|
)
|
|
(suspend)
|
|
)
|
|
(cleanup-for-death self)
|
|
(none)
|
|
)
|
|
:post
|
|
(behavior ()
|
|
(update-transforms! (-> self root-override))
|
|
(none)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-pulse-impact (kermit-pulse)
|
|
:code
|
|
(behavior ()
|
|
(sound-play-by-name (static-sound-name "get-shocked") (new-sound-id) 1024 0 0 1 #t)
|
|
(let ((gp-1 (get-process *default-dead-pool* part-tracker #x4000)))
|
|
(when gp-1
|
|
(let ((t9-3 (method-of-type part-tracker activate)))
|
|
(t9-3 (the-as part-tracker gp-1) *entity-pool* 'part-tracker (the-as pointer #x70004000))
|
|
)
|
|
(run-now-in-process
|
|
gp-1
|
|
part-tracker-init
|
|
(-> *part-group-id-table* 301)
|
|
-1
|
|
#f
|
|
#f
|
|
#f
|
|
(-> self root-override trans)
|
|
)
|
|
(-> gp-1 ppointer)
|
|
)
|
|
)
|
|
(cleanup-for-death self)
|
|
(none)
|
|
)
|
|
)
|
|
|
|
;; definition for function kermit-pulse-init-by-other
|
|
;; INFO: Return type mismatch object vs none.
|
|
;; Used lq/sq
|
|
(defbehavior kermit-pulse-init-by-other kermit-pulse ((arg0 vector) (arg1 entity))
|
|
(logclear! (-> self mask) (process-mask enemy attackable))
|
|
(set! (-> self mask) (logior (process-mask projectile) (-> self mask)))
|
|
(set! (-> self entity) arg1)
|
|
(let ((s5-0 (new 'process 'collide-shape-moving self (collide-list-enum hit-by-player))))
|
|
(set! (-> s5-0 dynam) (copy *standard-dynamics* 'process))
|
|
(set! (-> s5-0 reaction) default-collision-reaction)
|
|
(set! (-> s5-0 no-reaction)
|
|
(the-as (function collide-shape-moving collide-shape-intersect vector vector none) nothing)
|
|
)
|
|
(let ((s4-0 (new 'process 'collide-shape-prim-sphere s5-0 (the-as uint 0))))
|
|
(set! (-> s4-0 prim-core collide-as) (collide-kind enemy))
|
|
(set! (-> s4-0 collide-with) (collide-kind target))
|
|
(set! (-> s4-0 prim-core action) (collide-action solid))
|
|
(set! (-> s4-0 prim-core offense) (collide-offense indestructible))
|
|
(set-vector! (-> s4-0 local-sphere) 0.0 0.0 0.0 2867.2)
|
|
(set-root-prim! s5-0 s4-0)
|
|
)
|
|
(set! (-> s5-0 nav-radius) (* 0.75 (-> s5-0 root-prim local-sphere w)))
|
|
(backup-collide-with-as s5-0)
|
|
(set! (-> self root-override) s5-0)
|
|
)
|
|
(set! (-> self root-override trans quad) (-> arg0 quad))
|
|
(set! (-> self root-override quat vec quad) (-> self parent-override 0 collide-info quat vec quad))
|
|
(vector-identity! (-> self root-override scale))
|
|
(vector-reset! (-> self root-override transv))
|
|
(set! (-> self sound-id) (new-sound-id))
|
|
(set! (-> self part) (create-launch-control (-> *part-group-id-table* 300) self))
|
|
(go kermit-pulse-idle)
|
|
(none)
|
|
)
|
|
|
|
;; definition for function spawn-kermit-pulse
|
|
;; INFO: Return type mismatch int vs none.
|
|
(defun spawn-kermit-pulse ((arg0 kermit) (arg1 vector) (arg2 entity))
|
|
(let ((s3-0 (get-process *default-dead-pool* kermit-pulse #x4000)))
|
|
(when s3-0
|
|
(let ((t9-1 (method-of-type kermit-pulse activate)))
|
|
(t9-1 (the-as kermit-pulse s3-0) arg0 'kermit-pulse (the-as pointer #x70004000))
|
|
)
|
|
(run-now-in-process s3-0 kermit-pulse-init-by-other arg1 arg2)
|
|
(-> s3-0 ppointer)
|
|
)
|
|
)
|
|
0
|
|
(none)
|
|
)
|
|
|
|
;; definition of type kermit
|
|
(deftype kermit (nav-enemy)
|
|
((child-override (pointer kermit-pulse) :offset 20)
|
|
(rotate-dir vector :inline :offset-assert 400)
|
|
(charging-part sparticle-launch-control :offset-assert 416)
|
|
(airborne symbol :offset-assert 420)
|
|
(tongue-control joint-mod-tracker :offset-assert 424)
|
|
(tongue-pulse-pos float :offset-assert 428)
|
|
(miss-count int8 :offset-assert 432)
|
|
(charged-up symbol :offset-assert 436)
|
|
(sound-id sound-id :offset-assert 440)
|
|
)
|
|
:heap-base #x150
|
|
:method-count-assert 76
|
|
:size-assert #x1bc
|
|
:flag-assert #x4c015001bc
|
|
(:states
|
|
kermit-attack
|
|
kermit-chase
|
|
kermit-chase-new-position
|
|
kermit-give-up
|
|
kermit-idle
|
|
kermit-notice
|
|
kermit-patrol
|
|
kermit-retract-tongue
|
|
kermit-tongue-stuck
|
|
)
|
|
)
|
|
|
|
;; definition for method 3 of type kermit
|
|
(defmethod inspect kermit ((obj kermit))
|
|
(let ((t9-0 (method-of-type nav-enemy inspect)))
|
|
(t9-0 obj)
|
|
)
|
|
(format #t "~T~Trotate-dir: #<vector @ #x~X>~%" (-> obj rotate-dir))
|
|
(format #t "~T~Tcharging-part: ~A~%" (-> obj charging-part))
|
|
(format #t "~T~Tairborne: ~A~%" (-> obj airborne))
|
|
(format #t "~T~Ttongue-control: ~A~%" (-> obj tongue-control))
|
|
(format #t "~T~Ttongue-pulse-pos: ~f~%" (-> obj tongue-pulse-pos))
|
|
(format #t "~T~Tmiss-count: ~D~%" (-> obj miss-count))
|
|
(format #t "~T~Tcharged-up: ~A~%" (-> obj charged-up))
|
|
(format #t "~T~Tsound-id: ~D~%" (-> obj sound-id))
|
|
obj
|
|
)
|
|
|
|
;; definition for method 7 of type kermit
|
|
;; INFO: Return type mismatch nav-enemy vs kermit.
|
|
(defmethod relocate kermit ((obj kermit) (arg0 int))
|
|
(if (nonzero? (-> obj tongue-control))
|
|
(&+! (-> obj tongue-control) arg0)
|
|
)
|
|
(if (nonzero? (-> obj charging-part))
|
|
(&+! (-> obj charging-part) arg0)
|
|
)
|
|
(the-as kermit ((method-of-type nav-enemy relocate) obj arg0))
|
|
)
|
|
|
|
;; definition for method 10 of type kermit
|
|
(defmethod deactivate kermit ((obj kermit))
|
|
(if (nonzero? (-> obj charging-part))
|
|
(kill-and-free-particles (-> obj charging-part))
|
|
)
|
|
((method-of-type nav-enemy deactivate) obj)
|
|
(none)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defskelgroup *kermit-sg* kermit
|
|
0
|
|
4
|
|
((1 (meters 20)) (2 (meters 40)) (3 (meters 999999)))
|
|
:bounds (static-spherem 0 -1 0 3)
|
|
:longest-edge (meters 2)
|
|
)
|
|
|
|
;; definition for function kermit-enable-tongue
|
|
;; INFO: Return type mismatch int vs none.
|
|
(defbehavior kermit-enable-tongue kermit ()
|
|
(set! (-> self tongue-control enable) #t)
|
|
(set! (-> self draw bounds w) 81920.0)
|
|
0
|
|
(none)
|
|
)
|
|
|
|
;; definition for function kermit-disable-tongue
|
|
;; INFO: Return type mismatch int vs none.
|
|
(defbehavior kermit-disable-tongue kermit ()
|
|
(set! (-> self tongue-control enable) #f)
|
|
(set! (-> self draw bounds w) 12288.0)
|
|
0
|
|
(none)
|
|
)
|
|
|
|
;; definition for function kermit-tongue-pos
|
|
(defun kermit-tongue-pos ((arg0 kermit))
|
|
(-> arg0 node-list data 24 bone transform vector 3)
|
|
)
|
|
|
|
;; definition for function kermit-get-head-dir-xz
|
|
;; Used lq/sq
|
|
(defun kermit-get-head-dir-xz ((arg0 kermit) (arg1 vector))
|
|
(set! (-> arg1 quad) (-> arg0 node-list data 8 bone transform vector 2 quad))
|
|
(set! (-> arg1 y) 0.0)
|
|
(vector-xz-normalize! arg1 1.0)
|
|
)
|
|
|
|
;; definition for function kermit-get-head-dir
|
|
;; Used lq/sq
|
|
(defun kermit-get-head-dir ((arg0 kermit) (arg1 vector))
|
|
(set! (-> arg1 quad) (-> arg0 node-list data 8 bone transform vector 2 quad))
|
|
(vector-normalize! arg1 1.0)
|
|
)
|
|
|
|
;; definition for function kermit-player-target-pos
|
|
(defun kermit-player-target-pos ()
|
|
(target-pos 26)
|
|
)
|
|
|
|
;; definition for function kermit-get-tongue-target-callback
|
|
;; Used lq/sq
|
|
(defun kermit-get-tongue-target-callback ((arg0 vector))
|
|
(set! (-> arg0 quad) (-> (kermit-player-target-pos) quad))
|
|
arg0
|
|
)
|
|
|
|
;; definition for function kermit-check-tongue-is-clear?
|
|
(defbehavior kermit-check-tongue-is-clear? kermit ()
|
|
(let* ((gp-0 (kermit-tongue-pos self))
|
|
(v1-1 (-> self tongue-control target-pos))
|
|
(s5-1 (vector-! (new 'stack-no-clear 'vector) v1-1 gp-0))
|
|
(t2-0 (new 'stack 'collide-tri-result))
|
|
(f30-0
|
|
(fill-and-probe-using-line-sphere
|
|
*collide-cache*
|
|
gp-0
|
|
s5-1
|
|
409.6
|
|
(collide-kind background cak-2 crate enemy wall-object projectile ground-object)
|
|
self
|
|
t2-0
|
|
1
|
|
)
|
|
)
|
|
(gp-1 (< f30-0 0.0))
|
|
)
|
|
(set! (-> self tongue-control forward-scale-max)
|
|
(if gp-1
|
|
2.0
|
|
(* (vector-length s5-1) f30-0 (-> self tongue-control inv-forward-scale-factor))
|
|
)
|
|
)
|
|
gp-1
|
|
)
|
|
)
|
|
|
|
;; definition for function kermit-check-to-hit-player?
|
|
(defbehavior kermit-check-to-hit-player? kermit ((arg0 float))
|
|
(let* ((s5-0 (kermit-tongue-pos self))
|
|
(v1-0 (kermit-player-target-pos))
|
|
(s4-1 (vector-! (new 'stack-no-clear 'vector) v1-0 s5-0))
|
|
(f30-0 (vector-length s4-1))
|
|
(s5-1 (new 'stack-no-clear 'vector))
|
|
(f0-0 f30-0)
|
|
(s5-2 (vector-float*! s5-1 s4-1 (/ 1.0 f0-0)))
|
|
(v0-5 (>= (vector-dot (kermit-get-head-dir-xz self (new 'stack-no-clear 'vector)) s5-2) (cos arg0)))
|
|
)
|
|
(and (< f30-0 49152.0) v0-5)
|
|
)
|
|
)
|
|
|
|
;; definition for function kermit-set-nav-mesh-target
|
|
;; Used lq/sq
|
|
(defbehavior kermit-set-nav-mesh-target kermit ((arg0 vector))
|
|
(let* ((gp-0 (target-pos 0))
|
|
(s5-1 (vector-! (new 'stack-no-clear 'vector) arg0 gp-0))
|
|
)
|
|
(vector-length s5-1)
|
|
(let* ((a0-4 (vector-normalize-copy! (new 'stack-no-clear 'vector) s5-1 40960.0))
|
|
(v1-2 (vector+! (new 'stack-no-clear 'vector) gp-0 a0-4))
|
|
(v0-3 (-> self nav target-pos))
|
|
)
|
|
(set! (-> v0-3 quad) (-> v1-2 quad))
|
|
v0-3
|
|
)
|
|
)
|
|
)
|
|
|
|
;; definition for function kermit-short-hop
|
|
(defbehavior kermit-short-hop kermit ()
|
|
(let ((a0-0 (-> self skel root-channel 0)))
|
|
(set! (-> a0-0 frame-group) (the-as art-joint-anim (-> self draw art-group data 5)))
|
|
(set! (-> a0-0 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 5)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-0 param 1) 1.0)
|
|
(set! (-> a0-0 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-0 (the-as art-joint-anim (-> self draw art-group data 5)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(let ((f0-4 (ja-aframe-num 0)))
|
|
(if (>= f0-4 4.0)
|
|
(set! (-> self airborne) #t)
|
|
)
|
|
(if (>= f0-4 14.0)
|
|
(set! (-> self airborne) #f)
|
|
)
|
|
)
|
|
(suspend)
|
|
(let ((a0-2 (-> self skel root-channel 0)))
|
|
(set! (-> a0-2 param 0) (the float (+ (-> a0-2 frame-group data 0 length) -1)))
|
|
(set! (-> a0-2 param 1) 1.0)
|
|
(joint-control-channel-group-eval! a0-2 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
#f
|
|
)
|
|
|
|
;; definition for function kermit-long-hop
|
|
(defbehavior kermit-long-hop kermit ()
|
|
(let ((a0-0 (-> self skel root-channel 0)))
|
|
(set! (-> a0-0 frame-group) (the-as art-joint-anim (-> self draw art-group data 6)))
|
|
(set! (-> a0-0 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 6)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-0 param 1) 1.0)
|
|
(set! (-> a0-0 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-0 (the-as art-joint-anim (-> self draw art-group data 6)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(let ((f0-4 (ja-aframe-num 0)))
|
|
(if (>= f0-4 7.0)
|
|
(set! (-> self airborne) #t)
|
|
)
|
|
(if (>= f0-4 29.0)
|
|
(set! (-> self airborne) #f)
|
|
)
|
|
)
|
|
(suspend)
|
|
(let ((a0-2 (-> self skel root-channel 0)))
|
|
(set! (-> a0-2 param 0) (the float (+ (-> a0-2 frame-group data 0 length) -1)))
|
|
(set! (-> a0-2 param 1) 1.0)
|
|
(joint-control-channel-group-eval! a0-2 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
#f
|
|
)
|
|
|
|
;; definition for function kermit-hop
|
|
(defbehavior kermit-hop kermit ((arg0 float))
|
|
(ja-channel-push! 1 30)
|
|
(set! (-> self rotate-speed) 1820444.5)
|
|
(let ((f0-2 (fmin arg0 (vector-vector-distance (-> self collide-info trans) (-> self nav target-pos)))))
|
|
(cond
|
|
((< 16384.0 f0-2)
|
|
(set! (-> self target-speed) (* 0.045454547 (-> *display* frames-per-second) f0-2))
|
|
(kermit-long-hop)
|
|
)
|
|
(else
|
|
(set! (-> self target-speed) (* 0.1 (-> *display* frames-per-second) f0-2))
|
|
(kermit-short-hop)
|
|
)
|
|
)
|
|
)
|
|
(set! (-> self airborne) #f)
|
|
#f
|
|
)
|
|
|
|
;; definition for function kermit-set-rotate-dir-to-nav-target
|
|
;; Used lq/sq
|
|
(defbehavior kermit-set-rotate-dir-to-nav-target kermit ()
|
|
(cond
|
|
((logtest? (nav-control-flags navcf19) (-> self nav flags))
|
|
(vector-! (-> self rotate-dir) (-> self nav target-pos) (-> self collide-info trans))
|
|
)
|
|
(else
|
|
(let ((v0-1 (-> self rotate-dir)))
|
|
(set! (-> v0-1 quad) (-> self nav travel quad))
|
|
v0-1
|
|
)
|
|
)
|
|
)
|
|
)
|
|
|
|
;; definition for function kermit-set-rotate-dir-to-player
|
|
(defbehavior kermit-set-rotate-dir-to-player kermit ()
|
|
(vector-! (-> self rotate-dir) (target-pos 0) (-> self nav target-pos))
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
nav-enemy-default-event-handler
|
|
|
|
;; definition for method 39 of type kermit
|
|
;; INFO: Return type mismatch int vs none.
|
|
(defmethod common-post kermit ((obj kermit))
|
|
((the-as (function nav-enemy none) (find-parent-method kermit 39)) obj)
|
|
(when (-> obj charged-up)
|
|
)
|
|
0
|
|
(none)
|
|
)
|
|
|
|
;; definition for function kermit-simple-post
|
|
(defbehavior kermit-simple-post kermit ()
|
|
(nav-enemy-simple-post)
|
|
(none)
|
|
)
|
|
|
|
;; definition for function kermit-post
|
|
;; Used lq/sq
|
|
(defbehavior kermit-post kermit ()
|
|
(cond
|
|
((-> self airborne)
|
|
(dummy-11 (-> self nav) (-> self nav target-pos))
|
|
(set! (-> self collide-info transv x) (-> self nav travel x))
|
|
(set! (-> self collide-info transv y) 0.0)
|
|
(set! (-> self collide-info transv z) (-> self nav travel z))
|
|
(let ((f0-5
|
|
(fmin
|
|
(-> self target-speed)
|
|
(* (vector-xz-length (-> self collide-info transv)) (-> *display* frames-per-second))
|
|
)
|
|
)
|
|
)
|
|
(vector-xz-normalize! (-> self collide-info transv) f0-5)
|
|
)
|
|
(seek-toward-heading-vec! (-> self collide-info) (-> self rotate-dir) (-> self rotate-speed) (seconds 0.05))
|
|
(vector-v++!
|
|
(-> self collide-info transv)
|
|
(compute-acc-due-to-gravity (-> self collide-info) (new-stack-vector0) 0.0)
|
|
)
|
|
(integrate-for-enemy-with-move-to-ground!
|
|
(-> self collide-info)
|
|
(-> self collide-info transv)
|
|
(collide-kind background)
|
|
8192.0
|
|
#t
|
|
#f
|
|
#f
|
|
)
|
|
(nav-enemy-common-post)
|
|
)
|
|
(else
|
|
(set! (-> self collide-info transv quad) (-> *null-vector* quad))
|
|
(kermit-simple-post)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
|
|
;; definition for function kermit-get-new-patrol-point
|
|
;; Used lq/sq
|
|
(defbehavior kermit-get-new-patrol-point kermit ()
|
|
(nav-enemy-get-new-patrol-point)
|
|
(let ((v0-1 (-> self nav target-pos)))
|
|
(set! (-> v0-1 quad) (-> self nav destination-pos quad))
|
|
v0-1
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-idle (kermit)
|
|
:event
|
|
(the-as
|
|
(function process int symbol event-message-block object :behavior kermit)
|
|
nav-enemy-default-event-handler
|
|
)
|
|
:enter
|
|
(behavior ()
|
|
(set! (-> self notice-time) 0)
|
|
0
|
|
(none)
|
|
)
|
|
:trans
|
|
(behavior ()
|
|
(if (and *target* (>= (-> self enemy-info idle-distance)
|
|
(vector-vector-distance (-> self collide-info trans) (-> *target* control trans))
|
|
)
|
|
)
|
|
(go kermit-patrol)
|
|
)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(kermit-disable-tongue)
|
|
(let ((gp-0 (-> self skel root-channel 0)))
|
|
(joint-control-channel-group-eval!
|
|
gp-0
|
|
(the-as art-joint-anim (-> self draw art-group data 4))
|
|
num-func-identity
|
|
)
|
|
(set! (-> gp-0 frame-num) 0.0)
|
|
)
|
|
(while #t
|
|
(let ((a0-1 (-> self skel root-channel 0)))
|
|
(set! (-> a0-1 param 0) 1.0)
|
|
(joint-control-channel-group-eval! a0-1 (the-as art-joint-anim #f) num-func-loop!)
|
|
)
|
|
(suspend)
|
|
)
|
|
(none)
|
|
)
|
|
:post
|
|
(the-as (function none :behavior kermit) ja-post)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-patrol (kermit)
|
|
:event
|
|
(the-as
|
|
(function process int symbol event-message-block object :behavior kermit)
|
|
nav-enemy-default-event-handler
|
|
)
|
|
:enter
|
|
(behavior ()
|
|
(set! (-> self state-time) (-> *display* base-frame-counter))
|
|
(set-mode! (-> self neck) (joint-mod-handler-mode flex-blend))
|
|
(kermit-get-new-patrol-point)
|
|
(dummy-11 (-> self nav) (-> self nav target-pos))
|
|
(none)
|
|
)
|
|
:trans
|
|
(behavior ()
|
|
(if (and (or (not *target*) (< (-> self enemy-info idle-distance)
|
|
(vector-vector-distance (-> self collide-info trans) (-> *target* control trans))
|
|
)
|
|
)
|
|
(>= (- (-> *display* base-frame-counter) (-> self state-time)) (seconds 1))
|
|
)
|
|
(go kermit-idle)
|
|
)
|
|
(kermit-set-rotate-dir-to-nav-target)
|
|
(if (and (not (-> self airborne)) (nav-enemy-test-point-in-nav-mesh? (target-pos 0)))
|
|
(go kermit-notice)
|
|
)
|
|
(if (logtest? (nav-control-flags navcf19) (-> self nav flags))
|
|
(kermit-get-new-patrol-point)
|
|
)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(while #t
|
|
(let ((a0-0 (-> self skel root-channel 0)))
|
|
(set! (-> a0-0 frame-group) (the-as art-joint-anim (-> self draw art-group data 4)))
|
|
(set! (-> a0-0 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 4)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-0 param 1) 3.0)
|
|
(set! (-> a0-0 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-0 (the-as art-joint-anim (-> self draw art-group data 4)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(suspend)
|
|
(let ((a0-1 (-> self skel root-channel 0)))
|
|
(set! (-> a0-1 param 0) (the float (+ (-> a0-1 frame-group data 0 length) -1)))
|
|
(set! (-> a0-1 param 1) 3.0)
|
|
(joint-control-channel-group-eval! a0-1 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
(kermit-hop 20480.0)
|
|
)
|
|
(none)
|
|
)
|
|
:post
|
|
kermit-post
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-notice (kermit)
|
|
:event
|
|
(the-as
|
|
(function process int symbol event-message-block object :behavior kermit)
|
|
nav-enemy-default-event-handler
|
|
)
|
|
:enter
|
|
(behavior ()
|
|
(set-mode! (-> self neck) (joint-mod-handler-mode look-at))
|
|
(none)
|
|
)
|
|
:trans
|
|
(behavior ()
|
|
(kermit-set-rotate-dir-to-player)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(ja-channel-push! 1 30)
|
|
(set-mode! (-> self neck) (joint-mod-handler-mode look-at))
|
|
(kermit-hop 0.0)
|
|
(go kermit-chase)
|
|
(none)
|
|
)
|
|
:post
|
|
kermit-post
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-give-up (kermit)
|
|
:event
|
|
(the-as
|
|
(function process int symbol event-message-block object :behavior kermit)
|
|
nav-enemy-default-event-handler
|
|
)
|
|
:enter
|
|
(behavior ()
|
|
(set-mode! (-> self neck) (joint-mod-handler-mode flex-blend))
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(go kermit-patrol)
|
|
(none)
|
|
)
|
|
:post
|
|
kermit-simple-post
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-chase-new-position (kermit)
|
|
:event
|
|
(the-as
|
|
(function process int symbol event-message-block object :behavior kermit)
|
|
nav-enemy-default-event-handler
|
|
)
|
|
:enter
|
|
(behavior ()
|
|
(set! (-> self state-time) (-> *display* base-frame-counter))
|
|
(set! (-> self miss-count) 0)
|
|
(let* ((a1-1 (kermit-get-head-dir-xz self (new 'stack-no-clear 'vector)))
|
|
(gp-0 (vector-rotate-around-y! (new 'stack-no-clear 'vector) a1-1 16384.0))
|
|
(s5-0 (new 'stack-no-clear 'vector))
|
|
(v1-2 #f)
|
|
)
|
|
(let ((s4-0 0))
|
|
(while (and (not v1-2) (< s4-0 4))
|
|
(let ((f0-0 (rand-vu-float-range -40960.0 40960.0)))
|
|
(vector+*! s5-0 (-> self collide-info trans) gp-0 f0-0)
|
|
)
|
|
(kermit-set-nav-mesh-target s5-0)
|
|
(set! v1-2 (nav-enemy-test-point-in-nav-mesh? (-> self nav target-pos)))
|
|
(+! s4-0 1)
|
|
)
|
|
)
|
|
(if (not v1-2)
|
|
(kermit-set-nav-mesh-target (-> self collide-info trans))
|
|
)
|
|
)
|
|
(dummy-11 (-> self nav) (-> self nav target-pos))
|
|
(none)
|
|
)
|
|
:trans
|
|
(behavior ()
|
|
(when (not (-> self airborne))
|
|
(if (or (>= (- (-> *display* base-frame-counter) (-> self state-time)) (seconds 3))
|
|
(and (logtest? (nav-control-flags navcf19) (-> self nav flags))
|
|
(>= (- (-> *display* base-frame-counter) (-> self state-time)) (seconds 0.5))
|
|
)
|
|
)
|
|
(go kermit-chase)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(ja-channel-push! 1 51)
|
|
(dotimes (gp-0 3)
|
|
(let ((a0-1 (-> self skel root-channel 0)))
|
|
(set! (-> a0-1 frame-group) (the-as art-joint-anim (-> self draw art-group data 4)))
|
|
(set! (-> a0-1 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 4)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-1 param 1) 4.0)
|
|
(set! (-> a0-1 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-1 (the-as art-joint-anim (-> self draw art-group data 4)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(suspend)
|
|
(let ((a0-2 (-> self skel root-channel 0)))
|
|
(set! (-> a0-2 param 0) (the float (+ (-> a0-2 frame-group data 0 length) -1)))
|
|
(set! (-> a0-2 param 1) 4.0)
|
|
(joint-control-channel-group-eval! a0-2 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
)
|
|
(while #t
|
|
(kermit-hop 81920.0)
|
|
(nop!)
|
|
)
|
|
(none)
|
|
)
|
|
:post
|
|
kermit-post
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-chase (kermit)
|
|
:event
|
|
(the-as
|
|
(function process int symbol event-message-block object :behavior kermit)
|
|
nav-enemy-default-event-handler
|
|
)
|
|
:enter
|
|
(behavior ()
|
|
(set! (-> self state-time) (-> *display* base-frame-counter))
|
|
(set-mode! (-> self neck) (joint-mod-handler-mode look-at))
|
|
(kermit-set-nav-mesh-target (-> self collide-info trans))
|
|
(dummy-11 (-> self nav) (-> self nav target-pos))
|
|
(none)
|
|
)
|
|
:trans
|
|
(behavior ()
|
|
(kermit-set-nav-mesh-target (-> self collide-info trans))
|
|
(kermit-set-rotate-dir-to-player)
|
|
(if (nav-enemy-test-point-in-nav-mesh? (target-pos 0))
|
|
(set! (-> self state-time) (-> *display* base-frame-counter))
|
|
)
|
|
(kermit-tongue-pos self)
|
|
(let ((v1-5 (kermit-player-target-pos)))
|
|
(set! (-> self tongue-control target-pos quad) (-> v1-5 quad))
|
|
)
|
|
(when (not (-> self airborne))
|
|
(if (or (not *target*) (< (-> self enemy-info idle-distance)
|
|
(vector-vector-distance (-> self collide-info trans) (-> *target* control trans))
|
|
)
|
|
)
|
|
(go kermit-patrol)
|
|
)
|
|
(let ((gp-1 (kermit-check-to-hit-player? 3640.889))
|
|
(v1-17 (kermit-check-tongue-is-clear?))
|
|
)
|
|
(when gp-1
|
|
(if v1-17
|
|
(go kermit-attack)
|
|
(go kermit-chase-new-position)
|
|
)
|
|
)
|
|
)
|
|
(if (>= (- (-> *display* base-frame-counter) (-> self state-time)) (seconds 3))
|
|
(go kermit-give-up)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(ja-channel-push! 1 51)
|
|
(while #t
|
|
(let ((a0-1 (-> self skel root-channel 0)))
|
|
(set! (-> a0-1 frame-group) (the-as art-joint-anim (-> self draw art-group data 4)))
|
|
(set! (-> a0-1 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 4)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-1 param 1) 3.0)
|
|
(set! (-> a0-1 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-1 (the-as art-joint-anim (-> self draw art-group data 4)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(suspend)
|
|
(let ((a0-2 (-> self skel root-channel 0)))
|
|
(set! (-> a0-2 param 0) (the float (+ (-> a0-2 frame-group data 0 length) -1)))
|
|
(set! (-> a0-2 param 1) 3.0)
|
|
(joint-control-channel-group-eval! a0-2 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
(if (not (kermit-check-to-hit-player? 3640.889))
|
|
(kermit-hop 81920.0)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:post
|
|
kermit-post
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-attack (kermit)
|
|
:event
|
|
(the-as
|
|
(function process int symbol event-message-block object :behavior kermit)
|
|
nav-enemy-default-event-handler
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(ja-channel-push! 1 51)
|
|
(set! (-> self tongue-control forward-scale-control) 0.0)
|
|
(kermit-enable-tongue)
|
|
(let ((s5-0 #f)
|
|
(gp-0 #f)
|
|
)
|
|
(let ((f30-0 1.0))
|
|
(let ((a0-1 (-> self skel root-channel 0)))
|
|
(set! (-> a0-1 frame-group) (the-as art-joint-anim (-> self draw art-group data 7)))
|
|
(set! (-> a0-1 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 7)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-1 param 1) 1.0)
|
|
(set! (-> a0-1 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-1 (the-as art-joint-anim (-> self draw art-group data 7)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(set! (-> self tongue-control target-pos quad) (-> (kermit-player-target-pos) quad))
|
|
(when (and (not s5-0) (>= (ja-aframe-num 0) 14.0))
|
|
(set! s5-0 #t)
|
|
(set! gp-0 (kermit-check-to-hit-player? 3640.889))
|
|
(if (not gp-0)
|
|
(set! f30-0 0.8)
|
|
)
|
|
)
|
|
(when s5-0
|
|
(if (and (not gp-0) (= (-> self tongue-control forward-scale-control) f30-0))
|
|
(go kermit-retract-tongue)
|
|
)
|
|
(seek! (-> self tongue-control forward-scale-control) f30-0 0.25)
|
|
)
|
|
(suspend)
|
|
(let ((a0-5 (-> self skel root-channel 0)))
|
|
(set! (-> a0-5 param 0) (the float (+ (-> a0-5 frame-group data 0 length) -1)))
|
|
(set! (-> a0-5 param 1) 1.0)
|
|
(joint-control-channel-group-eval! a0-5 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
)
|
|
(cond
|
|
(gp-0
|
|
(level-hint-spawn
|
|
(game-text-id kermit-break-tongue)
|
|
"sksp0143"
|
|
(the-as entity #f)
|
|
*entity-pool*
|
|
(game-task none)
|
|
)
|
|
(level-hint-spawn
|
|
(game-text-id kermit-run-away-jak)
|
|
"sksp0151"
|
|
(the-as entity #f)
|
|
*entity-pool*
|
|
(game-task none)
|
|
)
|
|
(go kermit-tongue-stuck)
|
|
)
|
|
(else
|
|
(go kermit-retract-tongue)
|
|
)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:post
|
|
kermit-simple-post
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-tongue-stuck (kermit)
|
|
:event
|
|
(the-as
|
|
(function process int symbol event-message-block object :behavior kermit)
|
|
nav-enemy-default-event-handler
|
|
)
|
|
:enter
|
|
(behavior ()
|
|
(set! (-> self miss-count) 0)
|
|
(set! (-> self tongue-control forward-scale-control) 1.0)
|
|
(kermit-enable-tongue)
|
|
(set! (-> self tongue-pulse-pos) 0.0)
|
|
(spawn-kermit-pulse self (kermit-tongue-pos self) (-> self entity))
|
|
(none)
|
|
)
|
|
:exit
|
|
(behavior ()
|
|
(sound-stop (-> self sound-id))
|
|
(let ((v1-0 (-> self child-override)))
|
|
(if v1-0
|
|
(deactivate (-> v1-0 0))
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:trans
|
|
(behavior ()
|
|
(let ((s5-0 (kermit-player-target-pos))
|
|
(gp-0 (kermit-tongue-pos self))
|
|
)
|
|
(if (or (< 73728.0 (vector-vector-distance s5-0 gp-0))
|
|
(or (not (kermit-check-tongue-is-clear?)) (not (-> self child-override)))
|
|
)
|
|
(go kermit-retract-tongue)
|
|
)
|
|
(seek! (-> self tongue-pulse-pos) 1.0 (* 0.3 (-> *display* seconds-per-frame)))
|
|
(when (and (-> self child-override) (let ((v1-9 (-> self child-override)))
|
|
(= (-> (if v1-9
|
|
(-> v1-9 0 self-override)
|
|
)
|
|
type
|
|
)
|
|
kermit-pulse
|
|
)
|
|
)
|
|
)
|
|
(let* ((v1-13 (-> self child-override))
|
|
(s4-0 (if v1-13
|
|
(-> v1-13 0 self-override)
|
|
)
|
|
)
|
|
(v1-15 (vector-lerp! (new 'stack-no-clear 'vector) gp-0 s5-0 (-> self tongue-pulse-pos)))
|
|
)
|
|
(set! (-> s4-0 root-override trans quad) (-> v1-15 quad))
|
|
)
|
|
)
|
|
(send-event *target* 'tongue gp-0)
|
|
)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(ja-channel-push! 1 30)
|
|
(while #t
|
|
(let ((a0-1 (-> self skel root-channel 0)))
|
|
(set! (-> a0-1 frame-group) (the-as art-joint-anim (-> self draw art-group data 10)))
|
|
(set! (-> a0-1 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 10)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-1 param 1) 1.0)
|
|
(set! (-> a0-1 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-1 (the-as art-joint-anim (-> self draw art-group data 10)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(sound-play-by-name
|
|
(static-sound-name "kermit-stretch")
|
|
(-> self sound-id)
|
|
1024
|
|
0
|
|
0
|
|
1
|
|
(the-as symbol (-> self collide-info trans))
|
|
)
|
|
(suspend)
|
|
(let ((a0-4 (-> self skel root-channel 0)))
|
|
(set! (-> a0-4 param 0) (the float (+ (-> a0-4 frame-group data 0 length) -1)))
|
|
(set! (-> a0-4 param 1) 1.0)
|
|
(joint-control-channel-group-eval! a0-4 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:post
|
|
(behavior ()
|
|
(seek-to-point-toward-point! (-> self collide-info) (target-pos 0) (-> self rotate-speed) (seconds 0.05))
|
|
(kermit-simple-post)
|
|
(none)
|
|
)
|
|
)
|
|
|
|
;; failed to figure out what this is:
|
|
(defstate kermit-retract-tongue (kermit)
|
|
:event
|
|
(the-as
|
|
(function process int symbol event-message-block object :behavior kermit)
|
|
nav-enemy-default-event-handler
|
|
)
|
|
:enter
|
|
(behavior ()
|
|
(set! (-> self state-time) (-> *display* base-frame-counter))
|
|
(set! (-> self charged-up) #f)
|
|
(+! (-> self miss-count) 1)
|
|
(none)
|
|
)
|
|
:exit
|
|
(behavior ()
|
|
(set! (-> self tongue-control forward-scale-control) 0.0)
|
|
(kermit-disable-tongue)
|
|
(none)
|
|
)
|
|
:trans
|
|
(behavior ()
|
|
(kermit-set-nav-mesh-target (-> self collide-info trans))
|
|
(kermit-set-rotate-dir-to-player)
|
|
(when (not (-> self airborne))
|
|
(when (>= (- (-> *display* base-frame-counter) (-> self state-time)) (seconds 2.5))
|
|
(kill-and-free-particles (-> self charging-part))
|
|
(set! (-> self charged-up) #t)
|
|
(go kermit-chase)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(ja-channel-push! 1 30)
|
|
(let ((a0-1 (-> self skel root-channel 0)))
|
|
(set! (-> a0-1 frame-group) (the-as art-joint-anim (-> self draw art-group data 8)))
|
|
(set! (-> a0-1 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 8)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-1 param 1) 1.0)
|
|
(set! (-> a0-1 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-1 (the-as art-joint-anim (-> self draw art-group data 8)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(if (>= (ja-aframe-num 0) 3.0)
|
|
(seek! (-> self tongue-control forward-scale-control) 0.0 0.125)
|
|
)
|
|
(suspend)
|
|
(let ((a0-4 (-> self skel root-channel 0)))
|
|
(set! (-> a0-4 param 0) (the float (+ (-> a0-4 frame-group data 0 length) -1)))
|
|
(set! (-> a0-4 param 1) 1.0)
|
|
(joint-control-channel-group-eval! a0-4 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
(set! (-> self tongue-control forward-scale-control) 0.0)
|
|
(kermit-disable-tongue)
|
|
(while #t
|
|
(ja-channel-push! 1 30)
|
|
(let ((a0-7 (-> self skel root-channel 0)))
|
|
(set! (-> a0-7 frame-group) (the-as art-joint-anim (-> self draw art-group data 4)))
|
|
(set! (-> a0-7 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 4)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-7 param 1) 4.0)
|
|
(set! (-> a0-7 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-7 (the-as art-joint-anim (-> self draw art-group data 4)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(suspend)
|
|
(let ((a0-8 (-> self skel root-channel 0)))
|
|
(set! (-> a0-8 param 0) (the float (+ (-> a0-8 frame-group data 0 length) -1)))
|
|
(set! (-> a0-8 param 1) 4.0)
|
|
(joint-control-channel-group-eval! a0-8 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
(kermit-hop 0.0)
|
|
)
|
|
(none)
|
|
)
|
|
:post
|
|
kermit-post
|
|
)
|
|
|
|
;; definition for symbol *kermit-nav-enemy-info*, type nav-enemy-info
|
|
(define *kermit-nav-enemy-info* (new 'static 'nav-enemy-info
|
|
:idle-anim 4
|
|
:walk-anim -1
|
|
:turn-anim -1
|
|
:notice-anim -1
|
|
:run-anim -1
|
|
:jump-anim 6
|
|
:jump-land-anim -1
|
|
:victory-anim -1
|
|
:taunt-anim -1
|
|
:die-anim 11
|
|
:neck-joint 8
|
|
:player-look-at-joint 5
|
|
:run-travel-speed (meters 6)
|
|
:run-rotate-speed (degrees 10000.0)
|
|
:run-acceleration (meters 1)
|
|
:run-turn-time (seconds 0.05)
|
|
:walk-travel-speed (meters 3)
|
|
:walk-rotate-speed (degrees 10000.0)
|
|
:walk-acceleration (meters 1)
|
|
:walk-turn-time (seconds 0.05)
|
|
:attack-shove-back (meters 3)
|
|
:attack-shove-up (meters 2)
|
|
:shadow-size (meters 2)
|
|
:notice-nav-radius (meters 10)
|
|
:nav-nearest-y-threshold (meters 10)
|
|
:notice-distance (meters 30)
|
|
:stop-chase-distance (meters 40)
|
|
:frustration-distance (meters 8)
|
|
:frustration-time (seconds 4)
|
|
:die-anim-hold-frame 10000000000.0
|
|
:jump-land-anim-end-frame 10000000000.0
|
|
:jump-height-min (meters 1)
|
|
:jump-height-factor 0.5
|
|
:jump-start-anim-speed 1.0
|
|
:shadow-max-y (meters 1)
|
|
:shadow-min-y (meters -1)
|
|
:shadow-locus-dist (meters 150)
|
|
:use-align #f
|
|
:draw-shadow #t
|
|
:move-to-ground #f
|
|
:hover-if-no-ground #f
|
|
:use-momentum #f
|
|
:use-flee #f
|
|
:use-proximity-notice #f
|
|
:use-jump-blocked #f
|
|
:use-jump-patrol #f
|
|
:gnd-collide-with (collide-kind background)
|
|
:debug-draw-neck #f
|
|
:debug-draw-jump #f
|
|
)
|
|
)
|
|
|
|
;; definition for method 11 of type kermit
|
|
;; INFO: Return type mismatch object vs none.
|
|
(defmethod init-from-entity! kermit ((obj kermit) (arg0 entity-actor))
|
|
(set! (-> obj mask) (logior (process-mask enemy) (-> obj mask)))
|
|
(let ((s4-0 (new 'process 'collide-shape-moving obj (collide-list-enum usually-hit-by-player))))
|
|
(set! (-> s4-0 dynam) (copy *standard-dynamics* 'process))
|
|
(set! (-> s4-0 reaction) default-collision-reaction)
|
|
(set! (-> s4-0 no-reaction)
|
|
(the-as (function collide-shape-moving collide-shape-intersect vector vector none) nothing)
|
|
)
|
|
(let ((s3-0 (new 'process 'collide-shape-prim-group s4-0 (the-as uint 1) 0)))
|
|
(set! (-> s3-0 prim-core collide-as) (collide-kind enemy))
|
|
(set! (-> s3-0 collide-with) (collide-kind target))
|
|
(set! (-> s3-0 prim-core action) (collide-action solid))
|
|
(set-vector! (-> s3-0 local-sphere) 0.0 0.0 0.0 16384.0)
|
|
(set-root-prim! s4-0 s3-0)
|
|
(let ((s2-0 (new 'process 'collide-shape-prim-sphere s4-0 (the-as uint 3))))
|
|
(set! (-> s2-0 prim-core collide-as) (collide-kind enemy))
|
|
(set! (-> s2-0 collide-with) (collide-kind target))
|
|
(set! (-> s2-0 prim-core action) (collide-action solid))
|
|
(set! (-> s2-0 prim-core offense) (collide-offense touch))
|
|
(set! (-> s2-0 transform-index) 3)
|
|
(set-vector! (-> s2-0 local-sphere) 0.0 0.0 0.0 3072.0)
|
|
(append-prim s3-0 s2-0)
|
|
)
|
|
)
|
|
(set! (-> s4-0 nav-radius) (* 0.75 (-> s4-0 root-prim local-sphere w)))
|
|
(backup-collide-with-as s4-0)
|
|
(set! (-> obj collide-info) s4-0)
|
|
)
|
|
(process-drawable-from-entity! obj arg0)
|
|
(initialize-skeleton obj *kermit-sg* '())
|
|
(set! (-> obj draw origin-joint-index) (the-as uint 3))
|
|
(set! (-> obj airborne) #f)
|
|
(TODO-RENAME-45 obj *kermit-nav-enemy-info*)
|
|
(set-vector! (-> obj neck twist-max) 3640.889 3640.889 0.0 1.0)
|
|
(set! (-> obj neck up) (the-as uint 1))
|
|
(set! (-> obj neck nose) (the-as uint 2))
|
|
(set! (-> obj neck ear) (the-as uint 0))
|
|
(set! (-> obj neck max-dist) 102400.0)
|
|
(set! (-> obj neck ignore-angle) 16384.0)
|
|
(set! (-> obj miss-count) 0)
|
|
(set! (-> obj tongue-control) (new 'process 'joint-mod-tracker obj 24 kermit-get-tongue-target-callback 1 2))
|
|
(let ((f0-16 49152.0))
|
|
(set! (-> obj tongue-control inv-forward-scale-factor) (/ 1.0 f0-16))
|
|
)
|
|
(set! (-> obj tongue-control forward-scale-control) 0.0)
|
|
(set! (-> obj tongue-control forward-scale-max) 2.0)
|
|
(set! (-> obj tongue-control enable) #f)
|
|
(set! (-> obj charged-up) #t)
|
|
(set! (-> obj part) (create-launch-control (-> *part-group-id-table* 299) obj))
|
|
(set! (-> obj charging-part) (create-launch-control (-> *part-group-id-table* 298) obj))
|
|
(set! (-> obj sound-id) (new-sound-id))
|
|
(go kermit-idle)
|
|
(none)
|
|
)
|