Manic Miner Progress
Baggers
Posts: 3,019
Hi All,
This is the TV out from the Propeller, running my Manic Miner.
Looking good so far though, don't you think?
I've got levels up and running on the chip, now to sort out where the sprites are and start adding some
http://www.jimbagley.co.uk/jb_manic.binary
It now cycles through ALL 20 levels ( set up as hydra pins for tv out 12-14 and 5Mhz clock )
Post Edited (Baggers) : 5/11/2007 8:54:28 PM GMT
This is the TV out from the Propeller, running my Manic Miner.
Looking good so far though, don't you think?
I've got levels up and running on the chip, now to sort out where the sprites are and start adding some
http://www.jimbagley.co.uk/jb_manic.binary
It now cycles through ALL 20 levels ( set up as hydra pins for tv out 12-14 and 5Mhz clock )
Post Edited (Baggers) : 5/11/2007 8:54:28 PM GMT
Comments
Andre'
It's not a screen shot of another game! surely if it was a screenshot from a game, it would have the sprites on it too.
It's my SDL app I wrote last night, that reads through the data and displays it correctly.
So yes it is working so far as such, just in SDL on a PC.
I can view all 20 levels.
Like I said, next step is to get something on the TV now that I know how the data is stored.
Baggers.
I was aware that knowing the exact format would speed up the process, but this is a very fast result!
CarboardGuru, all the info about the actual format can be found at the "room format" page here:
www.geocities.com/andrewbroad/spectrum/willy/mm_format.html
and there you can see that all the block graphics are stored as nine bytes, one byte color attribute, and eight bytes for the 8x8 graphics block. The whole "room" (screen) is built up from these building blocks. Run length encoding is not used, nor necessary. How it all works is actually quite interesting and very well thought out!
Baggers, I assume that you only wanted to test the block graphics on the PC to see if you could get a result quickly, and that after you have ported your code to the HYDRA all the other data in the room format will be directly tested on the HYDRA, instead of on the PC?
Well, good luck with porting it to the HYDRA, I am curious whether the TV driver of Donkey Kong can be used, or whether you have to write a new driver.
Also, the title screen, and "game over" animations are not in the "room format", so I am curious about them, are you going to have a title screen and "game over" animation?
Note that the original title screen was just a passive graphics screen, but made a very smart use of the spectrums "blinking attribute" to emulate an animation, so that all the spectrums CPU time could be used to create the title music.
I hope you also found the main technical page about the MM and JSW too, if not its here:
www.geocities.com/andrewbroad/spectrum/willy/
The page about MM & JSW sound is here:
www.geocities.com/andrewbroad/spectrum/willy/music.html
Mahjongg
It's more attribute compressed, each level is 16x32 bytes ( an attribute colour ) then there are 8 characters per level which are used ( blank/wall/crumble/conveyor etc. ) each character definition is 9 bytes 1 byte attr ( matching the one from the level map ) then 8 bytes char (8x8 pixels). all levels are 1024Bytes. 20KB for the full 20 levels. wonder if i can get it all in 32KB [noparse]:)[/noparse] that'll be a challenge.
mahjongg,
thanks [noparse]:)[/noparse] and yes, that was a test on the PC to see to make sure that my understanding of the data layout was correct, ( thankfully it is ). now for porting it to Prop.
as for TV driver, I can use this for now, but I'll probably re-write it later on if need be, to make it more spectrum 2colour friendly.
as for the game over / foot screen, that should be easy to replicate. and the title screen, I can use some extra characters for that, as the levels only use 8
Anyway, I've got it working on that now too, and the little miners walking on the bottom third of the display.
will post progress tomorrow.
Baggers
edit: I've also added a VSync notifier to the spectrum TV display, so I can sync displaying graphics, to save flicker [noparse]:)[/noparse]
·
I remember the port of Chuckie Egg to the BBC Micro, complete with Spectrum like single colour sprites. That was a fun game.
Looks like we have a few Brits here.
BTW, I suggest that you add updates at the end of your thread rather than edit the first post. It kind of makes a nonsense of the replies for anyone reading later. Also what's this binary business? Where's the source?
Post Edited (CardboardGuru) : 5/12/2007 11:25:13 PM GMT
Andre'
Andre'
Yeah, BBC had some amazing ports, chuckie egg and defender being two of my faves, revs + elite being awsome games too.
As for the binary, sorry, I wanted to optimise the code a bit, and comment it, since these posts are not only for nostalgia, but they're for education purposes too, and I hadn't commented it, and since your driver and jlcebrian's driver are heavily commented, I thought I best copy suite... So once that's done I'll post source. [noparse]:)[/noparse]
edit: Yup, nice to see some brits on here too. ( anyone tried doing a PAL tv out?
Andre'
yes, I prototyped on SDL, as it's easier to know that once I know exactly how the graphics are stored, then I could convert quickly to hydra.
and thanks.
and don't worry, I won't forget to add sound effects [noparse]:)[/noparse]
Oh, and for future reference, updates will be at the bottom, not edited to the top [noparse]:)[/noparse]
Baggers.
Andre'
You could put all the levels into the unused EEPROM room above the 32K border using the "Hydra Asset Manager" tool (see: http://forums.parallax.com/showthread.php?p=628778), and download the level you want into a 1K buffer when you need it, using your own I2C download routine.
You can pilfer the code to do that from FemtoBasic (see: http://forums.parallax.com/showthread.php?p=643838) or from some other project that uses a I2C routine to directly access the EEPROM, there seem to be many these days.
What is this "SDL" you are talking about? is it (for example) "Simple Declarative Language" or "Specification and Description Language", or something else altogether? and why did you use SDL for this quick prototyping job? I have never heard of it, is it simple to use?
It's very interesting that suddenly we see a deluge of new games, and game building blocks. (Donkey kong video driver with multicolor sprites, spectrum video driver, Hydra Dense Music Format etc. etc.). This promises much for the future!
Mahjongg
SDL = Simple DirectMedia Layer ( see:·http://www.libsdl.org/ )
Baggers.
Cheers for links mahjongg, the problem with using >32Kb is that it's awkward to get it there in the first place.
I want it to load quickly and easily.
What I might do, is have no buffers, just use the level data as screen etc. and make it so you download the game directly to EEPROM first, as it will overwrite the level data.
It's getting there though
Why don't you convert the levels into run length encoded versions? If you look at the screens, they all consist of long horizontal runs of the same tile. So store a byte for the tile followed by a byte for the run length for each run*. And then uncompress them at the start of each level.
So, looking at the first 2 lines of central cavern as shown in the picture, the first line has 11 runs = 22 bytes
The second line has 5 runs = 10 bytes. (but it shares the last tile of line 1, so actually 4 runs = 8 bytes)
Versus the standard 32 bytes per line.
Looking at the screens, a run length of greater than 16 is rare, so you could perhaps use 4 bits for the run length and do 2 run lengths per 3 bytes rather than per 4 bytes.
As for byte per count, I could easily do that anyway, as there are ONLY 8 background characters, so could even be up to 32 length [noparse]:)[/noparse]
but again, that's for later, as I'm now doing the sprite renderer, in a seperate asm cog, as SPIN is taking about 48 scan lines just to draw the four Willy's on the bottom and the one on screen, and it's just writing words, not even or'ing them onto the screen.
Cheers for the input though [noparse]:)[/noparse]
Also, I was keeping the levels uncompressed for the moment, because I was going to make it play the many ManicMiner mod's it appears there's a few versions where people have made editors and changed the levels.
but I'll probably add the compressor exe, so that people can still change to what map levels they want.
I've had fun doing this, and will most likely have a crack at JSW after this is done [noparse]:)[/noparse]
I'll be releasing two versions,
One for Hydra ( I don't have a hydra, so I'll probably need someone to test it for me. )
And the other for the ProtoBoard, so normal Prop users ( like myself ) can play it too.
Baggers.
I Still have Eugene to do and slow moving baddies, and some other bits and pieces, then it's ready for a release.
then I'll comment the source, ( if people want it commenting that is, otherwise I'll not waste time doing that and jump onto JSW )
I use a LCD TV with PAL and I loaded the binary to RAM.
Does your LCD handle NTSC? as the JLC Spectrum TV is an NTSC display [noparse]:([/noparse] I'm in the UK ( PAL area too ) but my TV handles NTSC, if yours does, then it's something else, JLC did say he had timing issues with some LCD's, maybe your LCD needs stricter timing.
I will however be trying to re-do the Spectrum TV so that it's all my code, and I'll be attempting a PAL display too [noparse]:)[/noparse]
Baggers.
Oh well, have to wait for your PAL code then. [noparse]:)[/noparse]
PS, I all but finished it last night, I just have some timing issues with the Solar Power Level.
So be expecting the first release some time later today [noparse]:)[/noparse]
It's not commented as of yet, but that can come later if requested.
Baggers.
By the way RedNifre, do you use a Protoboard, or Hydra, I'm wondering, cos·most hydra·things are NTSC.
Post Edited (Baggers) : 5/22/2007 8:07:42 AM GMT
Wow! Staggeringly fast performace!
1. Hydra version
2. Proto-board version - hi-eeprom level data
3. Proto-board version - SDCard level data
I'll need someone to test the Hydra version for me.
once it's working, I'll release source.
I'm just taking my daughter to school now, then I'll post the hydra version for someone to test and give feedback, while I pack and upload Protoboard versions.
Baggers.
Hydra version has been uploaded, for someone to test, so that I know it works on a Hydra.
http://www.jimbagley.co.uk/HydraManicMiner.rar
http://www.jimbagley.co.uk/HydraManicMiner.zip
Can someone test it, and let me know if it works.
Thanks,
Baggers.
Edit: I've added www. and added a .zip file.
Post Edited (Baggers) : 5/22/2007 2:34:35 PM GMT
A few problems, none of them to do with the actual game!
1) The URL needs a www in it.
2) Someone's server isn't confirgured right, in Firefox the link doesn;t download, it displays garbage on the screen. IE copes with it though.
3) I don't have a RAR unarchive program installed. Did you know Prop Tool has a automatic zipping facility. File/Archive/Project. It'll zip up the current top object file together with an objects that it uses. Or is it that you have some issue with zips?
I've got to go out now. I'll have another try later.
http://www.jimbagley.co.uk/ProtoManicMiner.rar
http://www.jimbagley.co.uk/ProtoManicMiner.zip
and
http://www.jimbagley.co.uk/SDManicMiner.rar
http://www.jimbagley.co.uk/SDManicMiner.zip
Can people test and let me know how if it's worked.
I'll release source soon as I have confirmation that it works on all platforms.
Cheers,
Baggers.
PS, on a side note... Does anyone know how to remove double linefeeds? lol
OK, I tried it some more. Downloaded WinRAR and got the file uncompressed. Still more problems I'm afraid.
1) The GO.BAT uses COM6. I think the default set up for the Hydra port is COM4.
2) After changing the com port, the Hydra would reset as expected, but the uploads failed. Tried several times.
3) I tried programming the binaries using HAM and Prop tool instead. But I wasn't sure where to put the upper memory binary. I tried 0x10000 and uploaded the main binary with Prop tool. The Manic miner program ran, with text and graphics on the bottom of the screen. But the level area was just random garbage.
Andre'
The upper memory binary is itself an prop executable which you load into ram, it then shows a garbage screen, while it copies the level data etc it needs to from $8000-$e800. once it's complete it will show the title pic, and say DONE in the bottom of the screen.
at this time, you then download the main binary to ram or load to eeprom $0000
hope this helps.
sorry for the COM6 in go.bat that's cos it's COM6 for me [noparse]:)[/noparse] I forgot to tell people to change the port number. my bad
BOB,
Is your COM port 4 or 6? go.bat is set up to use 6 as default.
Baggers.
OK, got it now by loading both eeprom files with Prop tool. I'm one of those unfortunate people for who the serial link to the Hydra only works successfully 50% of the time even with prop tool. With that exe it hasn't worked at all. But prop tool did the job.
The game itself works great! Though I haven't managed to get past the first screen yet. I can see that for the middle key in the top row I have to jump either early or late, but I haven't managed to time it right yet.
Well done Jim!