]> git.jsancho.org Git - guile-irrlicht.git/blob - irrlicht/video.scm
SMaterial and vertices
[guile-irrlicht.git] / irrlicht / video.scm
1 ;;; guile-irrlicht --- FFI bindings for Irrlicht Engine
2 ;;; Copyright (C) 2019 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 (system foreign)
23   #:use-module ((irrlicht bindings core) #:prefix ffi-core:)
24   #:use-module ((irrlicht bindings video) #:prefix ffi-video:)
25   #:use-module (irrlicht util)
26   #:use-module (irrlicht util foreign)
27   #:export (begin-scene
28             end-scene
29             get-fps
30             get-texture
31             get-video-driver-name
32             make-s3dvertex
33             vertex-position
34             make-material))
35
36 (define* (begin-scene driver
37                       #:key
38                       (back-buffer #t)
39                       (z-buffer #t)
40                       (color '(255 0 0 0))
41                       (video-data %null-pointer)
42                       (source-rect '()))
43   (ffi-video:begin-scene driver
44                          (bool->integer back-buffer)
45                          (bool->integer z-buffer)
46                          (ffi-video:scolor->pointer color)
47                          video-data
48                          (if (null? source-rect)
49                              %null-pointer
50                              (ffi-core:rect->pointer source-rect))))
51
52 (define (end-scene driver)
53   (ffi-video:end-scene driver))
54
55 (define (get-fps driver)
56   (ffi-video:get-fps driver))
57
58 (define (get-texture driver filename)
59   (ffi-video:get-texture driver (string->pointer filename)))
60
61 (define (get-video-driver-name driver)
62   (pointer->string
63    (ffi-video:get-video-driver-name driver)))
64
65 ;; s3d vertices
66 (define (make-s3dvertex position normal color t-coords)
67   (ffi-video:pointer->s3dvertex
68    (make-c-struct ffi-video:s3dvertex
69                   (list position normal color t-coords))))
70
71 (define (vertex-position vertex)
72   (let ((data (parse-c-struct (ffi-video:s3dvertex->pointer vertex)
73                               ffi-video:s3dvertex)))
74     (car data)))
75
76 ;; smaterial
77 (define* (make-material #:key (wireframe #f) (lighting #t))
78   (let ((material
79          (list
80           ;; textureLayer[4]
81           (list %null-pointer 0 0 0 0 0 0 %null-pointer %null-pointer)
82           (list %null-pointer 0 0 0 0 0 0 %null-pointer %null-pointer)
83           (list %null-pointer 0 0 0 0 0 0 %null-pointer %null-pointer)
84           (list %null-pointer 0 0 0 0 0 0 %null-pointer %null-pointer)
85           ffi-video:EMT_SOLID         ; materialType
86           (list 255 255 255 255)      ; ambientColor
87           (list 255 255 255 255)      ; diffuseColor
88           (list 0 0 0 0)              ; emissiveColor
89           (list 255 255 255 255)      ; specularColor
90           0                           ; shininess
91           0                           ; materialTypeParam
92           0                           ; materialTypeParam2
93           1                           ; thickness
94           ffi-video:ECFN_LESSEQUAL    ; zBuffer
95           ffi-video:EAAM_SIMPLE       ; antiAliasing
96           (list
97            ffi-video:ECP_ALL          ; colorMask
98            ffi-video:ECM_DIFFUSE      ; colorMaterial
99            ffi-video:EBO_NONE         ; blendOperation
100            0                          ; polygonOffsetFactor
101            ffi-video:EPO_FRONT        ; polygonOffsetDirection
102            (bool->integer wireframe)  ; wireframe
103            (bool->integer #f)         ; pointCloud
104            (bool->integer #t)         ; gouraudShading
105            (bool->integer lighting)   ; lighting
106            (bool->integer #t)         ; zWriteEnable
107            (bool->integer #t)         ; backfaceCulling
108            (bool->integer #f)         ; frontfaceCulling
109            (bool->integer #f)         ; fogEnable
110            (bool->integer #f)         ; normalizeNormals
111            (bool->integer #t)         ; useMipMaps
112            ))))
113     (ffi-video:pointer->smaterial
114      (make-c-struct+ ffi-video:smaterial material))))