jak-project/goal_src/engine/draw/drawable-group.gc
water111 3afd99a8e3
[graphics] partial tfrag implementation (#958)
* temp

* some decomp

* tfrag dma setup

* fix negative label bug

* tfrag dma setup

* tfrag, with pipeline tricks

* kinda works

* cleanup before trying some color stuff

* time of day works

* clean up

* temp before render changes

* a few more fixes

* fix up tests

* clean up

* fix

* fix alignment

* one more cleanup
2021-11-13 20:44:17 -05:00

115 lines
3 KiB
Common Lisp

;;-*-Lisp-*-
(in-package goal)
;; name: drawable-group.gc
;; name in dgo: drawable-group
;; dgos: GAME, ENGINE
(defmethod new drawable-group ((allocation symbol) (type-to-make type) (arg0 int))
"Allocate a drawable-group with enough room for arg0 drawables"
(let ((v0-0 (object-new allocation type-to-make
(the-as int (+ (-> type-to-make size) (* (+ arg0 -1) 4)))
)
)
)
(set! (-> v0-0 length) arg0)
v0-0
)
)
(defmethod inspect drawable-group ((obj drawable-group))
(format #t "[~8x] ~A~%" obj (-> obj type))
(format #t "~Tid: ~D~%" (-> obj id))
(format #t "~Tlength: ~D~%" (-> obj length))
(format #t "~Tdata[~D]: @ #x~X~%" (-> obj length) (-> obj data))
(dotimes (s5-0 (-> obj length))
(format #t "~T [~D] ~A~%" s5-0 (-> obj data s5-0))
)
obj
)
(defmethod print drawable-group ((obj drawable-group))
(format #t "#<~A @ #x~X [~D]" (-> obj type) obj (-> obj length))
(dotimes (s5-0 (-> obj length))
(format #t " ~A" (-> obj data s5-0))
)
(format #t ">")
obj
)
(defmethod length drawable-group ((obj drawable-group))
(-> obj length)
)
(defmethod asize-of drawable-group ((obj drawable-group))
(the-as int (+ (-> drawable-group size) (* (+ (-> obj length) -1) 4)))
)
(defmethod mem-usage drawable-group ((obj drawable-group) (arg0 memory-usage-block) (arg1 int))
(set! (-> arg0 length) (max 1 (-> arg0 length)))
(set! (-> arg0 data 0 name) "drawable-group")
(+! (-> arg0 data 0 count) 1)
(let ((v1-6 (asize-of obj)))
(+! (-> arg0 data 0 used) v1-6)
(+! (-> arg0 data 0 total) (logand -16 (+ v1-6 15)))
)
(dotimes (s3-0 (-> obj length))
(mem-usage (-> obj data s3-0) arg0 arg1)
)
obj
)
(defmethod login drawable-group ((obj drawable-group))
(dotimes (s5-0 (-> obj length))
(login (-> obj data s5-0))
)
obj
)
(defmethod draw drawable-group ((obj drawable-group) (arg0 drawable) (arg1 display-frame))
(when (vis-cull (-> obj id))
(when (sphere-cull (-> obj bsphere))
(dotimes (s3-0 (-> obj length))
(draw (-> obj data s3-0) (-> (the-as drawable-group arg0) data s3-0) arg1)
)
)
)
0
(none)
)
(defmethod collect-stats drawable-group ((obj drawable-group))
(when (vis-cull (-> obj id))
(when (sphere-cull (-> obj bsphere))
(dotimes (s5-0 (-> obj length))
(collect-stats (-> obj data s5-0))
)
)
)
0
(none)
)
(defmethod debug-draw drawable-group ((obj drawable-group) (arg0 drawable) (arg1 display-frame))
(when (vis-cull (-> obj id))
(when (sphere-cull (-> obj bsphere))
(dotimes (s3-0 (-> obj length))
(debug-draw
(-> obj data s3-0)
(-> (the-as drawable-group arg0) data s3-0)
arg1
)
)
)
)
0
(none)
)
(defmethod dummy-16 drawable-group ((obj drawable-group) (arg0 object) (arg1 object))
(dotimes (s4-0 (-> obj length))
(set! arg1 (dummy-16 (-> obj data s4-0) arg0 arg1))
)
arg1
)