]> git.jsancho.org Git - guile-irrlicht.git/blob - irrlicht/gui.scm
7d1819e021712f7fb94fbf9aa9123880cef1b5a9
[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 (export <gui-element>)
46
47
48 ;; IGUIEnvironment
49 (define-class <gui-environment> (<reference-counted>)
50   (irr-class #:init-value "IGUIEnvironment"))
51
52 (define-method (add-button! (gui-environment <gui-environment>) rectangle . rest)
53   (let-keywords rest #f
54         ((parent (make <gui-element>))
55          (id -1)
56          (text "")
57          (tooltiptext ""))
58     (let ((addButton (get-irrlicht-proc "addButton" gui-environment parent)))
59       (addButton gui-environment rectangle parent id text tooltiptext))))
60
61 (define-method (add-editbox! (gui-environment <gui-environment>) text rectangle . rest)
62   (let-keywords rest #f
63         ((border #t)
64          (parent (make <gui-element>))
65          (id -1))
66     (let ((addEditBox (get-irrlicht-proc "addEditBox" gui-environment parent)))
67       (addEditBox gui-environment text rectangle border parent id))))
68
69 (define-method (add-image! (gui-environment <gui-environment>) image pos . rest)
70   (let-keywords rest #f
71         ((use-alpha-channel #t)
72          (parent (make <gui-element>))
73          (id -1)
74          (text ""))
75     (let ((addImage (get-irrlicht-proc "addImage" gui-environment parent)))
76       (addImage gui-environment image pos use-alpha-channel parent id text))))
77
78 (define-method (add-listbox! (gui-environment <gui-environment>) rectangle . rest)
79   (let-keywords rest #f
80         ((parent (make <gui-element>))
81          (id -1)
82          (draw-background #f))
83     (let ((addListBox (get-irrlicht-proc "addListBox" gui-environment parent)))
84       (addListBox gui-environment rectangle parent id draw-background))))
85
86 (define-method (add-scrollbar! (gui-environment <gui-environment>) horizontal rectangle . rest)
87   (let-keywords rest #f
88         ((parent (make <gui-element>))
89          (id -1))
90     (let ((addScrollBar (get-irrlicht-proc "addScrollBar" gui-environment parent)))
91       (addScrollBar gui-environment horizontal rectangle parent id))))
92
93 (define-method (add-static-text! (gui-environment <gui-environment>) text rectangle . rest)
94   (let-keywords rest #f
95         ((border #f)
96          (word-wrap #t)
97          (parent (make <gui-element>))
98          (id -1)
99          (fill-background #f))
100     (let ((addStaticText (get-irrlicht-proc "addStaticText" gui-environment parent)))
101       (addStaticText gui-environment text rectangle border word-wrap parent
102                      id fill-background))))
103
104 (define-method (draw-all (gui-environment <gui-environment>))
105   ((get-irrlicht-proc "drawAll" gui-environment)
106    gui-environment))
107
108 (define-method (get-built-in-font (gui-environment <gui-environment>))
109   (let ((getBuiltInFont (get-irrlicht-proc "getBuiltInFont" gui-environment)))
110     (getBuiltInFont gui-environment)))
111
112 (define-method (get-font (gui-environment <gui-environment>) filename)
113   (let ((getFont (get-irrlicht-proc "getFont" gui-environment)))
114     (getFont gui-environment filename)))
115
116 (define-method (get-skin (gui-environment <gui-environment>))
117   (let ((getSkin (get-irrlicht-proc "getSkin" gui-environment)))
118     (getSkin gui-environment)))
119
120 (export <gui-environment> add-button! add-editbox! add-image! add-listbox! add-scrollbar!
121         add-static-text! draw-all get-built-in-font get-font get-skin)
122
123
124 ;; IGUIStaticText
125 (define-class <gui-static-text> (<gui-element>)
126   (irr-class #:init-value "IGUIStaticText"))
127
128 (define-method (set-override-color! (static-text <gui-static-text>) color)
129   (let ((setOverrideColor (get-irrlicht-proc "setOverrideColor" static-text)))
130     (setOverrideColor static-text color)))
131
132 (export <gui-static-text> set-override-color!)
133
134
135 ;; IGUIImage
136 (define-class <gui-image> (<gui-element>)
137   (irr-class #:init-value "IGUIImage"))
138
139 (export <gui-image>)
140
141
142 ;; IGUISkin
143 (define-class <gui-skin> (<attribute-exchanging-object>)
144   (irr-class #:init-value "IGUISkin"))
145
146 (define-method (get-color (skin <gui-skin>) color)
147   (let ((getColor (get-irrlicht-proc "getColor" skin)))
148     (getColor skin color)))
149
150 (define-method (set-font! (skin <gui-skin>) font . rest)
151   (let-keywords rest #f
152         ((which 'default))
153     (let ((setFont (get-irrlicht-proc "setFont" skin)))
154       (setFont skin font which))))
155
156 (define-method (set-color! (skin <gui-skin>) which new-color)
157   (let ((setColor (get-irrlicht-proc "setColor" skin)))
158     (setColor skin which new-color)))
159
160 (export <gui-skin> get-color set-font! set-color!)
161
162
163 ;; IGUIFont
164 (define-class <gui-font> (<reference-counted>)
165   (irr-class #:init-value "IGUIFont"))
166
167 (export <gui-font>)
168
169
170 ;; IGUIButton
171 (define-class <gui-button> (<gui-element>)
172   (irr-class #:init-value "IGUIButton"))
173
174 (export <gui-button>)
175
176
177 ;; IGUIScrollBar
178 (define-class <gui-scrollbar> (<gui-element>)
179   (irr-class #:init-value "IGUIScrollBar"))
180
181 (define-method (get-position (scrollbar <gui-scrollbar>))
182   (let ((getPos (get-irrlicht-proc "getPos" scrollbar)))
183     (getPos scrollbar)))
184
185 (define-method (set-max! (scrollbar <gui-scrollbar>) max)
186   (let ((setMax (get-irrlicht-proc "setMax" scrollbar)))
187     (setMax scrollbar max)))
188
189 (define-method (set-position! (scrollbar <gui-scrollbar>) pos)
190   (let ((setPos (get-irrlicht-proc "setPos" scrollbar)))
191     (setPos scrollbar pos)))
192
193 (export <gui-scrollbar> get-position set-max! set-position!)
194
195
196 ;; IGUIListBox
197 (define-class <gui-listbox> (<gui-element>)
198   (irr-class #:init-value "IGUIListBox"))
199
200 (export <gui-listbox>)
201
202
203 ;; IGUIEditBox
204 (define-class <gui-editbox> (<gui-element>)
205   (irr-class #:init-value "IGUIEditBox"))
206
207 (export <gui-editbox>)