]> git.jsancho.org Git - guile-irrlicht.git/blob - irrlicht/video.scm
is-window-active?
[guile-irrlicht.git] / irrlicht / video.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 video)
22   #:use-module (oop goops)
23   #:use-module (ice-9 optargs)
24   #:use-module (irrlicht base)
25   #:use-module (irrlicht foreign))
26
27
28 ;; ITexture
29 (define-class <texture> (<irrlicht-base>)
30   (irr-class #:init-value "ITexture"))
31
32 (export <texture>)
33
34
35 ;; IVideoDriver
36 (define-class <video-driver> (<irrlicht-base>)
37   (irr-class #:init-value "IVideoDriver"))
38
39 (define-method (begin-scene (video-driver <video-driver>) . rest)
40   (let-keywords rest #f
41         ((back-buffer #t)
42          (z-buffer #t)
43          (color '(255 0 0 0))
44          video-data
45          source-rect)
46     ((get-irrlicht-proc "beginScene" video-driver)
47      video-driver
48      back-buffer
49      z-buffer
50      color
51      video-data
52      source-rect)))
53
54 (define-method (end-scene (video-driver <video-driver>))
55   ((get-irrlicht-proc "endScene" video-driver)
56    video-driver))
57
58 (define-method (get-name (video-driver <video-driver>))
59   (let ((getName (get-irrlicht-proc "getName" video-driver)))
60     (getName video-driver)))
61
62 (define-method (get-texture (video-driver <video-driver>) filename)
63   (make <texture>
64     #:irr-pointer
65     ((get-irrlicht-proc "getTexture" video-driver)
66      video-driver
67      filename)))
68
69 (export <video-driver> begin-scene end-scene get-name get-texture)