28: Planning Revisited
I thought it’d be weird to drop a hardware post in this week as I’ve not finished the Tevris game yet, so this week’s post will continue the Tetris theme and then there will be a Cardboctober Week 4 round-up at the end.
I think Tevris is a very good example of a beginner game development exercise for this reason as it provides a lot of 2-dimensional array manipulation, collision algorithms and very testable rules.
The one thing that constantly blocks me (hoho!) with building Tevris is the collision detection. Tetris is a game that has been around for a long time, and all of it’s game logic is codified in various languages. The collision algorithm should be simple to drop in – but with Tevris it hasn’t worked out that way yet.
I keep hitting walls (hoho!.. alright I’ll stop.) with off-by-one errors, and general weirdness. I think this is down to a lack fo structure/planning upfront in the build of the game, which is why I’ve written it from scratch a couple of times as I find a new challenge, and why I’m in the process of another complete re-write.
Planning revisited
The tetris board is a 2-dimensional array that is 10 cells wide and 22 cells tall. Though it’s 22 cells tall, we only actually use 20 of them as the playable area (with 2 used for buffering the top of a shape without being out of bounds).
data:image/s3,"s3://crabby-images/3ac43/3ac43adc13494c5ec1c6425cf0574aad5fa75ecf" alt=""
There are 7 different types of piece in a traditional tetris game: I, T, L, J, Z, S and O. Here is how each of them look in the default rotation:
data:image/s3,"s3://crabby-images/79e1b/79e1b73746fc956e082872b70ffe4af8dd5530ab" alt=""
The marked square in the middle of each piece is the point that the piece will be rotated around.
data:image/s3,"s3://crabby-images/8fe65/8fe65481d62db6976bd624c1e4d994c8c9471442" alt=""
When spawning, a random piece with a random rotation is placed at the top of the board. This piece is positioned so that the marked square is at the top/center of the board:
data:image/s3,"s3://crabby-images/4026c/4026cacd07852255627b4a7ff973fb75acb909cf" alt=""
The piece can be moved along the x-axis by the player. The piece will automatically drop 1 block at an interval along the y-axis, but can also be manually moved downwards on the y-axis.
If the piece gets to the left or right edge of the board, the piece should not be drawn beyond the edge of the board.
If the piece collides with a filled square on the board, it should be merged with the board.
If the piece reaches the bottom row of the board, it should be merged with the board.
data:image/s3,"s3://crabby-images/18228/1822890a3defa2b9ecb88eeaabdfeb69c154829d" alt=""
So now that I’ve got that written down somewhere, I can continue with my big re-write and hopefully have something working by the end of Cardboctober!
Cardboctober Week 4 recap:
Day 22
Day 23
- Planning Tetrominoes in VR (Max)
- iOS North (Pete)
Day 24
- Basic Game Board (Max)
- Bullet time (Pete)
Day 25
- Creating and Moving Pieces (Max)
- Smart device pairing (Pete)
Day 26
- Rotating Pieces (Max)
- Laser battle (Pete)
Day 27
- Moving with gaze 💩 (Max)
- Hairy ball (Pete)
Day 28
- This post (Max)
- Beer (Pete)
Cardboctober day 28
Check out all of my other Cardoctober posts here: /cardboctober.