About
SNDDRV is a new PSG sound driver inspired by Arkos Tracker 2.
SNDDRV covers almost feature of replayer of the Arkos Tracker 2.
SNDDRV and libmsx's build system make it easy to integrate Arkos Tracker 2 song file (.aks file) into your application.
Let's make your music with Arkos Tracker 2. Place its .aks files in your application's repository, and build together with your application code that uses SNDDRV API.
Features
- Supported sound chip
- Functionallity
- NTSC (60Hz), PAL/SECAM (50Hz), auto detect and auto adjust.
- Available to specify default playing frequency that the sound data author expecting.
- Run-time replay speed/frequency control.
- Stop, Start, Pause, Resume, Auto-Repeat.
- Playing sound effects (SFX) during playing background music (BGM).
- Same data format for BGM and SFX.
- Expressions
- Arpeggio
- Pitch slide
- Pitch glide
- Volume
- Volume fade in
- Volume fade out
- User defined arpeggio / pitch-bend tables
- User defined period / wavelength modification tables (e.g. for vibrato)
- Instrument (timbre)
- User defined instrument (timbre) tables
- Software amplitude envelope generator
- Noise generator
- Tone / Noise mixing
- Hardware amplitude envelope generator (Saw, Triangle, Inv-Saw, Inv-Triangle wave)
- Use hardware envelope generator as frequency modulator!
- Arpeggio / Pitch-bend
- Period / wavelength modification
- Ease to integration
- A support tool
aks2c.sh
translates Arkos Tracker 2 song file (.aks) to C source file.
- The
libmsx
's build system (makefiles) can automatically translates .aks files into C source files and built them into your application. It automates the following workflow.
- Translate .aks files into C source files.
- Compile translated C source files, all other C and ASM source files.
- Build all of them into your application.
How to integrate Arkos Tracker 2 .aks files into your application
- Make music with Arkos Tracker 2, and save as .aks file.
- Place .aks file(s) into
src
folder of your repository.
- Write application source code, for example such as the following, and place it into
src
folder:
Note that the filename of .aks file is also used as name of corresponding C source files and/or name of variable of snd_SoundAssets
type. Therefore it must be a legal identifier in C language.
For example, my_bgm.aks
, playlist000.aks
are okay.
But my bgm.aks
, 2022_Greatest_Hits.aks
, My favorite songs.aks
are invalid.
#include "my_bgm.h"
void main(void) {
for (;;) {
}
}
void set_vsync_handler(void(*handler)(void))
MSX Register user defined VSYNC interrupt handler.
void snd_start(void)
MSX Start / Resume music.
void snd_init(void)
MSX Initialize the PSG and the sound driver.
void snd_play(void)
MSX Main routine of the sound driver.
void snd_set_bgm(uint8_t index, const snd_SoundAssets *sa)
MSX Sets the specified music as BGM in the sound driver.
Using #include <msx.h> includes almost all C header files in libmsx, for ease to use.
See also