1 /* guile-irrlicht --- GNU Guile bindings for Irrlicht Engine
3 Copyright (C) 2020 Javier Sancho <jsf@jsancho.org>
5 This file is part of guile-irrlicht.
7 guile-irrlicht is free software; you can redistribute it and/or modify
8 it under the terms of the GNU Lesser General Public License as
9 published by the Free Software Foundation; either version 3 of the
10 License, or (at your option) any later version.
12 guile-irrlicht is distributed in the hope that it will be useful, but
13 WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 General Public License for more details.
17 You should have received a copy of the GNU Lesser General Public
18 License along with guile-irrlicht. If not, see
19 <http://www.gnu.org/licenses/>.
22 #include <irrlicht/irrlicht.h>
28 #include "gui-button.h"
29 #include "gui-editbox.h"
30 #include "gui-element.h"
31 #include "gui-environment.h"
33 #include "gui-image.h"
34 #include "gui-in-out-fader.h"
35 #include "gui-listbox.h"
36 #include "gui-scrollbar.h"
38 #include "gui-static-text.h"
39 #include "gui-toolbar.h"
40 #include "gui-window.h"
51 init_gui_environment ();
54 init_gui_in_out_fader ();
56 init_gui_scrollbar ();
58 init_gui_static_text ();
62 // Shared procedures (used by two or more objects)
63 DEFINE_GSUBR ("add-button!", 1, 1, 1, irr_gui_addButton);
64 DEFINE_GSUBR ("get-color", 1, 1, 0, irr_gui_getColor);
65 DEFINE_GSUBR ("get-font", 1, 1, 1, irr_gui_getFont);
66 DEFINE_GSUBR ("set-color!", 2, 1, 0, irr_gui_setColor);
67 DEFINE_GSUBR ("set-max!", 2, 0, 0, irr_gui_setMax);
68 DEFINE_GSUBR ("set-override-color!", 2, 0, 0, irr_gui_setOverrideColor);
72 irr_gui_addButton (SCM wrapped_obj,
76 if (gui_toolbar_p (wrapped_obj))
78 return irr_gui_IGUIToolBar_addButton (wrapped_obj, rest);
80 else if (gui_environment_p (wrapped_obj))
82 return irr_gui_IGUIEnvironment_addButton (wrapped_obj, rectangle, rest);
86 scm_error (scm_arg_type_key, NULL, "Cannot add button to object: ~S",
87 scm_list_1 (wrapped_obj), scm_list_1 (wrapped_obj));
92 irr_gui_getColor (SCM wrapped_obj,
95 #define GET_COLOR(OBJ) scm_from_color (OBJ->getColor ());
97 if (gui_image_p (wrapped_obj))
99 return GET_COLOR (unwrap_gui_image (wrapped_obj));
101 else if (gui_in_out_fader_p (wrapped_obj))
103 return GET_COLOR (unwrap_gui_in_out_fader (wrapped_obj));
105 else if (gui_skin_p (wrapped_obj))
107 return irr_gui_IGUISkin_getColor (wrapped_obj, color);
111 scm_error (scm_arg_type_key, NULL, "Cannot get color from object: ~S",
112 scm_list_1 (wrapped_obj), scm_list_1 (wrapped_obj));
117 irr_gui_getFont (SCM wrapped_obj,
121 if (gui_environment_p (wrapped_obj))
123 return irr_gui_IGUIEnvironment_getFont (wrapped_obj, filename);
125 else if (gui_skin_p (wrapped_obj))
127 return irr_gui_IGUISkin_getFont (wrapped_obj, rest);
131 scm_error (scm_arg_type_key, NULL, "Cannot get font from object: ~S",
132 scm_list_1 (wrapped_obj), scm_list_1 (wrapped_obj));
137 irr_gui_setColor (SCM wrapped_obj,
141 if (gui_image_p (wrapped_obj))
144 unwrap_gui_image (wrapped_obj)->setColor (scm_to_color (color));
145 return SCM_UNSPECIFIED;
147 else if (gui_in_out_fader_p (wrapped_obj))
149 // Params: color and dest_color (optional)
150 return irr_gui_IGUIInOutFader_setColor (wrapped_obj, color, dest_color);
152 else if (gui_skin_p (wrapped_obj) && dest_color != SCM_UNDEFINED)
154 // Params: which and new_color
155 return irr_gui_IGUISkin_setColor (wrapped_obj, color, dest_color);
159 scm_error (scm_arg_type_key, NULL, "Cannot set color to object: ~S",
160 scm_list_1 (wrapped_obj), scm_list_1 (wrapped_obj));
165 irr_gui_setMax (SCM wrapped_obj,
168 #define SET_MAX(OBJ) OBJ->setMax (scm_to_int32 (max));
170 if (gui_editbox_p (wrapped_obj))
172 SET_MAX (unwrap_gui_editbox (wrapped_obj));
174 else if (gui_scrollbar_p (wrapped_obj))
176 SET_MAX (unwrap_gui_scrollbar (wrapped_obj));
180 scm_error (scm_arg_type_key, NULL, "Cannot set max to object: ~S",
181 scm_list_1 (wrapped_obj), scm_list_1 (wrapped_obj));
183 return SCM_UNSPECIFIED;
187 irr_gui_setOverrideColor (SCM wrapped_obj,
190 #define SET_OVERRIDE_COLOR(OBJ) OBJ->setOverrideColor (scm_to_color (color));
192 if (gui_editbox_p (wrapped_obj))
194 SET_OVERRIDE_COLOR (unwrap_gui_editbox (wrapped_obj));
196 else if (gui_static_text_p (wrapped_obj))
198 SET_OVERRIDE_COLOR (unwrap_gui_static_text (wrapped_obj));
202 scm_error (scm_arg_type_key, NULL, "Cannot set override color to object: ~S",
203 scm_list_1 (wrapped_obj), scm_list_1 (wrapped_obj));
205 return SCM_UNSPECIFIED;