Add help section and support vim bindings
This commit is contained in:
parent
a0117d3bb1
commit
4936597ae2
2 changed files with 41 additions and 12 deletions
|
@ -21,8 +21,11 @@ import Data.Monoid (First(..))
|
||||||
-- 0. BUG in hard drop - if block is under an overhang then it gets sent above
|
-- 0. BUG in hard drop - if block is under an overhang then it gets sent above
|
||||||
-- 1. leaderboard saved to txt file (requires adding viewport for name entry)
|
-- 1. leaderboard saved to txt file (requires adding viewport for name entry)
|
||||||
-- and probably wrapping game in a ui state
|
-- and probably wrapping game in a ui state
|
||||||
|
-- 2. Add ToDo: Custom RGB colors or find a good theme and steal it. See if attribute monoid is used for defaulting when color not displayable?
|
||||||
|
-- 2. Consider allow speeding up just like Conway (thus removing pickLevel and having one interface)
|
||||||
-- 2. consider adding hard drop preview like other games, but need another color
|
-- 2. consider adding hard drop preview like other games, but need another color
|
||||||
-- 3. USE linear V2 instead of tuples.. dummy
|
-- 3. USE linear V2 instead of tuples.. dummy
|
||||||
|
-- 3. Consider refactoring (Game -> a) with State or Reader abstraction
|
||||||
-- 4. README with gif
|
-- 4. README with gif
|
||||||
-- 5. release binaries for darwin and linux
|
-- 5. release binaries for darwin and linux
|
||||||
|
|
||||||
|
|
|
@ -59,13 +59,16 @@ handleEvent g (AppEvent Tick) = handleTick g
|
||||||
handleEvent g (VtyEvent (V.EvKey V.KRight [])) = continue $ shift Right g
|
handleEvent g (VtyEvent (V.EvKey V.KRight [])) = continue $ shift Right g
|
||||||
handleEvent g (VtyEvent (V.EvKey V.KLeft [])) = continue $ shift Left g
|
handleEvent g (VtyEvent (V.EvKey V.KLeft [])) = continue $ shift Left g
|
||||||
handleEvent g (VtyEvent (V.EvKey V.KDown [])) = continue $ shift Down g
|
handleEvent g (VtyEvent (V.EvKey V.KDown [])) = continue $ shift Down g
|
||||||
|
handleEvent g (VtyEvent (V.EvKey (V.KChar 'l') [])) = continue $ shift Right g
|
||||||
|
handleEvent g (VtyEvent (V.EvKey (V.KChar 'h') [])) = continue $ shift Left g
|
||||||
|
handleEvent g (VtyEvent (V.EvKey (V.KChar 'j') [])) = continue $ shift Down g
|
||||||
handleEvent g (VtyEvent (V.EvKey (V.KChar ' ') [])) = continue $ hardDrop g
|
handleEvent g (VtyEvent (V.EvKey (V.KChar ' ') [])) = continue $ hardDrop g
|
||||||
handleEvent g (VtyEvent (V.EvKey V.KUp [])) = continue $ rotate g
|
handleEvent g (VtyEvent (V.EvKey V.KUp [])) = continue $ rotate g
|
||||||
|
handleEvent g (VtyEvent (V.EvKey (V.KChar 'k') [])) = continue $ rotate g
|
||||||
handleEvent g (VtyEvent (V.EvKey (V.KChar 'q') [])) = halt g
|
handleEvent g (VtyEvent (V.EvKey (V.KChar 'q') [])) = halt g
|
||||||
handleEvent g (VtyEvent (V.EvKey V.KEsc [])) = halt g
|
handleEvent g (VtyEvent (V.EvKey V.KEsc [])) = halt g
|
||||||
handleEvent g _ = continue g
|
handleEvent g _ = continue g
|
||||||
|
|
||||||
|
|
||||||
-- | Handles time steps, does nothing if game is over
|
-- | Handles time steps, does nothing if game is over
|
||||||
handleTick :: Game -> EventM Name (Next Game)
|
handleTick :: Game -> EventM Name (Next Game)
|
||||||
handleTick g = if isGameOver g
|
handleTick g = if isGameOver g
|
||||||
|
@ -76,9 +79,9 @@ handleTick g = if isGameOver g
|
||||||
|
|
||||||
drawUI :: Game -> [Widget Name]
|
drawUI :: Game -> [Widget Name]
|
||||||
drawUI g =
|
drawUI g =
|
||||||
[ C.vCenter $ vLimit 22 $ hBox [ padLeft Max $ drawStats g
|
[ C.vCenter $ vLimit 22 $ hBox [ padLeft Max $ padRight (Pad 2) $ drawStats g
|
||||||
, drawGrid g
|
, drawGrid g
|
||||||
, padRight Max $ drawNextShape (g ^. nextShape)
|
, padRight Max $ padLeft (Pad 2) $ drawInfo g
|
||||||
]
|
]
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -114,6 +117,8 @@ drawCell t = withAttr (tToAttr t) cw
|
||||||
tToAttr J = jAttr
|
tToAttr J = jAttr
|
||||||
tToAttr L = lAttr
|
tToAttr L = lAttr
|
||||||
|
|
||||||
|
-- TODO • for hardDrop preview
|
||||||
|
|
||||||
cw :: Widget Name
|
cw :: Widget Name
|
||||||
cw = str " ."
|
cw = str " ."
|
||||||
|
|
||||||
|
@ -121,28 +126,31 @@ ecw :: Widget Name
|
||||||
ecw = str " "
|
ecw = str " "
|
||||||
|
|
||||||
drawStats :: Game -> Widget Name
|
drawStats :: Game -> Widget Name
|
||||||
drawStats g = padRight (Pad 2)
|
drawStats g = hLimit 22
|
||||||
$ hLimit 22
|
|
||||||
$ withBorderStyle BS.unicodeBold
|
$ withBorderStyle BS.unicodeBold
|
||||||
$ B.borderWithLabel (str "Stats")
|
$ B.borderWithLabel (str "Stats")
|
||||||
$ vBox [ drawStat "Score" $ g ^. score
|
$ vBox [ drawStat "Score" $ g ^. score
|
||||||
, drawStat "Level" $ g ^. level
|
, padTop (Pad 1) $ drawStat "Level" $ g ^. level
|
||||||
, drawLeaderBoard g
|
, drawLeaderBoard g
|
||||||
]
|
]
|
||||||
|
|
||||||
drawStat :: String -> Int -> Widget Name
|
drawStat :: String -> Int -> Widget Name
|
||||||
drawStat s n = padLeftRight 1 $ padTop (Pad 1)
|
drawStat s n = padLeftRight 1
|
||||||
$ str s <+> (padLeft Max $ str $ show n)
|
$ str s <+> (padLeft Max $ str $ show n)
|
||||||
|
|
||||||
drawLeaderBoard :: Game -> Widget Name
|
drawLeaderBoard :: Game -> Widget Name
|
||||||
drawLeaderBoard g = emptyWidget
|
drawLeaderBoard g = emptyWidget
|
||||||
|
|
||||||
|
drawInfo :: Game -> Widget Name
|
||||||
|
drawInfo g = hLimit 16 -- size of next piece box
|
||||||
|
$ vBox [ drawNextShape (g ^. nextShape)
|
||||||
|
, padTop (Pad 2) $ drawHelp
|
||||||
|
]
|
||||||
|
|
||||||
drawNextShape :: Tetrimino -> Widget Name
|
drawNextShape :: Tetrimino -> Widget Name
|
||||||
drawNextShape t =
|
drawNextShape t = withBorderStyle BS.unicodeBold
|
||||||
padLeft (Pad 2)
|
$ B.borderWithLabel (str "Next")
|
||||||
$ withBorderStyle BS.unicodeBold
|
$ padTopBottom 1 $ padLeftRight 3
|
||||||
$ B.borderWithLabel (str "Next Piece")
|
|
||||||
$ padTopBottom 1 $ padLeftRight 2
|
|
||||||
$ vLimit 4
|
$ vLimit 4
|
||||||
$ vBox $ mkRow <$> [0,-1]
|
$ vBox $ mkRow <$> [0,-1]
|
||||||
where
|
where
|
||||||
|
@ -151,6 +159,24 @@ drawNextShape t =
|
||||||
blk = Block t (0,0) (relCells t)
|
blk = Block t (0,0) (relCells t)
|
||||||
cs = blk ^. to coords
|
cs = blk ^. to coords
|
||||||
|
|
||||||
|
drawHelp :: Widget Name
|
||||||
|
drawHelp = withBorderStyle BS.unicodeBold
|
||||||
|
$ B.borderWithLabel (str "Help")
|
||||||
|
$ padTopBottom 1
|
||||||
|
$ vBox $ map (uncurry drawKeyInfo)
|
||||||
|
$ [ ("Left", "h, ←")
|
||||||
|
, ("Right", "l, →")
|
||||||
|
, ("Down", "j, ↓")
|
||||||
|
, ("Rotate", "k, ↑")
|
||||||
|
, ("Quit", "q")
|
||||||
|
]
|
||||||
|
|
||||||
|
drawKeyInfo :: String -> String -> Widget Name
|
||||||
|
drawKeyInfo action keys =
|
||||||
|
(padRight Max $ padLeft (Pad 1) $ str (action ++ ":"))
|
||||||
|
<+> (padLeft Max $ padRight (Pad 1) $ str keys)
|
||||||
|
|
||||||
|
|
||||||
theMap = attrMap V.defAttr
|
theMap = attrMap V.defAttr
|
||||||
[ (iAttr, on V.cyan V.cyan)
|
[ (iAttr, on V.cyan V.cyan)
|
||||||
, (oAttr, on V.yellow V.yellow)
|
, (oAttr, on V.yellow V.yellow)
|
||||||
|
|
Loading…
Add table
Reference in a new issue