X-Git-Url: https://git.jsancho.org/?p=guile-irrlicht.git;a=blobdiff_plain;f=irrlicht%2Fscene.scm;h=425d01ec026bd8c08fa666beb6d764518deab0f8;hp=0053b9386854a1c7b5cbd0399f04d680715d1c8d;hb=0c415f2f23b5351bdd8e3901ccc29073fe98d9f6;hpb=8ff6816b98af584ca7670ad964d5f13f84e18044 diff --git a/irrlicht/scene.scm b/irrlicht/scene.scm index 0053b93..425d01e 100644 --- a/irrlicht/scene.scm +++ b/irrlicht/scene.scm @@ -1,5 +1,5 @@ ;;; guile-irrlicht --- FFI bindings for Irrlicht Engine -;;; Copyright (C) 2019 Javier Sancho +;;; Copyright (C) 2020 Javier Sancho ;;; ;;; This file is part of guile-irrlicht. ;;; @@ -19,27 +19,224 @@ (define-module (irrlicht scene) - #:export (add-animated-mesh-scene-node - get-mesh - set-material-flag! - set-md2-animation!)) - -(load-extension "libguile-irrlicht" "init_guile_irrlicht") - -(define irr-add-animated-mesh-scene-node add-animated-mesh-scene-node) -(define* (add-animated-mesh-scene-node scene-manager mesh - #:key - (parent #f) - (id -1) - (position '(0 0 0)) - (rotation '(0 0 0)) - (scale '(1 1 1)) - (also-add-if-mesh-pointer-zero #f)) - (irr-add-animated-mesh-scene-node scene-manager - mesh - parent - id - position - rotation - scale - also-add-if-mesh-pointer-zero)) + #:use-module (oop goops) + #:use-module (ice-9 optargs) + #:use-module (irrlicht base) + #:use-module (irrlicht foreign) + #:use-module (irrlicht io) + #:use-module (irrlicht irr) + #:use-module (irrlicht video)) + + +;; IMesh +(define-class () + (irr-class #:init-value "IMesh")) + +(export ) + + +;; IAnimatedMesh +(define-class () + (irr-class #:init-value "IAnimatedMesh")) + +(export ) + + +;; ISceneNodeAnimator +(define-class ( ) + (irr-class #:init-value "ISceneNodeAnimator")) + +(export ) + + +;; ISceneManager +(define-class () + (irr-class #:init-value "ISceneManager")) + +(define-method (add-animated-mesh-scene-node! (scene-manager ) + (mesh ) + . rest) + (let-keywords rest #f + ((parent (make )) + (id -1) + (position '(0 0 0)) + (rotation '(0 0 0)) + (scale '(1 1 1)) + (also-add-if-mesh-pointer-zero #f)) + (make + #:irr-pointer + ((get-irrlicht-proc "addAnimatedMeshSceneNode" scene-manager parent) + scene-manager + mesh + parent + id + position + rotation + scale + also-add-if-mesh-pointer-zero)))) + +(define-method (add-camera-scene-node! (scene-manager ) . rest) + (let-keywords rest #f + ((parent (make )) + (position '(0 0 0)) + (lookat '(0 0 100)) + (id -1) + (make-active #t)) + (make + #:irr-pointer + ((get-irrlicht-proc "addCameraSceneNode" scene-manager parent) + scene-manager + parent + position + lookat + 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 (create-rotation-animator (scene-manager ) rotation-speed) + (let ((createRotationAnimator (get-irrlicht-proc "createRotationAnimator" scene-manager))) + (make + #:irr-pointer + (createRotationAnimator scene-manager rotation-speed)))) + +(define-method (draw-all (scene-manager )) + ((get-irrlicht-proc "drawAll" scene-manager) + scene-manager)) + +(define-method (get-mesh (scene-manager ) filename) + (make + #:irr-pointer + ((get-irrlicht-proc "getMesh" scene-manager) + scene-manager + filename))) + +(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! + create-rotation-animator draw-all get-root-scene-node get-mesh) + + +;; ISceneNode +(define-class () + (irr-class #:init-value "ISceneNode")) + +(define-method (add-animator! (node ) (animator )) + (let ((addAnimator (get-irrlicht-proc "addAnimator" node))) + (addAnimator node animator))) + +(define-method (get-absolute-transformation (node )) + (let ((getAbsoluteTransformation (get-irrlicht-proc "getAbsoluteTransformation" node))) + (getAbsoluteTransformation node))) + +(define-method (set-material-flag! (node ) flag new-value) + ((get-irrlicht-proc "setMaterialFlag" node) + node + flag + new-value)) + +(define-method (set-material-texture! (node ) texture-layer (texture )) + ((get-irrlicht-proc "setMaterialTexture" node) + node + texture-layer + texture)) + +(define-method (set-position! (node ) new-pos) + (let ((setPosition (get-irrlicht-proc "setPosition" node))) + (setPosition node new-pos))) + +(export add-animator! get-absolute-transformation set-material-flag! + set-material-texture! set-position!) + + +;; IAnimatedMeshSceneNode +(define-class () + (irr-class #:init-value "IAnimatedMeshSceneNode")) + +(define-method (set-md2-animation! (node ) anim) + ((get-irrlicht-proc "setMD2Animation" node) + node + anim)) + +(export set-md2-animation!) + + +;; ICameraSceneNode +(define-class () + (irr-class #:init-value "ICameraSceneNode")) + +(export ) + + +;; IMeshSceneNode +(define-class () + (irr-class #:init-value "IMeshSceneNode")) + +(export )