diff options
Diffstat (limited to 'Demos/Pong/Pong.hs')
-rw-r--r-- | Demos/Pong/Pong.hs | 40 |
1 files changed, 18 insertions, 22 deletions
diff --git a/Demos/Pong/Pong.hs b/Demos/Pong/Pong.hs index b12f792..790a98e 100644 --- a/Demos/Pong/Pong.hs +++ b/Demos/Pong/Pong.hs | |||
@@ -3,12 +3,11 @@ | |||
3 | {-# LANGUAGE TypeSynonymInstances #-} | 3 | {-# LANGUAGE TypeSynonymInstances #-} |
4 | 4 | ||
5 | module Pong | 5 | module Pong |
6 | ( GameEvent (..), | 6 | ( GameEvent (..) |
7 | GameObject, | 7 | , GameObject |
8 | newWorld, | 8 | , newWorld |
9 | stepWorld, | 9 | , stepWorld |
10 | aabb, | 10 | ) |
11 | ) | ||
12 | where | 11 | where |
13 | 12 | ||
14 | import Spear.Math.AABB | 13 | import Spear.Math.AABB |
@@ -25,8 +24,8 @@ import Data.Monoid (mconcat) | |||
25 | 24 | ||
26 | -- Configuration | 25 | -- Configuration |
27 | 26 | ||
28 | padSize = vec2 0.07 0.015 | 27 | padSize = vec2 0.070 0.015 |
29 | ballSize = 0.012 :: Float | 28 | ballSize = vec2 0.012 0.012 |
30 | ballSpeed = 0.7 :: Float | 29 | ballSpeed = 0.7 :: Float |
31 | initialBallVelocity = vec2 1 1 | 30 | initialBallVelocity = vec2 1 1 |
32 | maxBounceAngle = (65::Float) * (pi::Float)/(180::Float) | 31 | maxBounceAngle = (65::Float) * (pi::Float)/(180::Float) |
@@ -54,10 +53,10 @@ data GameObjectId | |||
54 | deriving (Eq, Show) | 53 | deriving (Eq, Show) |
55 | 54 | ||
56 | data GameObject = GameObject | 55 | data GameObject = GameObject |
57 | { gameObjectId :: !GameObjectId | 56 | { gameObjectId :: !GameObjectId |
58 | , aabb :: {-# UNPACK #-} !AABB2 | 57 | , gameObjectSize :: {-# UNPACK #-} !Vector2 |
59 | , basis :: {-# UNPACK #-} !Transform2 | 58 | , basis :: {-# UNPACK #-} !Transform2 |
60 | , gostep :: Step [GameObject] [GameEvent] GameObject GameObject | 59 | , gostep :: Step [GameObject] [GameEvent] GameObject GameObject |
61 | } | 60 | } |
62 | 61 | ||
63 | 62 | ||
@@ -88,17 +87,14 @@ instance Spatial GameObject Vector2 Angle Transform2 where | |||
88 | 87 | ||
89 | 88 | ||
90 | instance Bounded2 GameObject where | 89 | instance Bounded2 GameObject where |
91 | boundingVolume obj = aabb2Volume $ translate (position obj) (aabb obj) | 90 | boundingVolume obj = aabb2Volume $ translate (position obj) (AABB2 (-size) size) |
91 | where size = gameObjectSize obj | ||
92 | 92 | ||
93 | 93 | ||
94 | ballBox, padBox :: AABB2 | ||
95 | ballBox = AABB2 (vec2 (-s) (-s)) (vec2 s s) where s = ballSize | ||
96 | padBox = AABB2 (-padSize) padSize | ||
97 | |||
98 | newWorld = | 94 | newWorld = |
99 | [ GameObject Ball ballBox (makeAt initialBallPos) $ stepBall initialBallVelocity, | 95 | [ GameObject Ball ballSize (makeAt initialBallPos) $ stepBall initialBallVelocity, |
100 | GameObject Enemy padBox (makeAt initialEnemyPos) stepEnemy, | 96 | GameObject Enemy padSize (makeAt initialEnemyPos) stepEnemy, |
101 | GameObject Player padBox (makeAt initialPlayerPos) stepPlayer | 97 | GameObject Player padSize (makeAt initialPlayerPos) stepPlayer |
102 | ] | 98 | ] |
103 | where makeAt = newTransform2 unitx2 unity2 | 99 | where makeAt = newTransform2 unitx2 unity2 |
104 | 100 | ||
@@ -129,7 +125,7 @@ stepBall vel = bounceBall vel .> moveBall | |||
129 | 125 | ||
130 | bounceBall :: Vector2 -> Step [GameObject] [GameEvent] GameObject (Vector2, GameObject) | 126 | bounceBall :: Vector2 -> Step [GameObject] [GameEvent] GameObject (Vector2, GameObject) |
131 | bounceBall vel = step $ \_ dt gos events ball -> | 127 | bounceBall vel = step $ \_ dt gos events ball -> |
132 | let (AABB2 pmin pmax) = translate (position ball) (aabb ball) | 128 | let (AABB2Volume (AABB2 pmin pmax)) = boundingVolume ball |
133 | sideCollision = x pmin < 0 || x pmax > 1 | 129 | sideCollision = x pmin < 0 || x pmax > 1 |
134 | backCollision = y pmin < 0 || y pmax > 1 | 130 | backCollision = y pmin < 0 || y pmax > 1 |
135 | flipX v@(Vector2 x y) = if sideCollision then vec2 (-x) y else v | 131 | flipX v@(Vector2 x y) = if sideCollision then vec2 (-x) y else v |
@@ -150,7 +146,7 @@ paddleBounce ball events vel paddle = | |||
150 | let collision = Collision Ball (gameObjectId paddle) `elem` events | 146 | let collision = Collision Ball (gameObjectId paddle) `elem` events |
151 | in if collision | 147 | in if collision |
152 | then | 148 | then |
153 | let (AABB2 pmin pmax) = translate (position paddle) (aabb paddle) | 149 | let (AABB2Volume (AABB2 pmin pmax)) = boundingVolume paddle |
154 | center = (x pmin + x pmax) / (2::Float) | 150 | center = (x pmin + x pmax) / (2::Float) |
155 | -- Normalized offset of the ball from the paddle's center, [-1, +1]. | 151 | -- Normalized offset of the ball from the paddle's center, [-1, +1]. |
156 | -- It's outside the [-1, +1] range if there is no collision. | 152 | -- It's outside the [-1, +1] range if there is no collision. |