]> git.jsancho.org Git - guile-irrlicht.git/blob - src/gui-environment.cpp
set-skin-font! get-built-in-font
[guile-irrlicht.git] / src / gui-environment.cpp
1 /* guile-irrlicht --- GNU Guile bindings for Irrlicht Engine
2
3    Copyright (C) 2020 Javier Sancho <jsf@jsancho.org>
4
5    This file is part of guile-irrlicht.
6
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.
11
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.
16
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/>.
20 */
21
22 #include <irrlicht/irrlicht.h>
23 #include <libguile.h>
24
25 #include "device.h"
26 #include "gsubr.h"
27 #include "gui-element.h"
28 #include "gui-environment.h"
29 #include "gui-font.h"
30 #include "gui-image.h"
31 #include "gui-skin.h"
32 #include "gui-static-text.h"
33 #include "position2d.h"
34 #include "rect.h"
35 #include "texture.h"
36 #include "wchar.h"
37 #include "wrapped.h"
38
39 extern "C" {
40
41   void
42   init_gui_environment (void)
43   {
44     init_gui_environment_type ();
45     DEFINE_GSUBR ("add-image!", 3, 0, 1, irr_gui_addImage);
46     DEFINE_GSUBR ("add-static-text!", 3, 0, 1, irr_gui_addStaticText);
47     DEFINE_GSUBR ("get-built-in-font", 1, 0, 0, irr_gui_getBuiltInFont);
48     DEFINE_GSUBR ("get-font", 2, 0, 0, irr_gui_getFont);
49     DEFINE_GSUBR ("get-gui-environment", 1, 0, 0, irr_getGUIEnvironment);
50     DEFINE_GSUBR ("get-skin", 1, 0, 0, irr_gui_getSkin);
51   }
52
53   DEFINE_WRAPPED_TYPE (irr::gui::IGUIEnvironment*, "gui-environment",
54                        init_gui_environment_type, gui_environment_p,
55                        wrap_gui_environment, unwrap_gui_environment);
56
57   SCM
58   irr_getGUIEnvironment (SCM wrapped_obj)
59   {
60     irr::gui::IGUIEnvironment* gui_environment;
61     if (device_p (wrapped_obj))
62       {
63         gui_environment = unwrap_device (wrapped_obj)->getGUIEnvironment ();
64       }
65     else
66       {
67         scm_error (scm_arg_type_key, NULL, "Cannot get GUI environment from object: ~S",
68                    scm_list_1 (wrapped_obj), scm_list_1 (wrapped_obj));
69       }
70     return wrap_gui_environment (gui_environment);
71   }
72
73   SCM
74   irr_gui_addImage (SCM wrapped_gui_environment,
75                     SCM image,
76                     SCM position,
77                     SCM rest)
78   {
79     SCM use_alpha_channel = SCM_BOOL_T;
80     SCM parent = SCM_BOOL_F;
81     SCM id = scm_from_int32 (-1);
82     SCM text = SCM_BOOL_F;
83
84     scm_c_bind_keyword_arguments ("add-image!", rest, (scm_t_keyword_arguments_flags)0,
85                                   scm_from_utf8_keyword ("use_alpha_channel"), &use_alpha_channel,
86                                   scm_from_utf8_keyword ("parent"), &parent,
87                                   scm_from_utf8_keyword ("id"), &id,
88                                   scm_from_utf8_keyword ("text"), &text,
89                                   SCM_UNDEFINED);
90
91     irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment);
92     irr::gui::IGUIImage* guiImage =
93       guienv->addImage (unwrap_texture (image),
94                         scm_to_position2d_s32 (position),
95                         scm_to_bool (use_alpha_channel),
96                         scm_is_false (parent) ? 0 : unwrap_gui_element (parent),
97                         scm_to_int32 (id),
98                         scm_is_false (text) ? 0 : scm_to_wide_char_string (text));
99     return wrap_gui_image (guiImage);
100   }
101
102   SCM
103   irr_gui_addStaticText (SCM wrapped_gui_environment,
104                          SCM text,
105                          SCM rectangle,
106                          SCM rest)
107   {
108     SCM border = SCM_BOOL_F;
109     SCM word_wrap = SCM_BOOL_T;
110     SCM parent = SCM_BOOL_F;
111     SCM id = scm_from_int32 (-1);
112     SCM fill_background = SCM_BOOL_F;
113
114     scm_c_bind_keyword_arguments ("add-static-text!", rest, (scm_t_keyword_arguments_flags)0,
115                                   scm_from_utf8_keyword ("border"), &border,
116                                   scm_from_utf8_keyword ("word-wrap"), &word_wrap,
117                                   scm_from_utf8_keyword ("parent"), &parent,
118                                   scm_from_utf8_keyword ("id"), &id,
119                                   scm_from_utf8_keyword ("fill-background"), &fill_background,
120                                   SCM_UNDEFINED);
121
122     irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment);
123     irr::gui::IGUIStaticText* staticText =
124       guienv->addStaticText (scm_to_wide_char_string (text),
125                              scm_to_rect_s32 (rectangle),
126                              scm_to_bool (border),
127                              scm_to_bool (word_wrap),
128                              scm_is_false (parent) ? 0 : unwrap_gui_element (parent),
129                              scm_to_int32 (id),
130                              scm_to_bool (fill_background));
131     return wrap_gui_static_text (staticText);
132   }
133
134   SCM
135   irr_gui_getBuiltInFont (SCM wrapped_gui_environment)
136   {
137     irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment);
138     irr::gui::IGUIFont* font = guienv->getBuiltInFont ();
139     return wrap_gui_font (font);
140   }
141
142   SCM
143   irr_gui_getFont (SCM wrapped_gui_environment,
144                    SCM filename)
145   {
146     irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment);
147     irr::gui::IGUIFont* font = guienv->getFont (scm_to_utf8_stringn (filename, NULL));
148     return wrap_gui_font (font);
149   }
150
151   SCM
152   irr_gui_getSkin (SCM wrapped_gui_environment)
153   {
154     irr::gui::IGUIEnvironment* guienv = unwrap_gui_environment (wrapped_gui_environment);
155     irr::gui::IGUISkin* skin = guienv->getSkin ();
156     return wrap_gui_skin (skin);
157   }
158
159 }