]> git.jsancho.org Git - guile-irrlicht.git/blobdiff - src/scene-manager.cpp
add-camera-scene-node-fps!
[guile-irrlicht.git] / src / scene-manager.cpp
index cb7f80c94d0249106ff105ae3d39b0a91e5fa681..eb7a3780ab6361e2afd0c72fcf3d70ed3041b7ab 100644 (file)
@@ -26,6 +26,9 @@
 #include "animated-mesh-scene-node.h"
 #include "camera-scene-node.h"
 #include "device.h"
+#include "keymap.h"
+#include "mesh.h"
+#include "mesh-scene-node.h"
 #include "scene-manager.h"
 #include "scene-node.h"
 #include "vector3d.h"
@@ -41,9 +44,14 @@ extern "C" {
                         (scm_t_subr)irr_scene_addAnimatedMeshSceneNode);
     scm_c_define_gsubr ("add-camera-scene-node!", 1, 0, 1,
                         (scm_t_subr)irr_scene_addCameraSceneNode);
+    scm_c_define_gsubr ("add-camera-scene-node-fps!", 1, 0, 1,
+                        (scm_t_subr)irr_scene_addCameraSceneNodeFPS);
+    scm_c_define_gsubr ("add-octree-scene-node!", 2, 0, 1,
+                        (scm_t_subr)irr_scene_addOctreeSceneNode);
     scm_c_define_gsubr ("get-mesh", 2, 0, 0, (scm_t_subr)irr_scene_getMesh);
     scm_c_define_gsubr ("get-scene-manager", 1, 0, 0, (scm_t_subr)irr_getSceneManager);
     scm_c_export ("add-animated-mesh-scene-node!", "add-camera-scene-node!",
+                  "add-camera-scene-node-fps!", "add-octree-scene-node!",
                   "get-mesh", "get-scene-manager", NULL);
   }
 
@@ -122,6 +130,87 @@ extern "C" {
     return wrap_camera_scene_node (camera);
   }
 
+  SCM
+  irr_scene_addCameraSceneNodeFPS (SCM wrapped_scene_manager,
+                                   SCM rest)
+  {
+    SCM parent = scm_from_bool (0);
+    SCM rotate_speed = scm_from_double (100);
+    SCM move_speed = scm_from_double (0.5);
+    SCM id = scm_from_int32 (-1);
+    SCM key_map_array = scm_from_bool (0);
+    SCM key_map_size = scm_from_int32 (0);
+    SCM no_vertical_movement = scm_from_bool (0);
+    SCM jump_speed = scm_from_double (0);
+    SCM invert_mouse = scm_from_bool (0);
+    SCM make_active = scm_from_bool (1);
+    
+    scm_c_bind_keyword_arguments ("add-camera-scene-node-fps!", rest, (scm_t_keyword_arguments_flags)0,
+                                  scm_from_utf8_keyword ("parent"), &parent,
+                                  scm_from_utf8_keyword ("rotate-speed"), &rotate_speed,
+                                  scm_from_utf8_keyword ("move-speed"), &move_speed,
+                                  scm_from_utf8_keyword ("id"), &id,
+                                  scm_from_utf8_keyword ("key-map-array"), &key_map_array,
+                                  scm_from_utf8_keyword ("key-map-size"), &key_map_size,
+                                  scm_from_utf8_keyword ("no-vertical-movement"), &no_vertical_movement,
+                                  scm_from_utf8_keyword ("jump-speed"), &jump_speed,
+                                  scm_from_utf8_keyword ("invert-mouse"), &invert_mouse,
+                                  scm_from_utf8_keyword ("make-active"), &make_active,
+                                  SCM_UNDEFINED);
+
+    irr::scene::ISceneManager* scene_manager = unwrap_scene_manager (wrapped_scene_manager);
+    irr::scene::ICameraSceneNode* camera =
+      scene_manager->addCameraSceneNodeFPS (scm_is_false (parent) ? 0 : unwrap_scene_node (parent),
+                                            scm_to_double (rotate_speed),
+                                            scm_to_double (move_speed),
+                                            scm_to_int32 (id),
+                                            scm_is_false (key_map_array) ? 0 : unwrap_keymap (key_map_array),
+                                            scm_to_int32 (key_map_size),
+                                            scm_to_bool (no_vertical_movement),
+                                            scm_to_double (jump_speed),
+                                            scm_to_bool (invert_mouse),
+                                            scm_to_bool (make_active));
+    return wrap_camera_scene_node (camera);
+  }
+
+  SCM
+  irr_scene_addOctreeSceneNode (SCM wrapped_scene_manager,
+                                SCM wrapped_mesh,
+                                SCM rest)
+  {
+    SCM parent = scm_from_bool (0);
+    SCM id = scm_from_int32 (-1);
+    SCM minimal_polys_per_node = scm_from_int32 (256);
+    SCM also_add_if_mesh_pointer_zero = scm_from_bool (0);
+
+    scm_c_bind_keyword_arguments ("add-octree-scene-node!", rest, (scm_t_keyword_arguments_flags)0,
+                                  scm_from_utf8_keyword ("parent"), &parent,
+                                  scm_from_utf8_keyword ("id"), &id,
+                                  scm_from_utf8_keyword ("minimal-polys-per-node"), &minimal_polys_per_node,
+                                  scm_from_utf8_keyword ("also-add-if-mesh-pointer-zero"), &also_add_if_mesh_pointer_zero,
+                                  SCM_UNDEFINED);
+
+    irr::scene::ISceneManager* smgr = unwrap_scene_manager (wrapped_scene_manager);
+    irr::scene::IMeshSceneNode* node;
+    if (animated_mesh_p (wrapped_mesh))
+      {
+        node = smgr->addOctreeSceneNode (unwrap_animated_mesh (wrapped_mesh),
+                                         scm_is_false (parent) ? 0 : unwrap_scene_node (parent),
+                                         scm_to_int32 (id),
+                                         scm_to_int32 (minimal_polys_per_node),
+                                         scm_to_bool (also_add_if_mesh_pointer_zero));
+      }
+    else
+      {
+        node = smgr->addOctreeSceneNode (unwrap_mesh (wrapped_mesh),
+                                         scm_is_false (parent) ? 0 : unwrap_scene_node (parent),
+                                         scm_to_int32 (id),
+                                         scm_to_int32 (minimal_polys_per_node),
+                                         scm_to_bool (also_add_if_mesh_pointer_zero));
+      }
+    return wrap_mesh_scene_node (node);
+  }
+
   SCM
   irr_scene_getMesh (SCM wrapped_scene_manager,
                      SCM filename)