More portable block definitions
This commit is contained in:
parent
4ad60ae573
commit
39bad552af
1 changed files with 13 additions and 7 deletions
|
@ -79,13 +79,19 @@ instance Translatable Block where
|
||||||
-- Low level functions on blocks and coordinates
|
-- Low level functions on blocks and coordinates
|
||||||
|
|
||||||
initBlock :: Tetrimino -> Block
|
initBlock :: Tetrimino -> Block
|
||||||
initBlock I = Block I startOrigin [(-2,0), (-1,0), (1,0)]
|
initBlock t = Block t startOrigin $ offset startOrigin $ relCells t
|
||||||
initBlock O = Block O startOrigin [(-1,0), (-1,-1), (0,-1)]
|
|
||||||
initBlock S = Block S startOrigin [(-1,-1), (0,-1), (1,0)]
|
offset :: Coord -> [Coord] -> [Coord]
|
||||||
initBlock Z = Block Z startOrigin [(-1,0), (0,-1), (1,-1)]
|
offset (xo,yo) = fmap (\(x,y) -> (xo + x, yo + x))
|
||||||
initBlock L = Block L startOrigin [(-1,-1), (-1,0), (1,0)]
|
|
||||||
initBlock J = Block J startOrigin [(-1,0), (1,0), (1,-1)]
|
relCells :: Tetrimino -> [Coord]
|
||||||
initBlock T = Block T startOrigin [(-1,0), (0,-1), (1,0)]
|
relCells I = [(-2,0), (-1,0), (1,0)]
|
||||||
|
relCells O = [(-1,0), (-1,-1), (0,-1)]
|
||||||
|
relCells S = [(-1,-1), (0,-1), (1,0)]
|
||||||
|
relCells Z = [(-1,0), (0,-1), (1,-1)]
|
||||||
|
relCells L = [(-1,-1), (-1,0), (1,0)]
|
||||||
|
relCells J = [(-1,0), (1,0), (1,-1)]
|
||||||
|
relCells T = [(-1,0), (0,-1), (1,0)]
|
||||||
|
|
||||||
-- | Visible, active board size
|
-- | Visible, active board size
|
||||||
boardWidth, boardHeight :: Int
|
boardWidth, boardHeight :: Int
|
||||||
|
|
Loading…
Add table
Reference in a new issue