X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=src%2Fscene-node.cpp;h=08c94a8f48be3464aac40f2fc87ac625964c8c9f;hb=0cb94da9c4b0cc97e1a6e3452922b78f9f84124e;hp=50d402b3866031277d9fab2edf9ca143dde2b3a1;hpb=68528ba0d56d77a3e803e984237c873515dc9618;p=guile-irrlicht.git diff --git a/src/scene-node.cpp b/src/scene-node.cpp index 50d402b..08c94a8 100644 --- a/src/scene-node.cpp +++ b/src/scene-node.cpp @@ -51,6 +51,16 @@ extern "C" { init_scene_node_type, scene_node_p, wrap_scene_node, unwrap_scene_node); + bool + is_scene_node_object (SCM wrapped_scene_node) + { + return + animated_mesh_scene_node_p (wrapped_scene_node) || + camera_scene_node_p (wrapped_scene_node) || + mesh_scene_node_p (wrapped_scene_node) || + scene_node_p (wrapped_scene_node); + } + SCM irr_scene_addAnimator (SCM wrapped_scene_node, SCM animator) @@ -71,10 +81,9 @@ extern "C" { } else { - scm_error (scm_arg_type_key, NULL, "Cannot add animator flag to object: ~S", + scm_error (scm_arg_type_key, NULL, "Cannot add animator to object: ~S", scm_list_1 (wrapped_scene_node), scm_list_1 (wrapped_scene_node)); } - return SCM_UNSPECIFIED; } @@ -85,6 +94,26 @@ extern "C" { return scm_from_matrix4 (node->getAbsoluteTransformation ()); } + SCM + irr_scene_getPosition (SCM wrapped_scene_node) + { +#define GET_POSITION(NODE) scm_from_vector3df (NODE->getPosition ()); + + if (scene_node_p (wrapped_scene_node)) + { + return GET_POSITION (unwrap_scene_node (wrapped_scene_node)); + } + else if (mesh_scene_node_p (wrapped_scene_node)) + { + return GET_POSITION (unwrap_mesh_scene_node (wrapped_scene_node)); + } + else + { + scm_error (scm_arg_type_key, NULL, "Cannot get position from object: ~S", + scm_list_1 (wrapped_scene_node), scm_list_1 (wrapped_scene_node)); + } + } + SCM irr_scene_ISceneNode_setMaterialFlag (SCM wrapped_scene_node, SCM flag,