mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-09 08:31:33 +11:00
Try a new song and add memory support
This commit is contained in:
parent
1a25268285
commit
0911ca44c5
BIN
tracker/agb-tracker/examples/algar_-_ninja_on_speed.xm
Normal file
BIN
tracker/agb-tracker/examples/algar_-_ninja_on_speed.xm
Normal file
Binary file not shown.
|
@ -6,7 +6,7 @@ use agb::Gba;
|
||||||
use agb_tracker::{include_xm, Track, Tracker};
|
use agb_tracker::{include_xm, Track, Tracker};
|
||||||
|
|
||||||
// Found on: https://modarchive.org/index.php?request=view_by_moduleid&query=36662
|
// Found on: https://modarchive.org/index.php?request=view_by_moduleid&query=36662
|
||||||
const DB_TOFFE: Track = include_xm!("examples/db_toffe.xm");
|
const DB_TOFFE: Track = include_xm!("examples/algar_-_ninja_on_speed.xm");
|
||||||
|
|
||||||
#[agb::entry]
|
#[agb::entry]
|
||||||
fn main(mut gba: Gba) -> ! {
|
fn main(mut gba: Gba) -> ! {
|
||||||
|
|
|
@ -124,7 +124,7 @@ impl Tracker {
|
||||||
tick: 0,
|
tick: 0,
|
||||||
|
|
||||||
current_row: 0,
|
current_row: 0,
|
||||||
current_pattern: 0,
|
current_pattern: 2,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -106,6 +106,8 @@ pub fn parse_module(module: &Module) -> TokenStream {
|
||||||
let mut patterns = vec![];
|
let mut patterns = vec![];
|
||||||
let mut pattern_data = vec![];
|
let mut pattern_data = vec![];
|
||||||
|
|
||||||
|
let mut effect_parameters = [0; u8::MAX as usize];
|
||||||
|
|
||||||
for pattern in &module.pattern {
|
for pattern in &module.pattern {
|
||||||
let start_pos = pattern_data.len();
|
let start_pos = pattern_data.len();
|
||||||
|
|
||||||
|
@ -166,6 +168,13 @@ pub fn parse_module(module: &Module) -> TokenStream {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let effect_parameter = if slot.effect_parameter != 0 {
|
||||||
|
effect_parameters[slot.effect_type as usize] = slot.effect_parameter;
|
||||||
|
slot.effect_parameter
|
||||||
|
} else {
|
||||||
|
effect_parameters[slot.effect_type as usize]
|
||||||
|
};
|
||||||
|
|
||||||
let effect2 = match slot.effect_type {
|
let effect2 = match slot.effect_type {
|
||||||
0x0 => {
|
0x0 => {
|
||||||
if slot.effect_parameter == 0 {
|
if slot.effect_parameter == 0 {
|
||||||
|
@ -203,7 +212,7 @@ pub fn parse_module(module: &Module) -> TokenStream {
|
||||||
let c4_speed = note_to_speed(Note::C4, 0.0, 0, module.frequency_type);
|
let c4_speed = note_to_speed(Note::C4, 0.0, 0, module.frequency_type);
|
||||||
let speed = note_to_speed(
|
let speed = note_to_speed(
|
||||||
Note::C4,
|
Note::C4,
|
||||||
slot.effect_parameter as f64,
|
effect_parameter as f64,
|
||||||
0,
|
0,
|
||||||
module.frequency_type,
|
module.frequency_type,
|
||||||
);
|
);
|
||||||
|
@ -216,7 +225,7 @@ pub fn parse_module(module: &Module) -> TokenStream {
|
||||||
let c4_speed = note_to_speed(Note::C4, 0.0, 0, module.frequency_type);
|
let c4_speed = note_to_speed(Note::C4, 0.0, 0, module.frequency_type);
|
||||||
let speed = note_to_speed(
|
let speed = note_to_speed(
|
||||||
Note::C4,
|
Note::C4,
|
||||||
-(slot.effect_parameter as f64),
|
-(effect_parameter as f64),
|
||||||
0,
|
0,
|
||||||
module.frequency_type,
|
module.frequency_type,
|
||||||
);
|
);
|
||||||
|
@ -229,8 +238,8 @@ pub fn parse_module(module: &Module) -> TokenStream {
|
||||||
PatternEffect::Panning(Num::new(slot.effect_parameter as i16 - 128) / 128)
|
PatternEffect::Panning(Num::new(slot.effect_parameter as i16 - 128) / 128)
|
||||||
}
|
}
|
||||||
0xA => {
|
0xA => {
|
||||||
let first = slot.effect_parameter >> 4;
|
let first = effect_parameter >> 4;
|
||||||
let second = slot.effect_parameter & 0xF;
|
let second = effect_parameter & 0xF;
|
||||||
|
|
||||||
if first == 0 {
|
if first == 0 {
|
||||||
PatternEffect::VolumeSlide(-Num::new(second as i16) / 16)
|
PatternEffect::VolumeSlide(-Num::new(second as i16) / 16)
|
||||||
|
|
Loading…
Reference in a new issue