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

agb_tracker

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

15 unstable releases (5 breaking)

0.21.1 Oct 2, 2024
0.20.5 Jun 18, 2024
0.19.1 Mar 6, 2024
0.18.0 Oct 31, 2023

#364 in Audio

MPL-2.0 license

550KB
12K 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

~8.5MB
~160K SLoC