]> git.jsancho.org Git - guile-irrlicht.git/blobdiff - irrlicht/scene.scm
add-octree-scene-node!
[guile-irrlicht.git] / irrlicht / scene.scm
index 3ca632656c3f37682b2a9c86e071820d334e5013..6a6486fe8565f8bf5ecdce34723df012112211a3 100644 (file)
 
 ;; IMesh
 (define-class <mesh> (<reference-counted>)
-  (irr-class #:init-value "IMesh" #:getter irr-class))
+  (irr-class #:init-value "IMesh"))
 
 (export <mesh>)
 
 
 ;; IAnimatedMesh
 (define-class <animated-mesh> (<mesh>)
-  (irr-class #:init-value "IAnimatedMesh" #:getter irr-class))
+  (irr-class #:init-value "IAnimatedMesh"))
 
 (export <animated-mesh>)
 
 
 ;; ISceneManager
 (define-class <scene-manager> (<reference-counted>)
-  (irr-class #:init-value "ISceneManager" #:getter irr-class))
+  (irr-class #:init-value "ISceneManager"))
 
-(define-method (add-animated-mesh-scene-node! (scene-manager <scene-manager>) mesh . rest)
+(define-method (add-animated-mesh-scene-node! (scene-manager <scene-manager>)
+                                              (mesh <animated-mesh>)
+                                              . rest)
   (let-keywords rest #f
         ((parent (make <scene-node>))
          (id -1)
     (make <animated-mesh-scene-node>
       #:irr-pointer
       ((get-irrlicht-proc "addAnimatedMeshSceneNode" scene-manager parent)
-       (irr-pointer scene-manager)
-       (irr-pointer mesh)
-       (irr-pointer parent)
+       scene-manager
+       mesh
+       parent
        id
        position
        rotation
        scale
        also-add-if-mesh-pointer-zero))))
 
+(define-method (add-camera-scene-node! (scene-manager <scene-manager>) . rest)
+  (let-keywords rest #f
+        ((parent (make <scene-node>))
+         (position '(0 0 0))
+         (lookat '(0 0 100))
+         (id -1)
+         (make-active #t))
+    (make <camera-scene-node>
+      #:irr-pointer
+      ((get-irrlicht-proc "addCameraSceneNode" scene-manager parent)
+       scene-manager
+       parent
+       position
+       lookat
+       id
+       make-active))))
+
+(define-method (add-octree-scene-node! (scene-manager <scene-manager>)
+                                       (mesh <animated-mesh>)
+                                       . rest)
+  (let-keywords rest #f
+        ((parent (make <scene-node>))
+         (id -1)
+         (minimal-polys-per-node 512)
+         (also-add-if-mesh-pointer-zero #f))
+    (let ((addOctreeSceneNode (get-irrlicht-proc "addOctreeSceneNode" scene-manager parent mesh)))
+      (make <mesh-scene-node>
+        #:irr-pointer
+        (addOctreeSceneNode scene-manager mesh parent id minimal-polys-per-node
+                            also-add-if-mesh-pointer-zero)))))
+
+(define-method (add-octree-scene-node! (scene-manager <scene-manager>)
+                                       (mesh <mesh>)
+                                       . rest)
+  (let-keywords rest #f
+        ((parent (make <scene-node>))
+         (id -1)
+         (minimal-polys-per-node 256)
+         (also-add-if-mesh-pointer-zero #f))
+    (let ((addOctreeSceneNode (get-irrlicht-proc "addOctreeSceneNode" scene-manager parent mesh)))
+      (make <mesh-scene-node>
+        #:irr-pointer
+        (addOctreeSceneNode scene-manager mesh parent id minimal-polys-per-node
+                            also-add-if-mesh-pointer-zero)))))
+
+(define-method (draw-all (scene-manager <scene-manager>))
+  ((get-irrlicht-proc "drawAll" scene-manager)
+   scene-manager))
+
 (define-method (get-mesh (scene-manager <scene-manager>) filename)
   (make <animated-mesh>
     #:irr-pointer
     ((get-irrlicht-proc "getMesh" scene-manager)
-     (irr-pointer scene-manager)
+     scene-manager
      filename)))
 
-(export <scene-manager> add-animated-mesh-scene-node! get-mesh)
+(export <scene-manager> add-animated-mesh-scene-node! add-camera-scene-node! add-octree-scene-node!
+        draw-all get-mesh)
 
 
 ;; ISceneNode
 (define-class <scene-node> (<attribute-exchanging-object>)
-  (irr-class #:init-value "ISceneNode" #:getter irr-class))
+  (irr-class #:init-value "ISceneNode"))
 
 (define-method (set-material-flag! (node <scene-node>) flag new-value)
   ((get-irrlicht-proc "setMaterialFlag" node)
-   (irr-pointer node)
+   node
    flag
    new-value))
 
 (define-method (set-material-texture! (node <scene-node>) texture-layer (texture <texture>))
   ((get-irrlicht-proc "setMaterialTexture" node)
-   (irr-pointer node)
+   node
    texture-layer
-   (irr-pointer texture)))
+   texture))
 
 (export <scene-node> set-material-flag! set-material-texture!)
 
 
-;; ISceneNode
+;; IAnimatedMeshSceneNode
 (define-class <animated-mesh-scene-node> (<scene-node>)
-  (irr-class #:init-value "IAnimatedMeshSceneNode" #:getter irr-class))
+  (irr-class #:init-value "IAnimatedMeshSceneNode"))
 
 (define-method (set-md2-animation! (node <animated-mesh-scene-node>) anim)
   ((get-irrlicht-proc "setMD2Animation" node)
-   (irr-pointer node)
+   node
    anim))
 
 (export <animated-mesh-scene-node> set-md2-animation!)
+
+
+;; ICameraSceneNode
+(define-class <camera-scene-node> (<scene-node>)
+  (irr-class #:init-value "ICameraSceneNode"))
+
+(export <camera-scene-node>)
+
+
+;; IMeshSceneNode
+(define-class <mesh-scene-node> (<scene-node>)
+  (irr-class #:init-value "IMeshSceneNode"))
+
+(export <mesh-scene-node>)