152 lines
4.8 KiB
Plaintext
Raw Normal View History

2019-08-17 17:57:59 -04:00
Q1. Are you implementing the game just like the original (i.e. vector
2019-01-25 15:49:51 -05:00
drawing)?
2019-01-20 02:01:48 -05:00
2019-08-17 17:57:59 -04:00
A1. No, this is just a quick hack using sprites.
2019-08-11 13:05:08 -04:00
While it would be pretty amazing, I haven't written
a 6502 optimized vector drawing library.
2019-01-20 02:01:48 -05:00
---
2019-08-17 17:57:59 -04:00
Q2. Is the gameplay exactly like the game?
2019-08-11 13:05:08 -04:00
2019-08-17 17:57:59 -04:00
A2. No, there are a lot of things that are hard to do in 40x48 and/or
2019-08-11 13:05:08 -04:00
with only 48k of RAM.
See the TODO file for a list of things I've noticed.
The game is really amazing and subtle and some things you only notice
after staring at it a long time.
I haven't reverse-engineered the game code or looked at source code,
my version is made purely by observing game play.
---
2019-08-17 17:57:59 -04:00
Q3. Why aren't the keyboard controls the same as the original game?
2019-08-17 17:57:59 -04:00
A3. The Apple II has simplistic keyboard support.
In general it's not possible to read more than one key at a time.
2019-08-11 13:05:08 -04:00
Also on pre-IIe machines it's not really possible to get key-release events.
Additionally, on older models there's no auto-repeat unless you
hold down the REPT key, which makes running difficult.
2019-08-11 13:05:08 -04:00
The original game really depends on being able to detect having
multiple keys down at once.
---
2019-08-17 17:57:59 -04:00
Q4. Does this have joystick support?
2019-08-17 17:57:59 -04:00
A4. It should not be hard to add, and in fact would give controls much
2019-08-11 13:05:08 -04:00
closer to the original.
I probably won't have time to implement it any time soon though.
----
2019-01-20 02:01:48 -05:00
2019-08-17 17:57:59 -04:00
Q5. Is there anything impressive going on here, like with your other demos?
2019-01-26 15:05:47 -05:00
2019-08-17 17:57:59 -04:00
A5. No, it's pretty much straight up "sprite" drawing.
2019-01-26 15:05:47 -05:00
One unusual thing is I am using grey2 (color 10) as the transparent
color rather than black, as there is black in the sprites.
2019-01-27 21:44:47 -05:00
2019-08-11 13:05:08 -04:00
It's actually refreshing not having to cycle everything.
2019-01-26 15:05:47 -05:00
---
2019-08-17 17:57:59 -04:00
Q6. Why are some cutscenes tiny and some large?
2019-01-20 02:01:48 -05:00
2019-08-17 17:57:59 -04:00
A6. I started making the cutscenes before I had a good feel for
how large they'd be or how quickly they could run. Some of the
earlier ones are smaller for that reason, before I decided I
could afford full-screen ones.
2019-01-20 02:01:48 -05:00
2019-08-17 17:57:59 -04:00
---
Q7. How are you making the graphics?
A7. Using the original for reference (currently a Windows/EGA version
2019-08-11 13:05:08 -04:00
for some reason?) Size down to 80x48. (This isn't bad as the original
is roughly 320x200 which scales well).
I manually map colors to the Apple II Lo-res palette.
2019-01-20 02:01:48 -05:00
Finally fine tune in a bit while using original for reference.
2019-01-25 15:49:51 -05:00
---
2019-08-17 17:57:59 -04:00
Q8. Why lores graphics? It's so *horribly* blocky.
2019-01-25 15:49:51 -05:00
2019-08-17 17:57:59 -04:00
A8. Yes, but I like it anyway. So many colors!
2019-01-25 15:49:51 -05:00
I spent a lot of time as an ANSI artist so I am used to blocky
16-color graphics, and to be honest with you my art skills sort
of peak at that resolution.
2019-08-11 13:05:08 -04:00
Also Apple II graphics programming is painful and LORES is so
much easier than HIRES (it's also smaller, faster, and takes
less valuable RAM).
2019-01-25 15:49:51 -05:00
Partly nostalgia too, but my family only had a monochrome monitor
so I never got to experience full-color lores back in the day.
Unfortunately this game doesn't really play well in monochrome.
---
2019-01-25 15:49:51 -05:00
2019-08-17 17:57:59 -04:00
Q9. Are you going to make a version using Hi-res or Double Hi-res graphics?
2019-01-25 15:49:51 -05:00
2019-08-17 17:57:59 -04:00
A9. No, there's an official version for the Apple IIgs if you want something
2019-01-25 15:49:51 -05:00
like that. Apple II hires graphics with sprites are a huge pain
to program, would probably be slower, and would take up a lot more
RAM.
---
2019-01-25 15:49:51 -05:00
2019-08-17 17:57:59 -04:00
Q10. How about double-lores graphics (80x48)? It would give you almost
2019-01-25 15:49:51 -05:00
square pixels?
2019-08-17 17:57:59 -04:00
A10. While not as bad as Hires, double-lores is also a pain. It only
2019-01-25 15:49:51 -05:00
works on the IIe with 128k or newer. Also you now have to copy
things to aux memory, and your sprites have to worry about the
colors being shifted (I think) on the AUX page. It will take
twice the ram and probably run 1/2 the speed.
Also the current code uses page-flipping to avoid flicker/tearing,
but doing page-flipping in double-lores is really tricky.
---
2019-01-25 15:49:51 -05:00
2019-08-17 17:57:59 -04:00
Q11. Why are you targeting such an old machine, an original Apple II or II+?
2019-01-25 15:49:51 -05:00
2019-08-17 17:57:59 -04:00
A11. Well, I own one. Also there's something about programming on a machine
2019-01-25 15:49:51 -05:00
from 1977, whose graphics hardware is a glorified shift register,
and is implemented entirely out of 7400 series logic and 555 timers.
---
2019-08-17 17:57:59 -04:00
Q12. In the intro, why not have lowercase letters?
2019-08-17 17:57:59 -04:00
A12. The Apple II/II+ only supported uppercase letters by default.
Also no "|" character, which explains why some of the ASCII art
looks a bit odd.
I suppose I could auto-uppercase on older machines on the fly like
my Still Alive demo does. The memory budget is a bit tight though.
---
2019-03-04 11:43:19 -05:00
2019-08-17 17:57:59 -04:00
Q13. Could you really use this on an original Apple II from 1977?
2019-03-04 11:43:19 -05:00
2019-08-17 17:57:59 -04:00
A13. Yes, in theory. You would have needed a 48k model which would
2019-03-04 11:43:19 -05:00
have been expensive at the time ($2638). Also the disk image
will fail to auto-boot and HELLO won't run as it's in Applesoft
BASIC (not the Integer BASIC that came with the original II).
You'll have to manually type C600G and then POKE the level you
want to address 5 (0 for intro, 1 for LEVEL 1, etc)
POKE 5,2
then
BRUN LOADER
2019-03-04 11:43:19 -05:00