Code a Zaxxon-style axonometric level | Wireframe #33
Fly through the space fortress in this 3D retro forced scrolling arcade sample. Mark Vanstone has the details
When Zaxxon was first released by Sega in 1982, it was hailed as a breakthrough thanks to its pseudo-3D graphics. This axonometric projection ensured that Zaxxon looked unlike any other shooter around in arcades.
Graphics aside, Zaxxon offered a subtly different twist on other shooting games of the time, like Defender and Scramble; the player flew over either open space or a huge fortress, where they had to avoid obstacles of varying heights. Players could tell how high they were flying with the aid of an altimeter, and also the shadow beneath their ship (shadows were another of Zaxxon’s innovations). The aim of the game was to get to the end of each level without running out of fuel or getting shot down; if the player did this, they’d encounter an area boss called Zaxxon. Points were awarded for destroying gun turrets and fuel silos, and extra lives could be gained as the player progressed through the levels.
Making our level
For this code sample, we can borrow some of the techniques used in a previous Source Code article about Ant Attack (see Wireframe issue 15) since it also used an isometric display. Although the way the map display is built up is very similar, we’ll use a JSON file to store the map data. If you’ve not come across JSON before, it’s well worth learning about, as a number of web and mobile apps use it, and it can be read by Python very easily. All we need to do is load the JSON file, and Python automatically puts the data into a Python dictionary object for us to use.
In the sample, there’s a short run of map data 40 squares long with blocks for the floor, some low walls, higher walls, and a handful of fuel silos. To add more block types, just add data to the
blocktypes area of the JSON file. The codes used in the map data are the index numbers of the
blocktypes, so the first
index 0, the next
index 1, and so on. Our
drawMap() function takes care of rendering the data into visual form and blits blocks from the top right to the bottom left of the screen. When the
draw loop gets to where the ship is, it draws first the shadow and then the ship a little higher up the screen, depending on the altitude of the ship. The equation to translate the ship’s screen coordinates to a block position on the map is a bit simplistic, but in this case, it does the job well enough.
Cursor keys guide the movement of the spaceship, which is limited by the width of the map and a height of 85 pixels. There’s some extra code to display the ship if it isn’t on the map – for example, at the start, before it reaches the map area. To make the code snippet into a true Zaxxon clone, you’ll have to add some laser fire and explosions, a fuel gauge, and a scoring system, but this code sample should provide the basis you’ll need to get started.
Get your copy of Wireframe issue 33
You can read more features like this one in Wireframe issue 33, available now at Tesco, WHSmith, all good independent UK newsagents, and the Raspberry Pi Store, Cambridge.
Or you can buy Wireframe directly from Raspberry Pi Press — delivery is available worldwide. And if you’d like a handy digital version of the magazine, you can also download issue 33 for free in PDF format.
Make sure to follow Wireframe on Twitter and Facebook for updates and exclusive offers and giveaways. Subscribe on the Wireframe website to save up to 49% compared to newsstand pricing!
David J Wright
Example json file named “person”:
with open(‘path_to_file/person.json’) as f:
data = json.load(f)
I tried to run the game on Linux and was advised I needed to install python-pip and it offered a command to do that. So I ran that and it installed OK. I then ran the command “pip install pgzero” and it failed as follows:
pip install pgzero
Downloading https://files.pythonhosted.org/packages/40/87/fbb77cfd9c6f2dbe63d09d3e693aa2bcde63995f6f014b3b0bda5d3dbcdd/pgzero-1.2.tar.gz (2.2MB)
100% |████████████████████████████████| 2.2MB 420kB/s
Complete output from command python setup.py egg_info:
Traceback (most recent call last):
File “”, line 1, in
ImportError: No module named setuptools
Command “python setup.py egg_info” failed with error code 1 in /tmp/pip-build-fbQ41z/pgzero/
Can someone point me in the direction of how to get “setuptools”?
Comments are closed