1 ;;; guile-irrlicht --- FFI bindings for Irrlicht Engine
2 ;;; Copyright (C) 2020 Javier Sancho <jsf@jsancho.org>
4 ;;; This file is part of guile-irrlicht.
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.
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.
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/>.
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))
29 (define-class <texture> (<irrlicht-base>)
30 (irr-class #:init-value "ITexture"))
36 (define-class <video-driver> (<irrlicht-base>)
37 (irr-class #:init-value "IVideoDriver"))
39 (define-method (begin-scene (video-driver <video-driver>) . rest)
46 ((get-irrlicht-proc "beginScene" video-driver)
54 (define-method (end-scene (video-driver <video-driver>))
55 ((get-irrlicht-proc "endScene" video-driver)
58 (define-method (get-fps (video-driver <video-driver>))
59 (let ((getFPS (get-irrlicht-proc "getFPS" video-driver)))
60 (getFPS video-driver)))
62 (define-method (get-name (video-driver <video-driver>))
63 (let ((getName (get-irrlicht-proc "getName" video-driver)))
64 (getName video-driver)))
66 (define-method (get-texture (video-driver <video-driver>) filename)
69 ((get-irrlicht-proc "getTexture" video-driver)
73 (export <video-driver> begin-scene end-scene get-fps get-name get-texture)
77 (define-class <vertex3d> (<irrlicht-base>)
78 (irr-class #:init-value "S3DVertex"))
80 (define (make-vertex3d position normal color tcoords)
81 (let ((S3DVertex_make (get-irrlicht-proc "S3DVertex_make")))
84 (S3DVertex_make position normal color tcoords))))
86 (export <vertex3d> make-vertex3d)