aboutsummaryrefslogtreecommitdiff
path: root/src/Update/Update.elm
diff options
context:
space:
mode:
authorJoris Guyonvarch2015-03-07 18:46:47 +0100
committerJoris Guyonvarch2015-03-07 18:46:47 +0100
commit6c1f5e10631a3f66f4c85a45b6f28ffd366105c5 (patch)
tree624d833aa62ad8ce5ed172144ff69a2846d55154 /src/Update/Update.elm
parentae14beca0452b59ead64b8cdd6544824d59a55dc (diff)
Show best score in html layout
Diffstat (limited to 'src/Update/Update.elm')
-rw-r--r--src/Update/Update.elm41
1 files changed, 24 insertions, 17 deletions
diff --git a/src/Update/Update.elm b/src/Update/Update.elm
index 0187dcf..ef85670 100644
--- a/src/Update/Update.elm
+++ b/src/Update/Update.elm
@@ -5,6 +5,7 @@ module Update.Update
import List
import Keyboard (KeyCode)
import Char (fromCode, toCode)
+import Maybe
import Model.Player (..)
import Model.Point (pointSpeed, pointMove, pointAwayDist)
@@ -21,23 +22,29 @@ import Update.CloudUpdate (cloudUpdate)
import Input (Input)
update : Input -> Game -> Game
-update {dir, inputKeysDown, delta} {time, keysDown, score, player, cloud, bestScore, seed} =
- let hostilePoints = cloud.points (otherConfig player.config)
- in if(playerPointsCollision time player hostilePoints) then
- let newBestScore = if(score > bestScore) then score else bestScore
- in initialGame seed player.pos player.config newBestScore
- else
- let newTime = time + delta
- newPlayer = playerStep delta dir (newKeyCode keysDown inputKeysDown) player
- (newCloud, addScore, newSeed) = cloudUpdate time seed newPlayer cloud
- in { time = newTime
- , keysDown = inputKeysDown
- , score = score + addScore
- , player = newPlayer
- , cloud = newCloud
- , bestScore = bestScore
- , seed = newSeed
- }
+update input game =
+ let hostilePoints = game.cloud.points (otherConfig game.player.config)
+ in if(playerPointsCollision game.time game.player hostilePoints)
+ then
+ { game
+ | time <- 0
+ , currentScore <- 0
+ , cloud <- initCloud
+ , scores <- game.currentScore :: game.scores
+ }
+ else
+ let newTime = game.time + input.delta
+ newPlayer = playerStep input.delta input.dir (newKeyCode game.keysDown input.inputKeysDown) game.player
+ (newCloud, addScore, newSeed) = cloudUpdate game.time game.seed newPlayer game.cloud
+ in
+ { game
+ | time <- newTime
+ , keysDown <- input.inputKeysDown
+ , currentScore <- game.currentScore + addScore
+ , player <- newPlayer
+ , cloud <- newCloud
+ , seed <- newSeed
+ }
playerStep : Float -> Vec2 -> (KeyCode -> Bool) -> Player -> Player
playerStep dt dir newKey player =