X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=irrlicht%2Fvideo.scm;h=5659276c57bd432f90fc69c5926af973b0c28265;hb=09e9ed196aadab0f77e831c134fce8bdb58b772b;hp=1df01fe47a04d9bd251f77455fafaa90d808893c;hpb=cc03ee884302dfeb94b5da68dd2b618c41333d5c;p=guile-irrlicht.git diff --git a/irrlicht/video.scm b/irrlicht/video.scm index 1df01fe..5659276 100644 --- a/irrlicht/video.scm +++ b/irrlicht/video.scm @@ -1,5 +1,5 @@ ;;; guile-irrlicht --- FFI bindings for Irrlicht Engine -;;; Copyright (C) 2019 Javier Sancho +;;; Copyright (C) 2020 Javier Sancho ;;; ;;; This file is part of guile-irrlicht. ;;; @@ -19,102 +19,51 @@ (define-module (irrlicht video) - #:use-module (system foreign) - #:use-module ((irrlicht bindings core) #:prefix ffi-core:) - #:use-module ((irrlicht bindings video) #:prefix ffi-video:) - #:use-module (irrlicht util) - #:use-module (irrlicht util foreign) - #:export (begin-scene - end-scene - get-fps - get-texture - get-video-driver-name - set-material! - make-s3dvertex - vertex-position - make-material)) + #:use-module (oop goops) + #:use-module (ice-9 optargs) + #:use-module (irrlicht base) + #:use-module (irrlicht foreign)) -(define* (begin-scene driver - #:key - (back-buffer #t) - (z-buffer #t) - (color '(255 0 0 0)) - (video-data %null-pointer) - (source-rect '())) - (ffi-video:begin-scene driver - (bool->integer back-buffer) - (bool->integer z-buffer) - (ffi-video:scolor->pointer color) - video-data - (if (null? source-rect) - %null-pointer - (ffi-core:rect->pointer source-rect)))) -(define (end-scene driver) - (ffi-video:end-scene driver)) +;; ITexture +(define-class () + (irr-class #:init-value "ITexture" #:getter irr-class)) -(define (get-fps driver) - (ffi-video:get-fps driver)) +(export ) -(define (get-texture driver filename) - (ffi-video:get-texture driver (string->pointer filename))) -(define (get-video-driver-name driver) - (pointer->string - (ffi-video:get-video-driver-name driver))) +;; IVideoDriver +(define-class () + (irr-class #:init-value "IVideoDriver" #:getter irr-class)) -(define (set-material! driver material) - (ffi-video:set-material - driver - (ffi-video:smaterial->pointer material))) +(define-method (begin-scene (video-driver ) . rest) + (let-keywords rest #f + ((back-buffer #t) + (z-buffer #t) + (color '(255 0 0 0)) + video-data + source-rect) + ((get-irrlicht-proc "beginScene" video-driver) + video-driver + back-buffer + z-buffer + color + video-data + source-rect))) -;; s3d vertices -(define (make-s3dvertex position normal color t-coords) - (ffi-video:pointer->s3dvertex - (make-c-struct ffi-video:s3dvertex - (list position normal color t-coords)))) +(define-method (end-scene (video-driver )) + ((get-irrlicht-proc "endScene" video-driver) + video-driver)) -(define (vertex-position vertex) - (let ((data (parse-c-struct (ffi-video:s3dvertex->pointer vertex) - ffi-video:s3dvertex))) - (car data))) +(define-method (get-name (video-driver )) + (let ((getName (get-irrlicht-proc "getName" video-driver))) + (getName video-driver))) -;; smaterial -(define* (make-material #:key (wireframe #f) (lighting #t)) - (let ((material - (list - ;; textureLayer[4] - (list %null-pointer 0 0 0 0 0 0 %null-pointer %null-pointer) - (list %null-pointer 0 0 0 0 0 0 %null-pointer %null-pointer) - (list %null-pointer 0 0 0 0 0 0 %null-pointer %null-pointer) - (list %null-pointer 0 0 0 0 0 0 %null-pointer %null-pointer) - ffi-video:EMT_SOLID ; materialType - (list 255 255 255 255) ; ambientColor - (list 255 255 255 255) ; diffuseColor - (list 0 0 0 0) ; emissiveColor - (list 255 255 255 255) ; specularColor - 0 ; shininess - 0 ; materialTypeParam - 0 ; materialTypeParam2 - 1 ; thickness - ffi-video:ECFN_LESSEQUAL ; zBuffer - ffi-video:EAAM_SIMPLE ; antiAliasing - (list - ffi-video:ECP_ALL ; colorMask - ffi-video:ECM_DIFFUSE ; colorMaterial - ffi-video:EBO_NONE ; blendOperation - 0 ; polygonOffsetFactor - ffi-video:EPO_FRONT ; polygonOffsetDirection - (bool->integer wireframe) ; wireframe - (bool->integer #f) ; pointCloud - (bool->integer #t) ; gouraudShading - (bool->integer lighting) ; lighting - (bool->integer #t) ; zWriteEnable - (bool->integer #t) ; backfaceCulling - (bool->integer #f) ; frontfaceCulling - (bool->integer #f) ; fogEnable - (bool->integer #f) ; normalizeNormals - (bool->integer #t) ; useMipMaps - )))) - (ffi-video:pointer->smaterial - (make-c-struct+ ffi-video:smaterial material)))) +(define-method (get-texture (video-driver ) filename) + (make + #:irr-pointer + ((get-irrlicht-proc "getTexture" video-driver) + video-driver + filename))) + +(export begin-scene end-scene get-name get-texture)