blob: bb3f6ab105618017546458f91644f4e58e91291e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
(use-modules (figl gl)
(srfi srfi-1)
(srfi srfi-9)
(srfi srfi-42)
(ice-9 format)
(2d sprite)
(2d game-loop)
(2d window)
(2d vector)
(2d input)
(2d helpers)
(2d agenda)
(2d coroutine))
(init-2d)
(define window-width 800)
(define window-height 600)
(define sprite #f)
(define (key-down key mod unicode)
(cond ((any-equal? key (keycode escape) (keycode q))
(close-window)
(quit))))
;; Draw our sprite
(define (render)
(draw-sprite sprite))
;; Register callbacks.
(set-render-callback (lambda () (render)))
(set-key-down-callback (lambda (key mod unicode) (key-down key mod unicode)))
;; Open the window.
(open-window window-width window-height)
;; Load a sprite and center it on the screen.
(set! sprite (load-sprite "images/sprite.png" #:position (vector (/ window-width 2)
(/ window-height 2))))
;; Simple script that moves the sprite to a random location every
;; second.
(agenda-schedule
(colambda ()
(while #t
(set-sprite-position! sprite (vector (random window-width)
(random window-height)))
(wait 60))))
(run-game-loop)
|