summaryrefslogtreecommitdiff
path: root/examples/action.scm
blob: fa68dc017027b93b458f44e2036cd31fb6935233 (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
(use-modules (2d actions)
             (2d agenda)
             (2d coroutine)
             (2d game)
             (2d game-loop)
             (2d scene)
             (2d sprite)
             (2d stage)
             (2d vector2))

(define (enter sprite)
  (let ((size (game-resolution actions-demo)))
    (schedule-action
     (action-parallel
      ;; Move horizontally across the screen in 60 frames.
      (lerp (lambda (x)
              (set-sprite-position!
               sprite
               (vector2 x (/ (vy size) 2))))
            0 (vx size) 60)
      ;; Rotate 1080 degrees in 120 frames.
      (lerp (lambda (angle)
              (set-sprite-rotation! sprite angle))
            0 360 120)))))

(define actions-scene
  (make-scene
   "Actions"
   #:init (lambda ()
            (load-sprite "images/ghost.png"
                         #:position (vector2 320 240)))
   #:enter enter
   #:draw draw-sprite))

(define actions-demo
  (make-game
   #:title "Actions"
   #:first-scene actions-scene))

(run-game actions-demo)