mirror of
https://github.com/open-goal/jak-project.git
synced 2024-10-20 21:27:52 -04:00
7edfc8bcec
* blocked: `part-tester` - `code` handler thinks it returns nothing * blocked: `crates` finished but `go` is returning none causing issues * blocked: `(event ram-boss-idle)::snow-ram-boss` expression building fails due to delay slot issue * decomp: finish `snow-ram` | `seagull` blocked, new static data issue * decomp: finish `snow-bumper` * stuck: `snow-ball` close, can't figure out a type made on the stack * decomp: finish `spider-egg` * decomp: finish `puffer` * decomp: finish `driller-lurker` * decomp: finish `dark-crystal` * stuck: `kermit` - mostly done but stuck on a joint related callback arg * decomp: finish `gnawer` * decomp: finish `mother-spider-egg` * decomp: finish `swamp-blimp` * stuck: `mistycannon` prebind function signature * decomp: finish `citb-plat` * decomp: finish `darkvine` * blocked: `jungle-mirrors` - issues with `link` macro * decomp: finish `launcherdoor` * decomp: finish `quicksandlurker` except for 1 unused function * stuck: `balloonlurker` - `(code balloonlurker-mine-explode)` has some weird joint related code * stuck: need to decompile an asm func in `orbit-plat` * decomp: finish `voicebox` * blocked: `mother-spider` has issues where `go` returns none * decomp: finish `bully` * decomp: finish `seagull` * fixed up after merge conflicts * decomp: finish `jungle-mirrors` * update gsrc * double checked files, fixed issues * decomp: revert change to projectile methods * decomp: some more fixes * address feedback * fix up remaining method calls in `cam-states` * fix jungle-mirrors
661 lines
27 KiB
Common Lisp
661 lines
27 KiB
Common Lisp
;;-*-Lisp-*-
|
|
(in-package goal)
|
|
|
|
;; name: mother-spider-egg.gc
|
|
;; name in dgo: mother-spider-egg
|
|
;; dgos: L1, MAI, MAINCAVE
|
|
|
|
(define-extern *mother-spider-egg-unbroken-sg* skeleton-group)
|
|
(define-extern *mother-spider-egg-broken-sg* skeleton-group)
|
|
|
|
(declare-type mother-spider-egg process-drawable)
|
|
|
|
(define-extern mother-spider-egg-falling (state mother-spider-egg)) ;; unknown type
|
|
(define-extern mother-spider-egg-die-exit (state mother-spider-egg)) ;; unknown type
|
|
(define-extern mother-spider-egg-hatch (state mother-spider-egg)) ;; unknown type
|
|
(define-extern mother-spider-egg-die (state mother-spider-egg)) ;; unknown type
|
|
(define-extern mother-spider-egg-on-ground (state mother-spider-egg)) ;; unknown type
|
|
(define-extern mother-spider-egg-die-while-falling (state mother-spider-egg)) ;; unknown type
|
|
|
|
;; DECOMP BEGINS
|
|
|
|
(deftype mother-spider-egg (process-drawable)
|
|
((parent-override (pointer mother-spider) :offset 12)
|
|
(root-override collide-shape-moving :offset 112)
|
|
(anim-speed float :offset-assert 176)
|
|
(part2 sparticle-launch-control :offset-assert 180)
|
|
(falling-start-time uint64 :offset-assert 184)
|
|
(fall-dest vector :inline :offset-assert 192)
|
|
(fall-dest-normal vector :inline :offset-assert 208)
|
|
(broken-look lod-set :inline :offset-assert 224)
|
|
(traj trajectory :inline :offset-assert 272)
|
|
(shadow-pos vector :inline :offset-assert 320)
|
|
)
|
|
:heap-base #xe0
|
|
:method-count-assert 22
|
|
:size-assert #x150
|
|
:flag-assert #x1600e00150
|
|
(:methods
|
|
(dummy-20 (_type_) none 20)
|
|
(draw-egg-shadow (_type_ vector symbol) symbol 21)
|
|
)
|
|
)
|
|
|
|
|
|
(defskelgroup *mother-spider-egg-unbroken-sg* spider-egg
|
|
0
|
|
-1
|
|
((1 (meters 20)) (2 (meters 40)) (3 (meters 999999)))
|
|
:bounds (static-spherem 0 1 0 2)
|
|
:longest-edge (meters 0)
|
|
:shadow 4
|
|
)
|
|
|
|
(defskelgroup *mother-spider-egg-broken-sg* spider-egg
|
|
5
|
|
-1
|
|
((6 (meters 20)) (7 (meters 40)) (8 (meters 999999)))
|
|
:bounds (static-spherem 0 1 0 2)
|
|
:longest-edge (meters 0)
|
|
)
|
|
|
|
(set! (-> *part-group-id-table* 324) (new 'static 'sparticle-launch-group
|
|
:length 2
|
|
:duration #x5
|
|
:linger-duration #x384
|
|
:flags (sp-group-flag use-local-clock)
|
|
:name "group-spider-egg-hatches"
|
|
:launcher
|
|
(new 'static 'inline-array sparticle-group-item 2
|
|
(sp-item 2018 :fade-after (meters 50.0) :falloff-to (meters 50.0))
|
|
(sp-item 2071 :fade-after (meters 50.0) :falloff-to (meters 50.0))
|
|
)
|
|
:bounds (new 'static 'sphere :w 32768.0)
|
|
)
|
|
)
|
|
|
|
(set! (-> *part-id-table* 2071) (new 'static 'sparticle-launcher
|
|
:init-specs
|
|
(new 'static 'inline-array sp-field-init-spec 16
|
|
(sp-tex spt-texture (new 'static 'texture-id :index #xf :page #x2))
|
|
(sp-flt spt-num 16.0)
|
|
(sp-flt spt-y (meters 0.5))
|
|
(sp-flt spt-scale-x (meters 0.1))
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-flt spt-scale-y (meters 0.1))
|
|
(sp-flt spt-r 255.0)
|
|
(sp-flt spt-g 64.0)
|
|
(sp-flt spt-b 255.0)
|
|
(sp-rnd-flt spt-a 32.0 96.0 1.0)
|
|
(sp-int spt-timer 225)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 75)
|
|
(sp-launcher-by-id spt-next-launcher 2072)
|
|
(sp-end)
|
|
)
|
|
)
|
|
)
|
|
|
|
(set! (-> *part-id-table* 2072)
|
|
(new 'static 'sparticle-launcher :init-specs (new 'static 'inline-array sp-field-init-spec 5
|
|
(sp-flt spt-scale-x (meters 0.1))
|
|
(sp-flt spt-scale-y (meters 2.0))
|
|
(sp-flt spt-scalevel-y (meters 0.2))
|
|
(sp-flt spt-fade-a -1.4222223)
|
|
(sp-end)
|
|
)
|
|
)
|
|
)
|
|
|
|
(set! (-> *part-id-table* 2018) (new 'static 'sparticle-launcher
|
|
:init-specs
|
|
(new 'static 'inline-array sp-field-init-spec 24
|
|
(sp-tex spt-texture (new 'static 'texture-id :page #x2))
|
|
(sp-flt spt-num 8.0)
|
|
(sp-rnd-flt spt-y (meters 0.5) (meters 0.5) 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 0.5) (meters 1.0) 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 32.0 32.0 1.0)
|
|
(sp-rnd-flt spt-g 0.0 16.0 1.0)
|
|
(sp-rnd-flt spt-b 32.0 32.0 1.0)
|
|
(sp-flt spt-a 0.0)
|
|
(sp-rnd-flt spt-vel-y (meters 0.0033333334) (meters 0.0033333334) 1.0)
|
|
(sp-flt spt-scalevel-x (meters 0.006666667))
|
|
(sp-rnd-flt spt-rotvel-z (degrees -1.2) (degrees 1.2) 1.0)
|
|
(sp-copy-from-other spt-scalevel-y -4)
|
|
(sp-flt spt-fade-a 1.4222223)
|
|
(sp-flt spt-accel-y 0.27306667)
|
|
(sp-int spt-timer 375)
|
|
(sp-cpuinfo-flags bit2 bit12 bit14)
|
|
(sp-int spt-next-time 45)
|
|
(sp-launcher-by-id spt-next-launcher 2073)
|
|
(sp-flt spt-conerot-x (degrees 90.0))
|
|
(sp-rnd-flt spt-conerot-y (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-rnd-flt spt-conerot-radius (meters 0.0) (meters 0.5) 1.0)
|
|
(sp-end)
|
|
)
|
|
)
|
|
)
|
|
|
|
(set! (-> *part-id-table* 2073)
|
|
(new 'static 'sparticle-launcher
|
|
:init-specs
|
|
(new 'static 'inline-array sp-field-init-spec 2 (sp-flt spt-fade-a -0.21333334) (sp-end))
|
|
)
|
|
)
|
|
|
|
(set! (-> *part-group-id-table* 325) (new 'static 'sparticle-launch-group
|
|
:length 1
|
|
:duration #x5
|
|
:linger-duration #x177
|
|
:flags (sp-group-flag use-local-clock)
|
|
:name "group-spider-egg-explodes"
|
|
:launcher
|
|
(new 'static 'inline-array sparticle-group-item 1
|
|
(sp-item 2074 :fade-after (meters 50.0) :falloff-to (meters 50.0))
|
|
)
|
|
:bounds (new 'static 'sphere :w 32768.0)
|
|
)
|
|
)
|
|
|
|
(set! (-> *part-id-table* 2074) (new 'static 'sparticle-launcher
|
|
:init-specs
|
|
(new 'static 'inline-array sp-field-init-spec 22
|
|
(sp-tex spt-texture (new 'static 'texture-id :page #x2))
|
|
(sp-flt spt-num 8.0)
|
|
(sp-rnd-flt spt-y (meters 0.5) (meters 0.5) 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 1.5) (meters 2.0) 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 32.0 32.0 1.0)
|
|
(sp-rnd-flt spt-g 0.0 16.0 1.0)
|
|
(sp-rnd-flt spt-b 32.0 32.0 1.0)
|
|
(sp-rnd-flt spt-a 32.0 32.0 1.0)
|
|
(sp-rnd-flt spt-vel-y (meters 0.0033333334) (meters 0.0033333334) 1.0)
|
|
(sp-flt spt-scalevel-x (meters 0.006666667))
|
|
(sp-rnd-flt spt-rotvel-z (degrees -1.2) (degrees 1.2) 1.0)
|
|
(sp-copy-from-other spt-scalevel-y -4)
|
|
(sp-flt spt-fade-a -1.4222223)
|
|
(sp-flt spt-accel-y 0.27306667)
|
|
(sp-int spt-timer 375)
|
|
(sp-cpuinfo-flags bit2 bit12 bit14)
|
|
(sp-flt spt-conerot-x (degrees 90.0))
|
|
(sp-rnd-flt spt-conerot-y (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-rnd-flt spt-conerot-radius (meters 0.0) (meters 0.5) 1.0)
|
|
(sp-end)
|
|
)
|
|
)
|
|
)
|
|
|
|
(defmethod draw-egg-shadow mother-spider-egg ((obj mother-spider-egg) (arg0 vector) (arg1 symbol))
|
|
(cond
|
|
((and (-> obj draw shadow) (zero? (-> obj draw cur-lod)) (logtest? (-> obj draw status) 8))
|
|
(let ((s5-0 (new 'stack-no-clear 'collide-tri-result))
|
|
(a1-1 (new 'stack-no-clear 'vector))
|
|
(a2-1 (new 'stack-no-clear 'vector))
|
|
)
|
|
(set! (-> a1-1 quad) (-> obj root-override trans quad))
|
|
(set! (-> a1-1 y) (+ 1228.8 (-> a1-1 y)))
|
|
(set-vector! a2-1 0.0 -61440.0 0.0 1.0)
|
|
(cond
|
|
((>= (dummy-10 *collide-cache* a1-1 a2-1 7372.8 1 obj s5-0 1) 0.0)
|
|
(let ((v1-11 (-> obj draw shadow-ctrl)))
|
|
(set! (-> v1-11 settings flags) (logand -33 (-> v1-11 settings flags)))
|
|
)
|
|
0
|
|
(let ((v1-14 (-> obj draw shadow-ctrl)))
|
|
(set! (-> v1-14 settings bot-plane w) (- (+ -4096.0 (-> s5-0 intersect y))))
|
|
)
|
|
0
|
|
(let ((v1-17 (-> obj draw shadow-ctrl)))
|
|
(set! (-> v1-17 settings top-plane w) (- (+ 6144.0 (-> s5-0 intersect y))))
|
|
)
|
|
0
|
|
(return #t)
|
|
)
|
|
(else
|
|
(let ((v1-22 (-> obj draw shadow-ctrl)))
|
|
(logior! (-> v1-22 settings flags) 32)
|
|
)
|
|
0
|
|
)
|
|
)
|
|
)
|
|
)
|
|
(else
|
|
(let ((v1-25 (-> obj draw shadow-ctrl)))
|
|
(logior! (-> v1-25 settings flags) 32)
|
|
)
|
|
0
|
|
)
|
|
)
|
|
#f
|
|
)
|
|
|
|
(defstate mother-spider-egg-falling (mother-spider-egg)
|
|
:event
|
|
(behavior ((arg0 process) (arg1 int) (arg2 symbol) (arg3 event-message-block))
|
|
(case arg2
|
|
(('touch 'attack)
|
|
(go mother-spider-egg-die-while-falling)
|
|
)
|
|
)
|
|
)
|
|
:enter
|
|
(behavior () (set! (-> self falling-start-time) (the-as uint (-> *display* base-frame-counter))) (none))
|
|
:trans
|
|
(behavior ()
|
|
(let ((f30-0 (fmin
|
|
(the float (- (-> *display* base-frame-counter) (the-as int (-> self falling-start-time))))
|
|
(-> self traj time)
|
|
)
|
|
)
|
|
)
|
|
(let ((f28-0 (/ f30-0 (-> self traj time))))
|
|
(eval-position! (-> self traj) f30-0 (-> self root-override trans))
|
|
(let ((f0-3 (lerp 0.3 0.4 f28-0)))
|
|
(set-vector! (-> self root-override scale) f0-3 f0-3 f0-3 1.0)
|
|
)
|
|
)
|
|
(when (= f30-0 (-> self traj time))
|
|
(sound-play-by-name (static-sound-name "eggs-lands") (new-sound-id) 1024 0 0 1 #t)
|
|
(go mother-spider-egg-on-ground)
|
|
)
|
|
)
|
|
(draw-egg-shadow self (-> self shadow-pos) #t)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(ja-channel-push! 1 0)
|
|
(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 9)))
|
|
(set! (-> a0-1 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 9)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-1 param 1) (-> self anim-speed))
|
|
(set! (-> a0-1 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-1 (the-as art-joint-anim (-> self draw art-group data 9)) 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) (-> self anim-speed))
|
|
(joint-control-channel-group-eval! a0-2 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:post
|
|
(the-as (function none :behavior mother-spider-egg) transform-post)
|
|
)
|
|
|
|
(defstate mother-spider-egg-on-ground (mother-spider-egg)
|
|
:event
|
|
(behavior ((arg0 process) (arg1 int) (arg2 symbol) (arg3 event-message-block))
|
|
(let ((v1-0 arg2))
|
|
(the-as
|
|
object
|
|
(cond
|
|
((= v1-0 'touch)
|
|
(dummy-55 (-> self root-override) arg0 (the-as touching-shapes-entry (-> arg3 param 0)) 0.7 6144.0 16384.0)
|
|
)
|
|
((= v1-0 'attack)
|
|
(go mother-spider-egg-die)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
:enter
|
|
(behavior ()
|
|
(set! (-> self state-time) (-> *display* base-frame-counter))
|
|
(if (not (draw-egg-shadow self (-> self shadow-pos) #t))
|
|
(set! (-> self shadow-pos quad) (-> self fall-dest quad))
|
|
)
|
|
(none)
|
|
)
|
|
:trans
|
|
(behavior ()
|
|
(if (>= (- (-> *display* base-frame-counter) (-> self state-time)) 600)
|
|
(go mother-spider-egg-hatch)
|
|
)
|
|
(draw-egg-shadow self (-> self shadow-pos) #f)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(ja-channel-push! 1 30)
|
|
(let ((gp-0 (new 'stack-no-clear 'quaternion))
|
|
(s5-0 (new 'stack-no-clear 'quaternion))
|
|
)
|
|
(let ((s3-0 (new 'stack-no-clear 'vector))
|
|
(s4-0 (new 'stack-no-clear 'vector))
|
|
)
|
|
(quaternion-copy! gp-0 (-> self root-override quat))
|
|
(set-vector! s4-0 0.0 1.0 0.0 1.0)
|
|
(set! (-> s3-0 quad) (-> self fall-dest-normal quad))
|
|
(vector-normalize! s3-0 1.0)
|
|
(quaternion-from-two-vectors! s5-0 s4-0 s3-0)
|
|
)
|
|
(quaternion*! s5-0 s5-0 gp-0)
|
|
(let ((a0-7 (-> self skel root-channel 0)))
|
|
(set! (-> a0-7 frame-group) (the-as art-joint-anim (-> self draw art-group data 11)))
|
|
(set! (-> a0-7 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 11)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-7 param 1) 1.3)
|
|
(set! (-> a0-7 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-7 (the-as art-joint-anim (-> self draw art-group data 11)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(let* ((f0-8 (ja-frame-num 0))
|
|
(v1-19 (if (> (-> self skel active-channels) 0)
|
|
(-> self skel root-channel 0 frame-group)
|
|
)
|
|
)
|
|
(f0-9 (/ f0-8 (the float (+ (-> v1-19 data 0 length) -1))))
|
|
)
|
|
(quaternion-slerp! (-> self root-override quat) gp-0 s5-0 f0-9)
|
|
)
|
|
(suspend)
|
|
(let ((a0-10 (-> self skel root-channel 0)))
|
|
(set! (-> a0-10 param 0) (the float (+ (-> a0-10 frame-group data 0 length) -1)))
|
|
(set! (-> a0-10 param 1) 1.3)
|
|
(joint-control-channel-group-eval! a0-10 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
)
|
|
(while #t
|
|
(let ((a0-12 (-> self skel root-channel 0)))
|
|
(set! (-> a0-12 frame-group) (the-as art-joint-anim (-> self draw art-group data 9)))
|
|
(set! (-> a0-12 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 9)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-12 param 1) (-> self anim-speed))
|
|
(set! (-> a0-12 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-12 (the-as art-joint-anim (-> self draw art-group data 9)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(suspend)
|
|
(let ((a0-13 (-> self skel root-channel 0)))
|
|
(set! (-> a0-13 param 0) (the float (+ (-> a0-13 frame-group data 0 length) -1)))
|
|
(set! (-> a0-13 param 1) (-> self anim-speed))
|
|
(joint-control-channel-group-eval! a0-13 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:post
|
|
(the-as (function none :behavior mother-spider-egg) transform-post)
|
|
)
|
|
|
|
(defstate mother-spider-egg-hatch (mother-spider-egg)
|
|
:trans
|
|
(behavior ()
|
|
(when (and (zero? (-> self draw cur-lod)) (logtest? (-> self draw status) 8))
|
|
(let ((a1-0 (new 'stack-no-clear 'vector)))
|
|
(set! (-> a1-0 quad) (-> self fall-dest quad))
|
|
(compute-and-draw-shadow
|
|
(-> self root-override trans)
|
|
a1-0
|
|
(-> self fall-dest-normal)
|
|
(the-as vector 7372.8)
|
|
81920.0
|
|
(the-as float 0)
|
|
)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(send-event (ppointer->process (-> self parent-override)) 'trigger)
|
|
(clear-collide-with-as (-> self root-override))
|
|
(let ((gp-0 (get-process *default-dead-pool* part-tracker #x4000)))
|
|
(when gp-0
|
|
(let ((t9-3 (method-of-type part-tracker activate)))
|
|
(t9-3 (the-as part-tracker gp-0) *entity-pool* 'part-tracker (the-as pointer #x70004000))
|
|
)
|
|
(run-now-in-process
|
|
gp-0
|
|
part-tracker-init
|
|
(-> *part-group-id-table* 324)
|
|
-1
|
|
#f
|
|
#f
|
|
#f
|
|
(-> self root-override trans)
|
|
)
|
|
(-> gp-0 ppointer)
|
|
)
|
|
)
|
|
(lods-assign! (-> self draw) (-> self broken-look))
|
|
(ja-channel-push! 1 60)
|
|
(let ((a0-7 (-> self skel root-channel 0)))
|
|
(set! (-> a0-7 frame-group) (the-as art-joint-anim (-> self draw art-group data 10)))
|
|
(set! (-> a0-7 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 10)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-7 param 1) 1.0)
|
|
(set! (-> a0-7 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-7 (the-as art-joint-anim (-> self draw art-group data 10)) 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) 1.0)
|
|
(joint-control-channel-group-eval! a0-8 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
(let ((v1-37 (-> self draw shadow-ctrl)))
|
|
(logior! (-> v1-37 settings flags) 32)
|
|
)
|
|
0
|
|
(go mother-spider-egg-die-exit)
|
|
(none)
|
|
)
|
|
:post
|
|
(the-as (function none :behavior mother-spider-egg) transform-post)
|
|
)
|
|
|
|
(defstate mother-spider-egg-die (mother-spider-egg)
|
|
:code
|
|
(behavior ()
|
|
(logclear! (-> self mask) (process-mask actor-pause))
|
|
(let ((v1-3 (-> self draw shadow-ctrl)))
|
|
(logior! (-> v1-3 settings flags) 32)
|
|
)
|
|
0
|
|
(lods-assign! (-> self draw) (-> self broken-look))
|
|
(ja-channel-push! 1 30)
|
|
(clear-collide-with-as (-> self root-override))
|
|
(let ((gp-0 (get-process *default-dead-pool* part-tracker #x4000)))
|
|
(when gp-0
|
|
(let ((t9-4 (method-of-type part-tracker activate)))
|
|
(t9-4 (the-as part-tracker gp-0) *entity-pool* 'part-tracker (the-as pointer #x70004000))
|
|
)
|
|
(run-now-in-process
|
|
gp-0
|
|
part-tracker-init
|
|
(-> *part-group-id-table* 325)
|
|
-1
|
|
#f
|
|
#f
|
|
#f
|
|
(-> self root-override trans)
|
|
)
|
|
(-> gp-0 ppointer)
|
|
)
|
|
)
|
|
(let ((a0-9 (-> self skel root-channel 0)))
|
|
(set! (-> a0-9 frame-group) (the-as art-joint-anim (-> self draw art-group data 12)))
|
|
(set! (-> a0-9 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 12)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-9 param 1) 1.0)
|
|
(set! (-> a0-9 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-9 (the-as art-joint-anim (-> self draw art-group data 12)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(suspend)
|
|
(let ((a0-10 (-> self skel root-channel 0)))
|
|
(set! (-> a0-10 param 0) (the float (+ (-> a0-10 frame-group data 0 length) -1)))
|
|
(set! (-> a0-10 param 1) 1.0)
|
|
(joint-control-channel-group-eval! a0-10 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
(go mother-spider-egg-die-exit)
|
|
(none)
|
|
)
|
|
:post
|
|
(the-as (function none :behavior mother-spider-egg) ja-post)
|
|
)
|
|
|
|
(defstate mother-spider-egg-die-while-falling (mother-spider-egg)
|
|
:trans
|
|
(behavior ()
|
|
(let ((f0-2 (fmin
|
|
(the float (- (-> *display* base-frame-counter) (the-as int (-> self falling-start-time))))
|
|
(-> self traj time)
|
|
)
|
|
)
|
|
)
|
|
(eval-position! (-> self traj) f0-2 (-> self root-override trans))
|
|
)
|
|
(none)
|
|
)
|
|
:code
|
|
(behavior ()
|
|
(logclear! (-> self mask) (process-mask actor-pause))
|
|
(clear-collide-with-as (-> self root-override))
|
|
(let ((v1-5 (-> self draw shadow-ctrl)))
|
|
(logior! (-> v1-5 settings flags) 32)
|
|
)
|
|
0
|
|
(let ((gp-0 (get-process *default-dead-pool* part-tracker #x4000)))
|
|
(when gp-0
|
|
(let ((t9-2 (method-of-type part-tracker activate)))
|
|
(t9-2 (the-as part-tracker gp-0) *entity-pool* 'part-tracker (the-as pointer #x70004000))
|
|
)
|
|
(run-now-in-process
|
|
gp-0
|
|
part-tracker-init
|
|
(-> *part-group-id-table* 325)
|
|
-1
|
|
#f
|
|
#f
|
|
#f
|
|
(-> self root-override trans)
|
|
)
|
|
(-> gp-0 ppointer)
|
|
)
|
|
)
|
|
(lods-assign! (-> self draw) (-> self broken-look))
|
|
(ja-channel-push! 1 30)
|
|
(let ((a0-9 (-> self skel root-channel 0)))
|
|
(set! (-> a0-9 frame-group) (the-as art-joint-anim (-> self draw art-group data 12)))
|
|
(set! (-> a0-9 param 0)
|
|
(the float (+ (-> (the-as art-joint-anim (-> self draw art-group data 12)) data 0 length) -1))
|
|
)
|
|
(set! (-> a0-9 param 1) 1.0)
|
|
(set! (-> a0-9 frame-num) 0.0)
|
|
(joint-control-channel-group! a0-9 (the-as art-joint-anim (-> self draw art-group data 12)) num-func-seek!)
|
|
)
|
|
(until (ja-done? 0)
|
|
(suspend)
|
|
(let ((a0-10 (-> self skel root-channel 0)))
|
|
(set! (-> a0-10 param 0) (the float (+ (-> a0-10 frame-group data 0 length) -1)))
|
|
(set! (-> a0-10 param 1) 1.0)
|
|
(joint-control-channel-group-eval! a0-10 (the-as art-joint-anim #f) num-func-seek!)
|
|
)
|
|
)
|
|
(go mother-spider-egg-die-exit)
|
|
(none)
|
|
)
|
|
:post
|
|
(the-as (function none :behavior mother-spider-egg) ja-post)
|
|
)
|
|
|
|
(defstate mother-spider-egg-die-exit (mother-spider-egg)
|
|
:code
|
|
(behavior ()
|
|
(send-event (ppointer->process (-> self parent-override)) 'untrigger)
|
|
(logior! (-> self draw status) 2)
|
|
(let ((v1-8 (-> self draw shadow-ctrl)))
|
|
(logior! (-> v1-8 settings flags) 32)
|
|
)
|
|
0
|
|
(set! (-> self root-override nav-flags) (logand -2 (-> self root-override nav-flags)))
|
|
(set! (-> self root-override nav-flags) (logand -3 (-> self root-override nav-flags)))
|
|
(clear-collide-with-as (-> self root-override))
|
|
(until (not (-> self child))
|
|
(suspend)
|
|
)
|
|
(none)
|
|
)
|
|
)
|
|
|
|
(defbehavior mother-spider-egg-init-by-other mother-spider-egg ((arg0 entity) (arg1 vector) (arg2 vector) (arg3 vector))
|
|
(set! (-> self entity) arg0)
|
|
(set! (-> self anim-speed) (rand-vu-float-range 0.8 1.2))
|
|
(set! (-> self falling-start-time) (the-as uint (-> *display* base-frame-counter)))
|
|
(set! (-> self fall-dest quad) (-> arg2 quad))
|
|
(set! (-> self fall-dest-normal quad) (-> arg3 quad))
|
|
(let ((s4-1 (new 'process 'collide-shape-moving self (collide-list-enum usually-hit-by-player))))
|
|
(set! (-> s4-1 dynam) (copy *standard-dynamics* 'process))
|
|
(set! (-> s4-1 reaction) default-collision-reaction)
|
|
(set! (-> s4-1 no-reaction)
|
|
(the-as (function collide-shape-moving collide-shape-intersect vector vector none) nothing)
|
|
)
|
|
(let ((s3-0 (new 'process 'collide-shape-prim-sphere s4-1 (the-as uint 0))))
|
|
(set! (-> s3-0 prim-core collide-as) (the-as uint 256))
|
|
(set! (-> s3-0 collide-with) (the-as uint 16))
|
|
(set! (-> s3-0 prim-core action) (the-as uint 1))
|
|
(set! (-> s3-0 prim-core offense) 1)
|
|
(set-vector! (-> s3-0 local-sphere) 0.0 2048.0 0.0 3686.4)
|
|
(set-root-prim! s4-1 s3-0)
|
|
)
|
|
(set! (-> s4-1 nav-radius) 4096.0)
|
|
(backup-collide-with-as s4-1)
|
|
(set! (-> self root-override) s4-1)
|
|
)
|
|
(set! (-> self root-override trans quad) (-> arg1 quad))
|
|
(set-vector! (-> self root-override scale) 0.3 0.3 0.3 1.0)
|
|
(quaternion-copy! (-> self root-override quat) (-> self parent-override 0 root-override quat))
|
|
(logior! (-> self mask) (process-mask actor-pause))
|
|
(set! (-> self mask) (logior (process-mask enemy) (-> self mask)))
|
|
(set! (-> self mask) (logior (process-mask attackable) (-> self mask)))
|
|
(initialize-skeleton self *mother-spider-egg-unbroken-sg* '())
|
|
(dummy-9 (-> self broken-look) *mother-spider-egg-broken-sg* (-> self draw art-group) (-> self entity))
|
|
(set! (-> self draw shadow-ctrl) (new 'process 'shadow-control 0.0 0.0 614400.0 (the-as float 60) 245760.0))
|
|
(set! (-> self nav) (new 'process 'nav-control (-> self root-override) 16 40960.0))
|
|
(logior! (-> self nav flags) (nav-control-flags display-marks bit3 bit5 bit6 bit7))
|
|
(set! (-> self root-override nav-flags) (logand -2 (-> self root-override nav-flags)))
|
|
(logior! (-> self root-override nav-flags) 2)
|
|
(set! (-> self nav extra-nav-sphere quad) (-> self fall-dest quad))
|
|
(set! (-> self nav extra-nav-sphere w) 4096.0)
|
|
(setup-from-to-height! (-> self traj) (-> self root-override trans) arg2 4096.0 -4.551111)
|
|
(create-connection!
|
|
*cavecrystal-light-control*
|
|
self
|
|
(-> self entity)
|
|
(the-as (function object object object object object) cavecrystal-light-control-default-callback)
|
|
-1
|
|
4096.0
|
|
)
|
|
(go mother-spider-egg-falling)
|
|
(none)
|
|
)
|
|
|
|
|
|
|
|
|