X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=src%2Fgui-environment.cpp;h=df43fc63d5359ef1b4ca5aef614cf8fbc2886a9f;hb=37aba303eccc24a407f1b5b0af81623e47b89a22;hp=fb13f53d363f901f1e7b2692523c3daf4e7a4d70;hpb=3394d6066c9092a5444c9273f52cea01e2eaf10f;p=guile-irrlicht.git diff --git a/src/gui-environment.cpp b/src/gui-environment.cpp index fb13f53..df43fc6 100644 --- a/src/gui-environment.cpp +++ b/src/gui-environment.cpp @@ -23,10 +23,21 @@ #include #include "device.h" +#include "gsubr.h" +#include "gui-button.h" +#include "gui-editbox.h" #include "gui-element.h" #include "gui-environment.h" +#include "gui-font.h" +#include "gui-image.h" +#include "gui-listbox.h" +#include "gui-scrollbar.h" +#include "gui-skin.h" #include "gui-static-text.h" +#include "gui-window.h" +#include "position2d.h" #include "rect.h" +#include "texture.h" #include "wchar.h" #include "wrapped.h" @@ -36,9 +47,14 @@ extern "C" { init_gui_environment (void) { init_gui_environment_type (); - scm_c_define_gsubr ("add-static-text!", 3, 0, 1, (scm_t_subr)irr_gui_addStaticText); - scm_c_define_gsubr ("get-gui-environment", 1, 0, 0, (scm_t_subr)irr_getGUIEnvironment); - scm_c_export ("add-static-text!", "get-gui-environment", NULL); + DEFINE_GSUBR ("add-image!", 3, 0, 1, irr_gui_addImage); + DEFINE_GSUBR ("add-editbox!", 3, 0, 1, irr_gui_addEditBox); + DEFINE_GSUBR ("add-listbox!", 2, 0, 1, irr_gui_addListBox); + DEFINE_GSUBR ("add-scrollbar!", 3, 0, 1, irr_gui_addScrollBar); + DEFINE_GSUBR ("add-static-text!", 3, 0, 1, irr_gui_addStaticText); + DEFINE_GSUBR ("add-window!", 2, 0, 1, irr_gui_addWindow); + DEFINE_GSUBR ("get-built-in-font", 1, 0, 0, irr_gui_getBuiltInFont); + DEFINE_GSUBR ("get-skin", 1, 0, 0, irr_gui_getSkin); } DEFINE_WRAPPED_TYPE (irr::gui::IGUIEnvironment*, "gui-environment", @@ -46,19 +62,105 @@ extern "C" { wrap_gui_environment, unwrap_gui_environment); SCM - irr_getGUIEnvironment (SCM wrapped_obj) + irr_gui_addImage (SCM wrapped_gui_environment, + SCM image, + SCM position, + SCM rest) { - irr::gui::IGUIEnvironment* gui_environment; - if (device_p (wrapped_obj)) - { - gui_environment = unwrap_device (wrapped_obj)->getGUIEnvironment (); - } - else - { - scm_error (scm_arg_type_key, NULL, "Cannot get GUI environment from object: ~S", - scm_list_1 (wrapped_obj), scm_list_1 (wrapped_obj)); - } - return wrap_gui_environment (gui_environment); + SCM use_alpha_channel = SCM_BOOL_T; + SCM parent = SCM_UNDEFINED; + SCM id = scm_from_int32 (-1); + SCM text = SCM_UNDEFINED; + + scm_c_bind_keyword_arguments ("add-image!", rest, (scm_t_keyword_arguments_flags)0, + scm_from_utf8_keyword ("use_alpha_channel"), &use_alpha_channel, + scm_from_utf8_keyword ("parent"), &parent, + scm_from_utf8_keyword ("id"), &id, + scm_from_utf8_keyword ("text"), &text, + SCM_UNDEFINED); + + irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment); + irr::gui::IGUIImage* guiImage = + guienv->addImage (unwrap_texture (image), + scm_to_position2d_s32 (position), + scm_to_bool (use_alpha_channel), + parent == SCM_UNDEFINED ? 0 : unwrap_gui_element (parent), + scm_to_int32 (id), + text == SCM_UNDEFINED ? 0 : scm_to_wide_char_string (text)); + return wrap_gui_image (guiImage); + } + + SCM + irr_gui_addEditBox (SCM wrapped_gui_environment, + SCM text, + SCM rectangle, + SCM rest) + { + SCM border = SCM_BOOL_T; + SCM parent = SCM_UNDEFINED; + SCM id = scm_from_int32 (-1); + + scm_c_bind_keyword_arguments ("add-editbox!", rest, (scm_t_keyword_arguments_flags)0, + scm_from_utf8_keyword ("border"), &border, + scm_from_utf8_keyword ("parent"), &parent, + scm_from_utf8_keyword ("id"), &id, + SCM_UNDEFINED); + + irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment); + irr::gui::IGUIEditBox* editbox = + guienv->addEditBox (scm_to_wide_char_string (text), + scm_to_rect_s32 (rectangle), + scm_to_bool (border), + parent == SCM_UNDEFINED ? 0 : unwrap_gui_element (parent), + scm_to_int32 (id)); + return wrap_gui_editbox (editbox); + } + + SCM + irr_gui_addListBox (SCM wrapped_gui_environment, + SCM rectangle, + SCM rest) + { + SCM parent = SCM_UNDEFINED; + SCM id = scm_from_int32 (-1); + SCM draw_background = SCM_BOOL_F; + + scm_c_bind_keyword_arguments ("add-listbox!", rest, (scm_t_keyword_arguments_flags)0, + scm_from_utf8_keyword ("parent"), &parent, + scm_from_utf8_keyword ("id"), &id, + scm_from_utf8_keyword ("draw-background"), &draw_background, + SCM_UNDEFINED); + + irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment); + irr::gui::IGUIListBox* listbox = + guienv->addListBox (scm_to_rect_s32 (rectangle), + parent == SCM_UNDEFINED ? 0 : unwrap_gui_element (parent), + scm_to_int32 (id), + scm_to_bool (draw_background)); + return wrap_gui_listbox (listbox); + } + + SCM + irr_gui_addScrollBar (SCM wrapped_gui_environment, + SCM horizontal, + SCM rectangle, + SCM rest) + { + SCM parent = SCM_UNDEFINED; + SCM id = scm_from_int32 (-1); + + scm_c_bind_keyword_arguments ("add-scrollbar!", rest, (scm_t_keyword_arguments_flags)0, + scm_from_utf8_keyword ("parent"), &parent, + scm_from_utf8_keyword ("id"), &id, + SCM_UNDEFINED); + + irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment); + irr::gui::IGUIScrollBar* scrollbar = + guienv->addScrollBar (scm_to_bool (horizontal), + scm_to_rect_s32 (rectangle), + parent == SCM_UNDEFINED ? 0 : unwrap_gui_element (parent), + scm_to_int32 (id)); + return wrap_gui_scrollbar (scrollbar); } SCM @@ -67,11 +169,11 @@ extern "C" { SCM rectangle, SCM rest) { - SCM border = scm_from_bool (0); - SCM word_wrap = scm_from_bool (1); - SCM parent = scm_from_bool (0); + SCM border = SCM_BOOL_F; + SCM word_wrap = SCM_BOOL_T; + SCM parent = SCM_UNDEFINED; SCM id = scm_from_int32 (-1); - SCM fill_background = scm_from_bool (0); + SCM fill_background = SCM_BOOL_F; scm_c_bind_keyword_arguments ("add-static-text!", rest, (scm_t_keyword_arguments_flags)0, scm_from_utf8_keyword ("border"), &border, @@ -87,10 +189,89 @@ extern "C" { scm_to_rect_s32 (rectangle), scm_to_bool (border), scm_to_bool (word_wrap), - scm_is_false (parent) ? 0 : unwrap_gui_element (parent), + parent == SCM_UNDEFINED ? 0 : unwrap_gui_element (parent), scm_to_int32 (id), scm_to_bool (fill_background)); return wrap_gui_static_text (staticText); } + SCM + irr_gui_addWindow (SCM wrapped_gui_environment, + SCM rectangle, + SCM rest) + { + SCM modal = SCM_BOOL_F; + SCM text = SCM_UNDEFINED; + SCM parent = SCM_UNDEFINED; + SCM id = scm_from_int32 (-1); + + scm_c_bind_keyword_arguments ("add-window!", rest, (scm_t_keyword_arguments_flags)0, + scm_from_utf8_keyword ("modal"), &modal, + scm_from_utf8_keyword ("text"), &text, + scm_from_utf8_keyword ("parent"), &parent, + scm_from_utf8_keyword ("id"), &id, + SCM_UNDEFINED); + + irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment); + irr::gui::IGUIWindow* window = + guienv->addWindow (scm_to_rect_s32 (rectangle), + scm_to_bool (modal), + text == SCM_UNDEFINED ? 0 : scm_to_wide_char_string (text), + parent == SCM_UNDEFINED ? 0 : unwrap_gui_element (parent), + scm_to_int32 (id)); + return wrap_gui_window (window); + } + + SCM + irr_gui_getBuiltInFont (SCM wrapped_gui_environment) + { + irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment); + irr::gui::IGUIFont* font = guienv->getBuiltInFont (); + return wrap_gui_font (font); + } + + SCM + irr_gui_getSkin (SCM wrapped_gui_environment) + { + irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment); + irr::gui::IGUISkin* skin = guienv->getSkin (); + return wrap_gui_skin (skin); + } + + SCM + irr_gui_IGUIEnvironment_addButton (SCM wrapped_gui_environment, + SCM rectangle, + SCM rest) + { + SCM parent = SCM_UNDEFINED; + SCM id = scm_from_int32 (-1); + SCM text = SCM_UNDEFINED; + SCM tooltiptext = SCM_UNDEFINED; + + scm_c_bind_keyword_arguments ("add-button!", rest, (scm_t_keyword_arguments_flags)0, + scm_from_utf8_keyword ("parent"), &parent, + scm_from_utf8_keyword ("id"), &id, + scm_from_utf8_keyword ("text"), &text, + scm_from_utf8_keyword ("tooltiptext"), &tooltiptext, + SCM_UNDEFINED); + + irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment); + irr::gui::IGUIButton* button = + guienv->addButton (scm_to_rect_s32 (rectangle), + parent == SCM_UNDEFINED ? 0 : unwrap_gui_element (parent), + scm_to_int32 (id), + text == SCM_UNDEFINED ? 0 : scm_to_wide_char_string (text), + tooltiptext == SCM_UNDEFINED ? 0 : scm_to_wide_char_string (tooltiptext)); + return wrap_gui_button (button); + } + + SCM + irr_gui_IGUIEnvironment_getFont (SCM wrapped_gui_environment, + SCM filename) + { + irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment); + irr::gui::IGUIFont* font = guienv->getFont (scm_to_utf8_stringn (filename, NULL)); + return wrap_gui_font (font); + } + }