Map out funcs and types for shifting & rotating
This commit is contained in:
parent
6c1627c481
commit
a7efdaba5c
1 changed files with 37 additions and 1 deletions
|
@ -88,7 +88,7 @@ boardHeight = 20
|
||||||
|
|
||||||
-- | Starting block origin cell
|
-- | Starting block origin cell
|
||||||
startOrigin :: Coord
|
startOrigin :: Coord
|
||||||
startOrigin = (6, 21)
|
startOrigin = (6, 22)
|
||||||
|
|
||||||
-- | Rotate block counter clockwise about origin
|
-- | Rotate block counter clockwise about origin
|
||||||
-- *Note*: Strict unsafe rotation not respecting boundaries
|
-- *Note*: Strict unsafe rotation not respecting boundaries
|
||||||
|
@ -148,8 +148,44 @@ clearFullRows g = g & board %~ clearBoard
|
||||||
let offset = length . filter (< y) $ fullRowIndices
|
let offset = length . filter (< y) $ fullRowIndices
|
||||||
in (x, y - offset)
|
in (x, y - offset)
|
||||||
|
|
||||||
|
-- | Handle counterclockwise block rotation (if possible)
|
||||||
|
rotate :: Game -> Game
|
||||||
|
rotate = undefined
|
||||||
|
|
||||||
|
-- | Check if a block on a board is stopped from further gravitation
|
||||||
|
isStopped :: Board -> Block -> Bool
|
||||||
|
isStopped = undefined
|
||||||
|
|
||||||
|
-- | If stopped, freeze current block to board and get next block
|
||||||
|
cycleNextBlock :: Game -> IO Game
|
||||||
|
cycleNextBlock = undefined
|
||||||
|
|
||||||
|
-- | Try to shift current block; if shifting not possible, leave block where it is
|
||||||
|
shift :: Direction -> Game -> Game
|
||||||
|
shift d g = g & currBlock %~ shiftBlock
|
||||||
|
where shiftBlock b = if isValidBlockPosition (translate d b) (g ^. board)
|
||||||
|
then translate d b
|
||||||
|
else b
|
||||||
|
|
||||||
|
-- | Check if coordinate is already occupied in board
|
||||||
|
isOccupied :: Board -> Coord -> Bool
|
||||||
|
isOccupied = undefined
|
||||||
|
|
||||||
|
-- | Check if coordinate is out of bounds
|
||||||
|
isOutOfBounds :: Coord -> Bool
|
||||||
|
isOutOfBounds (x,y) = x `elem` [1..boardWidth] && y `elem` [1..boardHeight]
|
||||||
|
|
||||||
|
-- | Gravitate current block, i.e. shift down
|
||||||
|
gravitate :: Game -> Game
|
||||||
|
gravitate = shift Down
|
||||||
|
|
||||||
|
-- | Checks if block's potential new origin is valid
|
||||||
|
isValidBlockPosition :: Block -> Board -> Bool
|
||||||
|
isValidBlockPosition = undefined
|
||||||
|
|
||||||
-- TODO wallkicks http://tetris.wikia.com/wiki/TGM_rotation
|
-- TODO wallkicks http://tetris.wikia.com/wiki/TGM_rotation
|
||||||
|
|
||||||
|
-- | Shuffle a sequence (random permutation)
|
||||||
shuffle :: Seq.Seq a -> IO (Seq.Seq a)
|
shuffle :: Seq.Seq a -> IO (Seq.Seq a)
|
||||||
shuffle xs
|
shuffle xs
|
||||||
| null xs = mempty
|
| null xs = mempty
|
||||||
|
|
Loading…
Add table
Reference in a new issue