summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Thompson <dthompson2@worcester.edu>2014-08-15 22:38:47 -0400
committerDavid Thompson <dthompson2@worcester.edu>2014-08-25 19:33:07 -0400
commitddc414fcdd8939fc04fd823bc72a198345dba67c (patch)
treef3ada46dad0da251baf47dca30c490ed3bebda86
parentf055cd55d1da639997ca13da1ad5e71a38034e83 (diff)
Render using scenes and cameras.
* sly/game.scm (start-game-loop): Add cameras parameter.
-rw-r--r--sly/game.scm14
1 files changed, 12 insertions, 2 deletions
diff --git a/sly/game.scm b/sly/game.scm
index ddfdd45..97a50e4 100644
--- a/sly/game.scm
+++ b/sly/game.scm
@@ -22,13 +22,17 @@
;;; Code:
(define-module (sly game)
+ #:use-module (srfi srfi-1)
#:use-module (srfi srfi-9)
#:use-module (srfi srfi-11)
+ #:use-module (srfi srfi-26)
#:use-module ((sdl sdl) #:prefix SDL:)
#:use-module (gl)
#:use-module (sly agenda)
+ #:use-module (sly camera)
#:use-module (sly event)
#:use-module (sly math)
+ #:use-module (sly scene)
#:use-module (sly signal)
#:use-module (sly vector)
#:use-module (sly window)
@@ -58,7 +62,8 @@ for the given STACK and error KEY with additional arguments ARGS."
(apply display-error (stack-ref stack 0) cep args)
(newline cep)))
-(define* (start-game-loop #:optional #:key
+(define* (start-game-loop cameras
+ #:optional #:key
(frame-rate 60)
(tick-rate 60)
(max-ticks-per-frame 4))
@@ -76,7 +81,8 @@ becoming completely unresponsive and possibly crashing."
(let ((size (signal-ref window-size)))
(gl-viewport 0 0 (vx size) (vy size)))
(gl-clear (clear-buffer-mask color-buffer depth-buffer))
- (run-hook draw-hook dt alpha)
+ (for-each (cut draw-camera <> alpha)
+ (signal-ref-maybe cameras))
(SDL:gl-swap-buffers))
(define (update lag)
@@ -87,6 +93,10 @@ unused accumulator time."
(cond ((>= ticks max-ticks-per-frame)
lag)
((>= lag tick-interval)
+ (for-each (cut update-scene-node <>)
+ (delete-duplicates
+ (map camera-scene (signal-ref-maybe cameras))
+ eq?))
(tick-agenda!)
(iter (- lag tick-interval) (1+ ticks)))
(else