1
0
Fork 0
mirror of https://github.com/doukutsu-rs/doukutsu-rs synced 2025-01-04 01:57:51 +00:00

Custom SFX support

This commit is contained in:
dawnDus 2022-03-06 17:49:25 -05:00
parent cb7b2bd402
commit e1f1dd4554
No known key found for this signature in database
GPG key ID: 972AABDE81848F21
2 changed files with 48 additions and 6 deletions

View file

@ -366,6 +366,8 @@ impl SharedGameState {
self.texture_set.unload_all(); self.texture_set.unload_all();
self.sound_manager.load_custom_sound_effects(ctx, &self.constants.base_paths)?;
Ok(()) Ok(())
} }

View file

@ -156,12 +156,14 @@ impl SoundManager {
let _ = self.tx.send(PlaybackMessage::SetSampleVolume(volume.powf(3.0))); let _ = self.tx.send(PlaybackMessage::SetSampleVolume(volume.powf(3.0)));
} }
pub fn reload_songs( pub fn set_sfx_samples(&self, id: u8, data: Vec<i16>) {
&mut self, if self.no_audio {
constants: &EngineConstants, return;
settings: &Settings, }
ctx: &mut Context, let _ = self.tx.send(PlaybackMessage::SetSampleData(id, data));
) -> GameResult { }
pub fn reload_songs(&mut self, constants: &EngineConstants, settings: &Settings, ctx: &mut Context) -> GameResult {
let prev_song = self.prev_song_id; let prev_song = self.prev_song_id;
let current_song = self.current_song_id; let current_song = self.current_song_id;
@ -420,6 +422,40 @@ impl SoundManager {
Ok(()) Ok(())
} }
pub fn load_custom_sound_effects(&self, ctx: &mut Context, roots: &Vec<String>) -> GameResult {
for path in roots.iter().rev() {
let wavs = filesystem::read_dir(ctx, [path, "sfx/"].join(""))?
.filter(|f| f.to_string_lossy().to_lowercase().ends_with(".wav"));
for filename in wavs {
if let Ok(mut file) = filesystem::open(ctx, &filename) {
let wav = wav::WavSample::read_from(&mut file)?;
let id = filename
.file_stem()
.unwrap_or_default()
.to_str()
.unwrap_or_default()
.parse::<u8>()
.unwrap_or(0);
if id == 0 {
continue;
}
let step = (wav.format.channels * 2) as usize;
let data = wav
.data
.chunks_exact(2)
.into_iter()
.step_by(step)
.map(|a| i16::from_ne_bytes([a[0], a[1]]))
.collect();
self.set_sfx_samples(id, data);
}
}
}
Ok(())
}
} }
pub(in crate::sound) enum PlaybackMessage { pub(in crate::sound) enum PlaybackMessage {
@ -440,6 +476,7 @@ pub(in crate::sound) enum PlaybackMessage {
RestoreState, RestoreState,
SetSampleParams(u8, PixToneParameters), SetSampleParams(u8, PixToneParameters),
SetOrgInterpolation(InterpolationMode), SetOrgInterpolation(InterpolationMode),
SetSampleData(u8, Vec<i16>),
} }
#[derive(PartialEq, Eq)] #[derive(PartialEq, Eq)]
@ -644,6 +681,9 @@ where
Ok(PlaybackMessage::SetOrgInterpolation(interpolation)) => { Ok(PlaybackMessage::SetOrgInterpolation(interpolation)) => {
org_engine.interpolation = interpolation; org_engine.interpolation = interpolation;
} }
Ok(PlaybackMessage::SetSampleData(id, data)) => {
pixtone.set_sample_data(id, data);
}
Err(_) => { Err(_) => {
break; break;
} }