Skip to main content

Homebrew game for C64 - part 2: more SID tune fun

The development of the music for this game has gone so well - way better than the development of the gameplay itself, which I'm having serious doubts about!

Writing a silly tune was the easiest part. I've now improved that - it has a 'chorus' which is deliberately reminiscent of 'English Country Garden'. The main part of the tune is meant to accompany sheep trotting / blundering around a field.

It even has a fourth part now, although I can only use three because the C64's sound chip - SID - has three tone voices.
And here's how it sounds using the Vice C64 emulator:



Disclaimer: Tonight I've been messing around with voices and ASDR envelopes, and haven't yet found settings that I really like. The bass in particular is raspy here, I want a smooth sound, but when I use the triangle waveform it sounds very quiet even with the highest sustain volume.

In the first part of this little diary, I mentioned that I started to use Derek Morris' sound library. It allowed me to 'code' the tune with his user-friendly constants.
It worked with three voices at once but I had trouble with the synchronisation. At first I devised a method of breaking the music down into bars, and having the main program loop kick off each bar of the three voices at the same time. That's why there's a cmdEnd at the end of each bar in the code above.

That worked. To a point. The music was in sync at the start of each bar. Within each bar, things got a little rough, and I started to fiddle with the delays on certain notes to try and straighten that out. That worked. To a point. That was all a bit of a fudge, so I carefully read DM's code to make sure that it was doing what I assumed it was doing. It really was, and it's beautifully-written (I don't mean to sound patronising. I mean that I've learned so much by reading his code and his book.)

But after manually following the loops in his code around and around as if I were the processor, noting down variable values on paper, I found that the delay loops were delaying for one more cycle than I thought they were. It's to do with counting down to zero. You get one more delay than the number you specify after the CmdDelay. I wouldn't call this a bug, Mr Morris designed this for playing a sound effect on a single voice so this point is insignificant in that context.

It took a single 'dec' instruction in the right place, and the soundlib is playing my music perfectly. (although faster than before, so I've had to re-write the delay values in my sound command files so that there are 48 in each bar rather than 32). I no longer need my 'bar-by-bar' system to keep everything in sync, because as long as the delay count is the same in each bar, everything will stay in sync. That saves one byte per bar per voice, plus my sync routine and the execution time of that each programme loop.

Manually translating the notated music to the sound library instructions is very laborious. Particularly looking up the high and low note values for each note in Appendix E of the Prog Ref Guide (I bought a copy of the C64 one in the end). I'm thinking about how I might write a tool(s) to help with this, because I've really enjoyed the composition part and want to do a lot more. Possibly even a mac app to take the sheet music (as musicXML) and build those sound commands. 

Comments

Popular posts from this blog

RC2024/10 - my entry

A while ago I made this MIDI module for RC2014: It works but a better design would have its own serial chip and port decoding.  As it is, it provides the MIDI interface and a clock signal for the second SIO2 serial port. This means that it requires a little setting up and will only work for RC2014s with an SIO2 (and port B not already used). I think people might reasonably expect it to be plug-and-play and self-contained, ie do all the serial itself. My challenge to myself is to:  learn how to connect a serial chip (probably 68B50 ACIA) to receive the incoming MIDI and to serialise outgoing MIDI design the module, including the port decoding write a library so that it can easily be used on any RC2014. Potential applications include a MIDI sequencer and using incoming MIDI to trigger notes on the AY or SID sound chips. Entering the Retro Challenge 2024 (aka RC2024/10)  has given me an incentive to get on with this! I'm happy to see several more entries in the RC2014 catego...

IM53 8080 birthday cake

 Each year I've been trying to get more creative with ideas for Spencer's birthday cake. The plan this year was to incorporate LEDs in place of candles. I eventually settled on an Altair / IMSAI / PDP -style computer since those are the type of computers that inspired his RC2014. The IMSAI 8080 has the most colourful switches as well as a name that I could twist. The thought that it could show randomly flashing lights (as if the computer were running) and that it could also play a game of 'kill the bit' was very appealing. A plan formed to use a capacitive touch pad on the cake itself. The first job is to bake the fruitcake. I often use a 7" square tin and one of those cut in half and rearranged makes a cake of suitable proportions.  Even after taking a slice off the faces to make them nice and square, there are still some rounded corners, so after putting on the marzipan, I used more marzipan as a filler to flatten the whole thing. Even though I wanted to end up w...

New MSX graphics / sound / joystick module for RC2014 / RCBus

I'm impressed at what Les has packed onto this standard-sized module. It contains an FPGA replacement for the TMS9918A, a YM/AY sound module and joystick interface.  The project is open-source and is here . In MSX terms this is the VDP (vidio display processor) and PSG (programmable sound generator), thus being an alternative for both the J B Langston TMS9918A video module and Ed Brindley's YM/AY sound module and adds two joystick ports to boot. All on a single module for RC2014 or compatible computers. There's no room for the d-sub joystick ports, so headers are provided so that these ribbon cables can be used.  This is a neat solution for those wishing to take advantage of Les' MSX8 system , which loads most MSX rom files along with a modified MSX BIOS from CP/M on a ROMWBW RC2014.  It is hard-wired to the MSX ports for the sound and video, so it won't be suitable for those wanting to run Colecovision ROMs, for example. I'm torn myself between the real TMS ...