X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=gacela%2Fimage.scm;h=2af2b4b732ab98685fe349488b4ecb0bcf01a749;hb=f5a68f317089a2b52f787322d5384b0afadeb7cd;hp=1fa861f09b440746c45c3a11d82dfa3d4352f3a1;hpb=8875fdf238b6ae7fa548937f103142def7b6c19f;p=gacela.git diff --git a/gacela/image.scm b/gacela/image.scm index 1fa861f..2af2b4b 100644 --- a/gacela/image.scm +++ b/gacela/image.scm @@ -23,13 +23,19 @@ #:use-module ((sdl2 render) #:prefix sdl2:) #:use-module ((sdl2 surface) #:prefix sdl2:) #:use-module (gl) - #:export (bitmap - move-xy - stretch)) + #:export (image + move + scale + over)) -(define (bitmap filename) +(define (calculate proc-or-value) + (if (procedure? proc-or-value) + (proc-or-value) + proc-or-value)) + +(define (image filename) (make-scene - "bitmap" + "image" (let ((image (sdl2:load-image filename)) (texture #f) (w/2 0) @@ -52,19 +58,28 @@ (gl-vertex (- w/2) (- h/2) 0)) (gl-disable (oes-framebuffer-object texture-2d)))))) -(define (move-xy x y scene) - (define (to-integer n) - (inexact->exact (round n))) +(define* (move scene x y #:optional (z 0)) (make-scene - "move-xy" + "move" (lambda () - (let ((xy (list (to-integer (if (procedure? x) (x) x)) - (to-integer (if (procedure? y) (y) y))))) - (display-scene scene #:xy xy))))) + (gl-translate (calculate x) + (calculate y) + (calculate z)) + (display-scene scene)))) -(define* (stretch scene x #:optional (y x) (z y)) +(define* (scale scene x #:optional (y x) (z y)) (make-scene - "stretch" + "scale" (lambda () (gl-scale x y z) (display-scene scene)))) + +(define (over . scenes) + (make-scene + "over" + (lambda () + (let display ((sc scenes)) + (cond ((not (null? sc)) + (with-gl-push-matrix + (display-scene (car sc))) + (display (cdr sc))))))))