Skip to content
noooway edited this page May 28, 2017 · 123 revisions

This tutorial describes how to write a more or less full-featured Arkanoid (Breakout) clone.

The intended audience are people, who have basic programming experience, but have trouble structuring their code for projects bigger than "Hello World". An Arkanoid, while simple, contains many elements found in more elaborate games. My aim is to introduce a typical code structure, and to provide a starting point for further modifications.

Chapter 1 describes how to build a prototype for an Arkanoid-type game in the most straightforward way, without relying too much on any external libraries or advanced language features.

Chapter 2 expands the prototype, introducing gamestates, basic graphics and sound. At the end of this chapter, the general frame of the game is complete. What is left is to fill it with the details.

Chapter 3 proceeds to add functionality to achieve a full-featured game. While the first two chapters are rather general, material in this chapter is mostly specific for Arkanoid-type games. Warning: the code for this chapter is in a working state, but requires some minor corrections.

Appendices - which are not written yet :) - demonstrate some additional topics, such as how to use environments to define Lua modules, classes, and so on.

I realize that the length of the tutorial - almost 30 parts - is probably a bit too much. On the other hand, the amount of work necessary to write a game is commonly underestimated and this tutorial clearly shows what it actually takes to develop even a simple one.

Lua programming language and LÖVE framework are used. Basic programming experience is assumed. Familiarity with Lua and LÖVE is beneficial but not necessary. Some non-obvious Lua idioms are briefly explained.

The code can be downloaded using git

cd /your-path/
git clone https://github.com/noooway/love2d_arkanoid_tutorial

or by Github's "Clone or download -> Download ZIP" button.

Each step can be run with the LÖVE interpreter by issuing a love command followed by the folder name, for example

cd /your-path/love2d_arkanoid_tutorial
love 1-01_TheBallTheBrickThePlatform 

One last thing before we start: feedback is crucial. If you have any critique, suggestions, improvements or just any other ideas, let me know.

Contents:

Chapter 1: Building Prototype

  1. The Ball, The Brick, The Platform
  2. Bricks and Walls
  3. Detecting Collisions
  4. Resolving Collisions
  5. Levels

    Appendix A: Storing Levels as Strings

Chapter 2: General Code Structure

  1. Splitting Code into Several Files
  2. Loading Levels from Files
  3. Straightforward Gamestates
  4. Advanced Gamestates
  5. Basic Tiles
  6. Different Brick Types
  7. Basic Sound
  8. Game Over

    Appendix B: Stricter Modules
    Appendix C-1: Intro to Classes
    Appendix C-2: Chapter 2 Using Classes.

Chapter 3: Adding Details

  1. Better Ball Rebounds
  2. Ball Launch From Platform (Two Objects Moving Together)
  3. Mouse Controls
  4. Spawning Bonuses
  5. Bonus Effects
  6. Glue Bonus
  7. Add New Ball Bonus
  8. Life and Next Level Bonuses
  9. Random Bonuses
  10. Menu Buttons
  11. Wall Tiles
  12. Side Panel (draft)
  13. Score (draft)
  14. Fonts (draft)
  15. More Sounds (draft)
  16. Final Screen (draft)
  17. Packaging and Distribution (draft)

Additional Topics:

  1. Spreading the Word (draft)
  2. Finding a Team

Acknowledgements
Archive

    Home
    Acknowledgements
    Todo

Chapter 1: Prototype

  1. The Ball, The Brick, The Platform
  2. Game Objects as Lua Tables
  3. Bricks and Walls
  4. Detecting Collisions
  5. Resolving Collisions
  6. Levels

    Appendix A: Storing Levels as Strings
    Appendix B: Optimized Collision Detection (draft)

Chapter 2: General Code Structure

  1. Splitting Code into Several Files
  2. Loading Levels from Files
  3. Straightforward Gamestates
  4. Advanced Gamestates
  5. Basic Tiles
  6. Different Brick Types
  7. Basic Sound
  8. Game Over

    Appendix C: Stricter Modules (draft)
    Appendix D-1: Intro to Classes (draft)
    Appendix D-2: Chapter 2 Using Classes.

Chapter 3 (deprecated): Details

  1. Improved Ball Rebounds
  2. Ball Launch From Platform (Two Objects Moving Together)
  3. Mouse Controls
  4. Spawning Bonuses
  5. Bonus Effects
  6. Glue Bonus
  7. Add New Ball Bonus
  8. Life and Next Level Bonuses
  9. Random Bonuses
  10. Menu Buttons
  11. Wall Tiles
  12. Side Panel
  13. Score
  14. Fonts
  15. More Sounds
  16. Final Screen
  17. Packaging

    Appendix D: GUI Layouts
    Appendix E: Love-release and Love.js

Beyond Programming:

  1. Game Design
  2. Minimal Marketing (draft)
  3. Finding a Team (draft)

Archive

Clone this wiki locally