]> git.jsancho.org Git - gacela.git/blobdiff - src/video.scm
Improved cache system for resources and more things.
[gacela.git] / src / video.scm
index 11ce6995637f98c313940ef0838a04ac9635ae65..466438f1db06b050740e6c0addb08d2228fba193 100644 (file)
@@ -20,6 +20,7 @@
   #:use-module (gacela gl)
   #:use-module (gacela ftgl)
   #:use-module (gacela math)
+  #:use-module (gacela utils)
   #:use-module (ice-9 optargs)
   #:use-module (ice-9 receive)
   #:export (init-video
@@ -47,6 +48,7 @@
            progn-textures
            draw
            load-texture
+           load-texture-without-cache
            get-texture-properties
            draw-texture
            draw-line
@@ -61,6 +63,7 @@
            set-camera
            camera-look
            load-font
+           load-font-without-texture
            render-text)
   #:export-syntax (glmatrix-block))
 
          (else (let ((zoomx (/ (+ width 0.5) old-width)) (zoomy (/ (+ height 0.5) old-height)))
               (zoomSurface surface zoomx zoomy 0))))))
 
-(define* (load-texture filename #:key (min-filter GL_LINEAR) (mag-filter GL_LINEAR))
+(define* (load-texture-without-cache filename #:key (min-filter GL_LINEAR) (mag-filter GL_LINEAR))
   (progn-textures
    (receive
     (image real-w real-h) (load-image-for-texture filename)
             (set-texture-size! texture real-w real-h)
             texture))))))
 
+(define load-texture (use-cache-with load-texture-without-cache))
+
 (define (get-texture-properties texture)
   `((width . ,(texture-w texture)) (height . ,(texture-h texture))))
 
 
 ;;; Text and fonts
 
-(define* (load-font font-file #:key (size 40) (encoding ft_encoding_unicode))
+(define* (load-font-without-cache font-file #:key (size 40) (encoding ft_encoding_unicode))
   (let ((font (ftglCreateTextureFont font-file size)))
     (ftglSetFontFaceSize font size 72)
     (ftglSetFontCharMap font encoding)
     font))
 
+(define load-font (use-cache-with load-font-without-cache))
+
 (define* (render-text text font #:key (size #f))
   (cond (size
         (cond ((not (= (ftglGetFontFaceSize font) size))