#gameboy-advance #music #tracker #agb #playing #format #channel

agb_tracker

Library for playing tracker music. Designed for use with the agb library for the Game Boy Advance.

13 releases (4 breaking)

0.20.5 Jun 18, 2024
0.20.4 Jun 13, 2024
0.20.2 May 25, 2024
0.19.1 Mar 6, 2024
0.16.0 Oct 3, 2023

#435 in Audio

24 downloads per month

MPL-2.0 license

485KB
11K SLoC

agb_tracker

agb_tracker is a library for playing tracker music on the Game Boy Advance (GBA) using the agb library.

The default mechanism for playing background music using agb is to include a the entire music as a raw sound file. However, this can get very large (>8MB) for only a few minutes of music, taking up most of your limited ROM space.

Using a tracker, you can store many minutes of music in only a few kB of ROM which makes the format much more space efficient at the cost of some CPU.

This library uses about 20-30% of the GBA's CPU time per frame, for 4 channels but most of that is agb's mixing. The main step function uses around 2000 cycles (<1%).

Example

#![no_std]
#![no_main]

use agb::{Gba, sound::mixer::Frequency};
use agb_tracker::{include_xm, Track, Tracker};

static DB_TOFFE: Track = include_xm!("examples/db_toffe.xm");

#[agb::entry]
fn main(mut gba: Gba) -> ! {
    let vblank_provider = agb::interrupt::VBlank::get();

    let mut mixer = gba.mixer.mixer(Frequency::Hz32768);
    mixer.enable();

    let mut tracker = Tracker::new(&DB_TOFFE);

    loop {
        tracker.step(&mut mixer);
        mixer.frame();

        vblank_provider.wait_for_vblank();
    }
}

Note that currently you have to select 32768Hz as the frequency for the mixer. This restriction will be lifted in a future version.

Concepts

The main concept of the agb_tracker crate is to move as much of the work to build time as possible to make the actual playing as fast as we can. The passed tracker file gets parsed and converted into a simplified format which is then played while the game is running.

In theory, the format the tracker file gets converted into is agnostic to the base format. Currently, only XM is implemented, however, more formats could be added in future depending on demand.

Dependencies

~8MB
~152K SLoC