X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=src%2Fscene-node.cpp;h=08a133669364bb21e703c93b9ce60c3b2993c4eb;hb=19663b6c5766b06c73148fdf803ce3555052a23e;hp=1ec773c4ace9c2084e9f17e1d5ecfb8ee82a4d12;hpb=d6fd925d118daf71de62200a6c5505fa06917f62;p=guile-irrlicht.git diff --git a/src/scene-node.cpp b/src/scene-node.cpp index 1ec773c..08a1336 100644 --- a/src/scene-node.cpp +++ b/src/scene-node.cpp @@ -21,146 +21,153 @@ #include #include - -#include "animated-mesh-scene-node.h" +#include "gsubr.h" #include "material-flags.h" #include "matrix4.h" -#include "mesh-scene-node.h" #include "scene-node.h" -#include "scene-node-animator.h" -#include "texture.h" #include "vector3d.h" -#include "wrapped.h" -extern "C" { - void - init_scene_node (void) - { - init_scene_node_type (); - scm_c_define_gsubr ("add-animator!", 2, 0, 0, (scm_t_subr)irr_scene_addAnimator); - scm_c_define_gsubr ("get-absolute-transformation", 1, 0, 0, - (scm_t_subr)irr_scene_getAbsoluteTransformation); - scm_c_define_gsubr ("set-material-texture!", 3, 0, 0, (scm_t_subr)irr_scene_setMaterialTexture); - scm_c_export ("add-animator!", "get-absolute-transformation", - "set-material-texture!", NULL); - } +using namespace irr; - DEFINE_WRAPPED_TYPE (irr::scene::ISceneNode*, "scene-node", - init_scene_node_type, scene_node_p, - wrap_scene_node, unwrap_scene_node); - SCM - irr_scene_addAnimator (SCM wrapped_scene_node, - SCM animator) - { - irr::scene::ISceneNode* node; - - if (mesh_scene_node_p (wrapped_scene_node)) - { - node = (irr::scene::ISceneNode*)unwrap_mesh_scene_node (wrapped_scene_node); - } - else if (scene_node_p (wrapped_scene_node)) - { - node = unwrap_scene_node (wrapped_scene_node); - } - else - { - scm_error (scm_arg_type_key, NULL, "Cannot add animator flag to object: ~S", - scm_list_1 (wrapped_scene_node), scm_list_1 (wrapped_scene_node)); - } - - node->addAnimator (unwrap_scene_node_animator (animator)); - return SCM_UNSPECIFIED; - } +template +SCM +scene_ISceneNode_addAnimator (SCM scene_node, + SCM animator) +{ + TSceneNode node = (TSceneNode) scm_to_pointer (scene_node); + node->addAnimator ((scene::ISceneNodeAnimator*) scm_to_pointer (animator)); + return SCM_UNSPECIFIED; +} - SCM - irr_scene_getAbsoluteTransformation (SCM wrapped_scene_node) - { - irr::scene::ISceneNode* node = unwrap_scene_node (wrapped_scene_node); - return scm_from_matrix4 (node->getAbsoluteTransformation ()); - } - SCM - irr_scene_ISceneNode_setMaterialFlag (SCM wrapped_scene_node, - SCM flag, - SCM newvalue) - { - irr::scene::ISceneNode* node; - - if (animated_mesh_scene_node_p (wrapped_scene_node)) - { - node = (irr::scene::ISceneNode*)unwrap_animated_mesh_scene_node (wrapped_scene_node); - } - else if (mesh_scene_node_p (wrapped_scene_node)) - { - node = (irr::scene::ISceneNode*)unwrap_mesh_scene_node (wrapped_scene_node); - } - else if (scene_node_p (wrapped_scene_node)) - { - node = unwrap_scene_node (wrapped_scene_node); - } - else - { - scm_error (scm_arg_type_key, NULL, "Cannot set material flag to object: ~S", - scm_list_1 (wrapped_scene_node), scm_list_1 (wrapped_scene_node)); - } - - node->setMaterialFlag (scm_to_material_flag (flag), - scm_to_bool (newvalue)); - return SCM_UNSPECIFIED; - } +template +SCM +scene_ISceneNode_getAbsoluteTransformation (SCM scene_node) +{ + TSceneNode node = (TSceneNode) scm_to_pointer (scene_node); + return scm_from_matrix4 (node->getAbsoluteTransformation ()); +} + + +template +SCM +scene_ISceneNode_getPosition (SCM scene_node) +{ + TSceneNode node = (TSceneNode) scm_to_pointer (scene_node); + return scm_from_vector3df (node->getPosition ()); +} - SCM - irr_scene_setMaterialTexture (SCM wrapped_scene_node, - SCM texture_layer, - SCM texture) - { - irr::scene::ISceneNode* node; - - if (animated_mesh_scene_node_p (wrapped_scene_node)) - { - node = (irr::scene::ISceneNode*)unwrap_animated_mesh_scene_node (wrapped_scene_node); - } - else if (mesh_scene_node_p (wrapped_scene_node)) - { - node = (irr::scene::ISceneNode*)unwrap_mesh_scene_node (wrapped_scene_node); - } - else if (scene_node_p (wrapped_scene_node)) - { - node = unwrap_scene_node (wrapped_scene_node); - } - else - { - scm_error (scm_arg_type_key, NULL, "Cannot set material texture to object: ~S", - scm_list_1 (wrapped_scene_node), scm_list_1 (wrapped_scene_node)); - } - - node->setMaterialTexture (scm_to_uint32 (texture_layer), - unwrap_texture (texture)); - return SCM_UNSPECIFIED; - } - SCM - irr_scene_setPosition (SCM wrapped_scene_node, - SCM position) +template +SCM +scene_ISceneNode_setMaterialFlag (SCM scene_node, + SCM flag, + SCM newvalue) +{ + TSceneNode node = (TSceneNode) scm_to_pointer (scene_node); + node->setMaterialFlag (scm_to_material_flag (flag), scm_to_bool (newvalue)); + return SCM_UNSPECIFIED; +} + + +template +SCM +scene_ISceneNode_setMaterialTexture (SCM scene_node, + SCM texture_layer, + SCM texture) +{ + TSceneNode node = (TSceneNode) scm_to_pointer (scene_node); + node->setMaterialTexture (scm_to_uint32 (texture_layer), + (video::ITexture*) scm_to_pointer (texture)); + return SCM_UNSPECIFIED; +} + + +template +SCM +scene_ISceneNode_setPosition (SCM scene_node, + SCM position) +{ + TSceneNode node = (TSceneNode) scm_to_pointer (scene_node); + node->setPosition (scm_to_vector3df (position)); + return SCM_UNSPECIFIED; +} + + +template +SCM +scene_ISceneNode_setRotation (SCM scene_node, + SCM rotation) +{ + TSceneNode node = (TSceneNode) scm_to_pointer (scene_node); + node->setRotation (scm_to_vector3df (rotation)); + return SCM_UNSPECIFIED; +} + + +template +SCM +scene_ISceneNode_setScale (SCM scene_node, + SCM scale) +{ + TSceneNode node = (TSceneNode) scm_to_pointer (scene_node); + node->setScale (scm_to_vector3df (scale)); + return SCM_UNSPECIFIED; +} + + +extern "C" { + + void + init_scene_node (void) { - if (scene_node_p (wrapped_scene_node)) - { - unwrap_scene_node (wrapped_scene_node)-> - setPosition (scm_to_vector3df (position)); - } - else if (mesh_scene_node_p (wrapped_scene_node)) - { - unwrap_mesh_scene_node (wrapped_scene_node)-> - setPosition (scm_to_vector3df (position)); - } - else - { - scm_error (scm_arg_type_key, NULL, "Cannot set position to object: ~S", - scm_list_1 (wrapped_scene_node), scm_list_1 (wrapped_scene_node)); - } - return SCM_UNSPECIFIED; + DEFINE_GSUBR ("scene_IAnimatedMeshSceneNode_addAnimator", 2, 0, 0, + scene_ISceneNode_addAnimator); + DEFINE_GSUBR ("scene_IMeshSceneNode_addAnimator", 2, 0, 0, + scene_ISceneNode_addAnimator); + DEFINE_GSUBR ("scene_ISceneNode_addAnimator", 2, 0, 0, + scene_ISceneNode_addAnimator); + + DEFINE_GSUBR ("scene_ISceneNode_getAbsoluteTransformation", 1, 0, 0, + scene_ISceneNode_getAbsoluteTransformation); + + DEFINE_GSUBR ("scene_IMeshSceneNode_getPosition", 1, 0, 0, + scene_ISceneNode_getPosition); + DEFINE_GSUBR ("scene_ISceneNode_getPosition", 1, 0, 0, + scene_ISceneNode_getPosition); + + DEFINE_GSUBR ("scene_IAnimatedMeshSceneNode_setMaterialFlag", 3, 0, 0, + scene_ISceneNode_setMaterialFlag); + DEFINE_GSUBR ("scene_IMeshSceneNode_setMaterialFlag", 3, 0, 0, + scene_ISceneNode_setMaterialFlag); + DEFINE_GSUBR ("scene_ISceneNode_setMaterialFlag", 3, 0, 0, + scene_ISceneNode_setMaterialFlag); + + DEFINE_GSUBR ("scene_IAnimatedMeshSceneNode_setMaterialTexture", 3, 0, 0, + scene_ISceneNode_setMaterialTexture); + DEFINE_GSUBR ("scene_IMeshSceneNode_setMaterialTexture", 3, 0, 0, + scene_ISceneNode_setMaterialTexture); + DEFINE_GSUBR ("scene_ISceneNode_setMaterialTexture", 3, 0, 0, + scene_ISceneNode_setMaterialTexture); + + DEFINE_GSUBR ("scene_IMeshSceneNode_setPosition", 2, 0, 0, + scene_ISceneNode_setPosition); + DEFINE_GSUBR ("scene_ISceneNode_setPosition", 2, 0, 0, + scene_ISceneNode_setPosition); + + DEFINE_GSUBR ("scene_IAnimatedMeshSceneNode_setRotation", 2, 0, 0, + scene_ISceneNode_setRotation); + DEFINE_GSUBR ("scene_ICameraSceneNode_setRotation", 2, 0, 0, + scene_ISceneNode_setRotation); + DEFINE_GSUBR ("scene_ISceneNode_setRotation", 2, 0, 0, + scene_ISceneNode_setRotation); + + DEFINE_GSUBR ("scene_IAnimatedMeshSceneNode_setScale", 2, 0, 0, + scene_ISceneNode_setScale); + DEFINE_GSUBR ("scene_ISceneNode_setScale", 2, 0, 0, + scene_ISceneNode_setScale); } }