2019-12-17 00:23:52 -08:00
|
|
|
# penetrator
|
|
|
|
Remake of the ZX Spectrum game for the Apple II.
|
|
|
|
|
|
|
|
1. INTRODUCTION
|
|
|
|
|
|
|
|
This is a "port" of the Commander X16 version that's also in my repo's as just
|
|
|
|
penetrator. I had to rewrite quite a bit of the drawing code and make some
|
|
|
|
other changes to make it work on the Apple II, and to make it fast enough.
|
|
|
|
|
|
|
|
This is also my very first program for the Apple II. It was a learning
|
|
|
|
experience :)
|
|
|
|
|
|
|
|
2. CURRENT STATUS
|
|
|
|
|
|
|
|
The game is a pretty good replica of the original. It is missing sound. It's
|
|
|
|
also missing the demo attract mode, and the fireworks.
|
|
|
|
|
|
|
|
3. TECHNICAL DETAILS
|
|
|
|
|
|
|
|
The game is written in 6502 assembly using the ca65 assembler.
|
|
|
|
|
2019-12-17 08:37:53 -08:00
|
|
|
Below is a CPU cycle profile of 1 game frame in stage 4. It's a busy frame with
|
|
|
|
bullets, bombs and enemies. Most importantly, it has a busy terrain at the top
|
2019-12-17 08:44:11 -08:00
|
|
|
and bottom.
|
2019-12-17 08:37:53 -08:00
|
|
|
|
2019-12-17 08:48:31 -08:00
|
|
|
Hex | Dec | Frame % | Item
|
|
|
|
--- | --- | --- | ---
|
|
|
|
148F3 | 84211 | 100% | Total Frame
|
|
|
|
61F | 1567 | 2.0% | inputGame
|
|
|
|
0A | 10 | 0.0% | Misc
|
|
|
|
73 | 115 | 0.1% | gameWorldMove
|
|
|
|
05 | 5 | 0.0% | Misc
|
|
|
|
19 | 25 | 0.0% | gameCheckStage
|
|
|
|
08 | 8 | 0.0% | Misc
|
|
|
|
B80 | 2944 | 3.5% | gameAI
|
|
|
|
17 | 23 | 0.0% | Misc
|
|
|
|
7267 | 29287 | 34.8% | drawClearRows
|
|
|
|
6721 | 26401 | 31.4% | terrainDraw
|
|
|
|
38A8 | 14504 | 17.2% | drawEnemies
|
|
|
|
985 | 2437 | 2.9% | drawPlayer
|
|
|
|
581 | 1409 | 1.7% | drawBullets
|
|
|
|
6E3 | 1763 | 2.1% | drawBombs
|
|
|
|
E14 | 3604 | 4.3% | drawExplosions
|
|
|
|
06 | 6 | 0.0% | Misc
|
|
|
|
1A | 26 | 0.0% | drawPresent
|
|
|
|
11 | 17 | 0.0% | Misc
|
|
|
|
3C | 60 | 0.1% | Emulator error
|
2019-12-17 08:44:11 -08:00
|
|
|
|
|
|
|
|
2019-12-17 08:37:53 -08:00
|
|
|
As can be seen, clearing the area where the world will be drawn takes almost 35%
|
|
|
|
of the frame and drawing the terrain takes another 31% of the frame. The
|
|
|
|
Emulator Error are unaccounted for cycles -discrepency between total cycles at
|
|
|
|
the start and end, vs. the cycles reported in each step. I modifies the
|
|
|
|
emulator myself to do step reporting and I assume I must have missed someting.
|
2019-12-17 00:23:52 -08:00
|
|
|
|
|
|
|
4. KEYS and JOYSTICK
|
|
|
|
|
|
|
|
The Apple 2 gameplay works only with a joystick since you cannot detect multiple
|
|
|
|
keys down on the Apple II. The UI works with the keyboard or joystick and the
|
|
|
|
world editor uses both.
|
|
|
|
|
2019-12-17 08:37:53 -08:00
|
|
|
The joystick can also drive the menu's. Pressing right, for example, is
|
|
|
|
equivalent to pressing 1 (the UI menu options are selected through numbers).
|
|
|
|
|
2019-12-17 00:23:52 -08:00
|
|
|
The menus all show the keys to advance. There's also a help screen in the
|
|
|
|
editor.
|
|
|
|
|
|
|
|
5. THE FILES
|
|
|
|
|
|
|
|
I tried to comment all the code very thoroughly in the CX16 version. Since this
|
|
|
|
version is derived from that version, the code is also well documented, but to
|
|
|
|
be honest, the comments may not always be accurate. I did not do a pass to see
|
|
|
|
if they are accurate.
|
|
|
|
|
|
|
|
There are actually 2 programs in this. The 1st is the game, and it's in
|
|
|
|
src/apple2.
|
|
|
|
|
|
|
|
* defs.inc - Constants and definitions used throughout
|
2019-12-17 08:37:53 -08:00
|
|
|
* draw.inc - HGR buffer drawing. drawSprite, for example
|
2019-12-17 00:23:52 -08:00
|
|
|
* edit.inc - The built-in world editor
|
|
|
|
* file.inc - Load and Save code
|
2019-12-17 08:37:53 -08:00
|
|
|
* fontdata.inc - A ZX Spectrum font in reverse 8x8 - Apple II format
|
2019-12-17 00:23:52 -08:00
|
|
|
* game.inc - The in-game logic, AI etc. The bulk of the "game"
|
|
|
|
* input.inc - User controls for game and editor
|
|
|
|
* logo.hgr - 8Kb splash screen in HGR format
|
2019-12-17 08:37:53 -08:00
|
|
|
* logo.inc - File that simply does an incbin on logo.hgr
|
2019-12-17 00:23:52 -08:00
|
|
|
* logodata.inc - Line data for writing Penetrator and logo image data
|
2019-12-17 08:37:53 -08:00
|
|
|
* macros.inc - Print macros mostly
|
2019-12-17 00:23:52 -08:00
|
|
|
* penetrator.asm - Where the game starts, initial setup, etc.
|
|
|
|
* penetrator.cfg - ca65 configuration file
|
|
|
|
* rodata.inc - Read-only data such as lookup tables, sprites etc.
|
|
|
|
* terrain.inc - The terrain drawing routines
|
|
|
|
* text.inc - In game text and print functions
|
|
|
|
* trndata.inc - The world data (triplet - top, bottom and enemy pos)
|
|
|
|
* ui.inc - User facing screens, name input, etc.
|
2019-12-17 08:37:53 -08:00
|
|
|
* variables.inc - All non zero page variables (stats, scores, draw buffers)
|
|
|
|
* zpvars.inc - The zero page variables (most variables)
|
2019-12-17 00:23:52 -08:00
|
|
|
|
|
|
|
The second is the ProDos loader that will auto-load the game. It's in the
|
|
|
|
src/apple2.loader folder. It has these files (all provided to me by Oliver
|
|
|
|
Schmidt)
|
|
|
|
|
|
|
|
* loader.cfg - ca65 configuration file
|
|
|
|
* loader.s - file to load and start the game
|
|
|
|
|
|
|
|
6. BUILDING THE GAME
|
|
|
|
|
2019-12-17 08:37:53 -08:00
|
|
|
Making the game has a few steps. Use make and the Makefile on all OSs, that
|
|
|
|
would be the easiest.
|
2019-12-17 00:23:52 -08:00
|
|
|
|
2019-12-17 00:30:25 -08:00
|
|
|
Start by making the loader - this needs to be done once only.
|
2019-12-17 00:23:52 -08:00
|
|
|
make TARGETS=apple2.loader
|
|
|
|
|
2019-12-17 00:30:25 -08:00
|
|
|
Next, make the game with:
|
2019-12-17 00:23:52 -08:00
|
|
|
make
|
|
|
|
|
|
|
|
The next step is to make a bootable disk image. For this, you will need some
|
|
|
|
other piece of 3rd party software. It's called AppleCommander. Once
|
|
|
|
downloaded, put it in the apple2 folder in the root (apple2 folder at same level
|
|
|
|
as Makefile). This software will put the loader and game into the disk image.
|
|
|
|
|
|
|
|
Since I use Windows to develop, I have a file called build.cmd next to the
|
|
|
|
Makefile (and checked in here as well). The contents of this file is listed
|
2019-12-17 00:30:25 -08:00
|
|
|
below (where the line ends with "\\" isn't actually a line-end, I just cut the
|
2019-12-17 00:23:52 -08:00
|
|
|
line there for readability, the next line is actually on the same line as the
|
2019-12-17 00:30:25 -08:00
|
|
|
line ending with "\\").
|
2019-12-17 00:23:52 -08:00
|
|
|
|
2019-12-17 00:30:25 -08:00
|
|
|
copy apple2\\template.dsk Penetrator.dsk
|
2019-12-17 07:39:42 -08:00
|
|
|
java -jar apple2\AppleCommander-win64-1.5.0.jar -p Penetrator.dsk \\
|
|
|
|
penetrat.system sys < penetrator-apple2.apple2.loader
|
|
|
|
java -jar apple2\AppleCommander-win64-1.5.0.jar -as Penetrator.dsk \\
|
|
|
|
penetrat bin < penetrator-apple2.apple2
|
2019-12-17 00:30:25 -08:00
|
|
|
apple2\\Applewin.exe -d1 penetrator.dsk
|
2019-12-17 00:23:52 -08:00
|
|
|
|
|
|
|
You will need to install Java to use AppleCommander. The apple2/template.dsk is
|
|
|
|
a "blank ProDos floppy" that has the loader and the game placed on it by
|
|
|
|
AppleCommander. I use the AppleWin emulator to run the game (-d1 penetrator.dsk
|
|
|
|
mounts the floppy in drive one, and then boots from it automatically). In
|
|
|
|
powershell, when developing the game, I would just use this command to do it
|
2019-12-17 00:30:25 -08:00
|
|
|
all:
|
|
|
|
make; .\\build.cmd
|
2019-12-17 00:23:52 -08:00
|
|
|
|
2019-12-17 00:30:25 -08:00
|
|
|
Find AppleCommander here (I used Version 1.5.0):
|
2019-12-17 00:23:52 -08:00
|
|
|
https://github.com/AppleCommander/AppleCommander/releases
|
|
|
|
|
2019-12-17 00:30:25 -08:00
|
|
|
Find AppleWin here:
|
2019-12-17 00:23:52 -08:00
|
|
|
https://github.com/AppleWin/AppleWin/releases
|
|
|
|
|
|
|
|
7. CREDITS
|
|
|
|
|
|
|
|
* Phillip Mitchell and Beam Software for creating and publishing the game in
|
|
|
|
1982.
|
|
|
|
* A special call-out to Oliver Schmidt who provided me with invaluable
|
|
|
|
assistance to get me going on the Apple II.
|
|
|
|
* Everyone involved in the Apple II projects (AppleWin | AppleCommander).
|
|
|
|
* Everyone involved in making the cc65 tools, it's very good.
|
|
|
|
|
|
|
|
8. CONTACT
|
|
|
|
|
|
|
|
Feel free to contact me at swessels@email.com if you have thoughts or
|
|
|
|
suggestions.
|
|
|
|
|
2019-12-17 00:30:25 -08:00
|
|
|
Thank you
|
|
|
|
Stefan Wessels
|
|
|
|
16 December 2019 - Initial Revision
|