]> git.jsancho.org Git - guile-irrlicht.git/blob - irrlicht/gui.scm
Some doc
[guile-irrlicht.git] / irrlicht / gui.scm
1 ;;; guile-irrlicht --- FFI bindings for Irrlicht Engine
2 ;;; Copyright (C) 2020 Javier Sancho <jsf@jsancho.org>
3 ;;;
4 ;;; This file is part of guile-irrlicht.
5 ;;;
6 ;;; Guile-irrlicht is free software; you can redistribute it and/or modify
7 ;;; it under the terms of the GNU Lesser General Public License as
8 ;;; published by the Free Software Foundation; either version 3 of the
9 ;;; License, or (at your option) any later version.
10 ;;;
11 ;;; Guile-irrlicht is distributed in the hope that it will be useful, but
12 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
13 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 ;;; General Public License for more details.
15 ;;;
16 ;;; You should have received a copy of the GNU Lesser General Public
17 ;;; License along with guile-irrlicht.  If not, see
18 ;;; <http://www.gnu.org/licenses/>.
19
20
21 (define-module (irrlicht gui)
22   #:use-module (oop goops)
23   #:use-module (ice-9 optargs)
24   #:use-module (irrlicht base)
25   #:use-module (irrlicht foreign)
26   #:use-module ((irrlicht io) #:select (<attribute-exchanging-object>))
27   #:use-module ((irrlicht irr) #:select (<event-receiver> <reference-counted>)))
28
29
30 ;; ICursorControl
31 (define-class <cursor-control> (<reference-counted>)
32   (irr-class #:init-value "ICursorControl"))
33
34 (define-method (set-visible! (cursor-control <cursor-control>) visible)
35   (let ((setVisible (get-irrlicht-proc "setVisible" cursor-control)))
36     (setVisible cursor-control visible)))
37
38 (export <cursor-control> set-visible!)
39
40
41 ;; IGUIElement
42 (define-class <gui-element> (<attribute-exchanging-object> <event-receiver>)
43   (irr-class #:init-value "IGUIElement"))
44
45 (define-method (get-id (element <gui-element>))
46   (let ((getID (get-irrlicht-proc "getID" element)))
47     (getID element)))
48
49 (export <gui-element> get-id)
50
51
52 ;; IGUIEnvironment
53 (define-class <gui-environment> (<reference-counted>)
54   (irr-class #:init-value "IGUIEnvironment"))
55
56 (define-method (add-button! (gui-environment <gui-environment>) rectangle . rest)
57   (let-keywords rest #f
58         ((parent (make <gui-element>))
59          (id -1)
60          (text "")
61          (tooltiptext ""))
62     (let* ((addButton (get-irrlicht-proc "addButton" gui-environment parent))
63            (button (addButton gui-environment rectangle parent id text tooltiptext)))
64       (mem-wrapped button))))
65
66 (define-method (add-editbox! (gui-environment <gui-environment>) text rectangle . rest)
67   (let-keywords rest #f
68         ((border #t)
69          (parent (make <gui-element>))
70          (id -1))
71     (let* ((addEditBox (get-irrlicht-proc "addEditBox" gui-environment parent))
72            (editbox (addEditBox gui-environment text rectangle border parent id)))
73       (mem-wrapped editbox))))
74
75 (define-method (add-file-open-dialog! (gui-environment <gui-environment>) . rest)
76   (let-keywords rest #f
77         ((title "")
78          (modal #t)
79          (parent (make <gui-element>))
80          (id -1)
81          (restore-cwd #f)
82          (start-dir ""))
83     (let* ((addFileOpenDialog (get-irrlicht-proc "addFileOpenDialog" gui-environment parent))
84            (dialog (addFileOpenDialog gui-environment title modal parent id restore-cwd start-dir)))
85       (mem-wrapped dialog))))
86
87 (define-method (add-image! (gui-environment <gui-environment>) image pos . rest)
88   (let-keywords rest #f
89         ((use-alpha-channel #t)
90          (parent (make <gui-element>))
91          (id -1)
92          (text ""))
93     (let* ((addImage (get-irrlicht-proc "addImage" gui-environment parent))
94            (img (addImage gui-environment image pos use-alpha-channel parent id text)))
95       (mem-wrapped img))))
96
97 (define-method (add-listbox! (gui-environment <gui-environment>) rectangle . rest)
98   (let-keywords rest #f
99         ((parent (make <gui-element>))
100          (id -1)
101          (draw-background #f))
102     (let* ((addListBox (get-irrlicht-proc "addListBox" gui-environment parent))
103            (listbox (addListBox gui-environment rectangle parent id draw-background)))
104       (mem-wrapped listbox))))
105
106 (define-method (add-scrollbar! (gui-environment <gui-environment>) horizontal rectangle . rest)
107   (let-keywords rest #f
108         ((parent (make <gui-element>))
109          (id -1))
110     (let* ((addScrollBar (get-irrlicht-proc "addScrollBar" gui-environment parent))
111            (scrollbar (addScrollBar gui-environment horizontal rectangle parent id)))
112       (mem-wrapped scrollbar))))
113
114 (define-method (add-static-text! (gui-environment <gui-environment>) text rectangle . rest)
115   (let-keywords rest #f
116         ((border #f)
117          (word-wrap #t)
118          (parent (make <gui-element>))
119          (id -1)
120          (fill-background #f))
121     (let* ((addStaticText (get-irrlicht-proc "addStaticText" gui-environment parent))
122            (static-text (addStaticText gui-environment text rectangle border word-wrap parent
123                                        id fill-background)))
124       (mem-wrapped static-text))))
125
126 (define-method (add-window! (gui-environment <gui-environment>) rectangle . rest)
127   (let-keywords rest #f
128         ((modal #f)
129          (text "")
130          (parent (make <gui-element>))
131          (id -1))
132     (let* ((addWindow (get-irrlicht-proc "addWindow" gui-environment parent))
133            (window (addWindow gui-environment rectangle modal text parent id)))
134       (mem-wrapped window))))
135
136 (define-method (draw-all (gui-environment <gui-environment>))
137   ((get-irrlicht-proc "drawAll" gui-environment)
138    gui-environment))
139
140 (define-method (get-built-in-font (gui-environment <gui-environment>))
141   (let ((getBuiltInFont (get-irrlicht-proc "getBuiltInFont" gui-environment)))
142     (getBuiltInFont gui-environment)))
143
144 (define-method (get-font (gui-environment <gui-environment>) filename)
145   (let* ((getFont (get-irrlicht-proc "getFont" gui-environment))
146          (font (getFont gui-environment filename)))
147     (if (null-object? font)
148         (error "In procedure get-font: Font unavailable")
149         font)))
150
151 (define-method (get-skin (gui-environment <gui-environment>))
152   (let ((getSkin (get-irrlicht-proc "getSkin" gui-environment)))
153     (getSkin gui-environment)))
154
155 (export <gui-environment> add-button! add-editbox! add-file-open-dialog! add-image! add-listbox!
156         add-scrollbar! add-static-text! add-window! draw-all get-built-in-font get-font get-skin)
157
158
159 ;; IGUIStaticText
160 (define-class <gui-static-text> (<gui-element>)
161   (irr-class #:init-value "IGUIStaticText"))
162
163 (define-method (set-override-color! (static-text <gui-static-text>) color)
164   (let ((setOverrideColor (get-irrlicht-proc "setOverrideColor" static-text)))
165     (setOverrideColor static-text color)))
166
167 (export <gui-static-text> set-override-color!)
168
169
170 ;; IGUIImage
171 (define-class <gui-image> (<gui-element>)
172   (irr-class #:init-value "IGUIImage"))
173
174 (export <gui-image>)
175
176
177 ;; IGUISkin
178 (define-class <gui-skin> (<attribute-exchanging-object>)
179   (irr-class #:init-value "IGUISkin"))
180
181 (define-method (get-color (skin <gui-skin>) color)
182   (let ((getColor (get-irrlicht-proc "getColor" skin)))
183     (getColor skin color)))
184
185 (define-method (set-font! (skin <gui-skin>) font . rest)
186   (let-keywords rest #f
187         ((which 'default))
188     (let ((setFont (get-irrlicht-proc "setFont" skin)))
189       (setFont skin font which))))
190
191 (define-method (set-color! (skin <gui-skin>) which new-color)
192   (let ((setColor (get-irrlicht-proc "setColor" skin)))
193     (setColor skin which new-color)))
194
195 (export <gui-skin> get-color set-font! set-color!)
196
197
198 ;; IGUIFont
199 (define-class <gui-font> (<reference-counted>)
200   (irr-class #:init-value "IGUIFont"))
201
202 (export <gui-font>)
203
204
205 ;; IGUIButton
206 (define-class <gui-button> (<gui-element>)
207   (irr-class #:init-value "IGUIButton"))
208
209 (export <gui-button>)
210
211
212 ;; IGUIScrollBar
213 (define-class <gui-scrollbar> (<gui-element>)
214   (irr-class #:init-value "IGUIScrollBar"))
215
216 (define-method (get-position (scrollbar <gui-scrollbar>))
217   (let ((getPos (get-irrlicht-proc "getPos" scrollbar)))
218     (getPos scrollbar)))
219
220 (define-method (set-max! (scrollbar <gui-scrollbar>) max)
221   (let ((setMax (get-irrlicht-proc "setMax" scrollbar)))
222     (setMax scrollbar max)))
223
224 (define-method (set-position! (scrollbar <gui-scrollbar>) pos)
225   (let ((setPos (get-irrlicht-proc "setPos" scrollbar)))
226     (setPos scrollbar pos)))
227
228 (export <gui-scrollbar> get-position set-max! set-position!)
229
230
231 ;; IGUIListBox
232 (define-class <gui-listbox> (<gui-element>)
233   (irr-class #:init-value "IGUIListBox"))
234
235 (define-method (add-item! (listbox <gui-listbox>) text)
236   (let ((addItem (get-irrlicht-proc "addItem" listbox)))
237     (addItem listbox text)))
238
239 (export <gui-listbox> add-item!)
240
241
242 ;; IGUIEditBox
243 (define-class <gui-editbox> (<gui-element>)
244   (irr-class #:init-value "IGUIEditBox"))
245
246 (export <gui-editbox>)
247
248
249 ;; IGUIWindow
250 (define-class <gui-window> (<gui-element>)
251   (irr-class #:init-value "IGUIWindow"))
252
253 (export <gui-window>)
254
255
256 ;; IGUIFileOpenDialog
257 (define-class <gui-file-open-dialog> (<gui-element>)
258   (irr-class #:init-value "IGUIFileOpenDialog"))
259
260 (define-method (get-file-name (dialog <gui-file-open-dialog>))
261   (let ((getFileName (get-irrlicht-proc "getFileName" dialog)))
262     (getFileName dialog)))
263
264 (export <gui-file-open-dialog> get-file-name)