X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=irrlicht%2Fscene.scm;h=6c55a3d0cda9c2c7729a84484c216e851ed4d294;hb=a880a7401ee591eaff7d1c32bf14c1af977f7776;hp=d268dea8a583492e5f8fddafb7478c3a0b9a061a;hpb=fc3be36ca8e29c32e1758ae99c9982aa287d8920;p=guile-irrlicht.git diff --git a/irrlicht/scene.scm b/irrlicht/scene.scm index d268dea..6c55a3d 100644 --- a/irrlicht/scene.scm +++ b/irrlicht/scene.scm @@ -85,6 +85,72 @@ id make-active)))) +(define-method (add-camera-scene-node-fps! (scene-manager ) . rest) + (let-keywords rest #f + ((parent (make )) + (rotate-speed 100) + (move-speed 0.5) + (id -1) + (key-map-array (make )) + (key-map-size 0) + (no-vertical-movement #f) + (jump-speed 0) + (invert-mouse #f) + (make-active #t)) + (let ((addCameraSceneNodeFPS (get-irrlicht-proc "addCameraSceneNodeFPS" + scene-manager parent))) + (make + #:irr-pointer + (addCameraSceneNodeFPS scene-manager #:parent parent #:rotate-speed rotate-speed + #:move-speed move-speed #:id id #:key-map-array key-map-array + #:key-map-size key-map-size + #:no-vertical-movement no-vertical-movement + #:jump-speed jump-speed #:invert-mouse invert-mouse + #:make-active make-active))))) + +(define-method (add-custom-scene-node! (scene-manager ) proc-render + proc-get-bounding-box proc-get-material-count + proc-get-material . rest) + (let-keywords rest #f + ((parent (make )) + (id -1) + (position '(0 0 0)) + (rotation '(0 0 0)) + (scale '(1 1 1))) + (let ((addCustomSceneNode (get-irrlicht-proc "addCustomSceneNode" scene-manager parent))) + (make + #:irr-pointer + (addCustomSceneNode scene-manager proc-render proc-get-bounding-box proc-get-material-count + proc-get-material parent id position rotation scale))))) + +(define-method (add-octree-scene-node! (scene-manager ) + (mesh ) + . rest) + (let-keywords rest #f + ((parent (make )) + (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 + #: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 ) + (mesh ) + . rest) + (let-keywords rest #f + ((parent (make )) + (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 + #:irr-pointer + (addOctreeSceneNode scene-manager mesh parent id minimal-polys-per-node + also-add-if-mesh-pointer-zero))))) + (define-method (draw-all (scene-manager )) ((get-irrlicht-proc "drawAll" scene-manager) scene-manager)) @@ -96,7 +162,13 @@ scene-manager filename))) -(export add-animated-mesh-scene-node! add-camera-scene-node! draw-all get-mesh) +(define-method (get-root-scene-node (scene-manager )) + (let ((getRootSceneNode (get-irrlicht-proc "getRootSceneNode" scene-manager))) + (make #:irr-pointer (getRootSceneNode scene-manager)))) + +(export add-animated-mesh-scene-node! add-camera-scene-node! + add-camera-scene-node-fps! add-custom-scene-node! add-octree-scene-node! draw-all + get-root-scene-node get-mesh) ;; ISceneNode @@ -115,7 +187,11 @@ texture-layer texture)) -(export set-material-flag! set-material-texture!) +(define-method (set-position! (node ) new-pos) + (let ((setPosition (get-irrlicht-proc "setPosition" node))) + (setPosition node new-pos))) + +(export set-material-flag! set-material-texture! set-position!) ;; IAnimatedMeshSceneNode @@ -135,3 +211,10 @@ (irr-class #:init-value "ICameraSceneNode")) (export ) + + +;; IMeshSceneNode +(define-class () + (irr-class #:init-value "IMeshSceneNode")) + +(export )