dynwave is a dynamic audio player based on fixed samples stream, written in Rust.
The purpose of this is to implement a cross platform audio player that plays audio samples stream generated and plays it real-time.
This works as a fusion between rubato and cpal.
This is useful for emulators for example, where an emulation loop will be like this:
- Run emulation for a frame.
- Extract the collected audio samples for that frame.
- Queue the samples for playing (using
dynwave). - Take video frame and display it.
- Repeat.
You can use dynwave to play audio streams for your Rust projects.
Add it as a dependency in your Cargo.toml file:
cargo add dynwaveuse dynwave::{AudioPlayer, BufferSize};
let mut player = AudioPlayer::<f32>::new(44100, BufferSize::OneSecond).unwrap();
// Start playing the audio
player.play().unwrap();
// generate audio samples (can be done in a emulation loop for example)
let samples = generate_samples();
player.queue(&samples);
// pause the audio
player.pause().unwrap();The minimum supported Rust version for this crate is 1.70.0.
Contributions are welcome, please open an issue or a PR if you have any suggestions or ideas.
Make sure to:
- Run
cargo fmt. - Run
cargo clippy. - Run
cargo test.
If you are using
dynwavein your project, please open a PR to add it here.
| Project | Description |
|---|---|
| mizu | A GameBoy emulator written in Rust (this is actually were this library originiated Amjad50/mizu#11) |
| trapezoid | PSX emulator powered with Vulkan and Rust |
| plastic | NES emulator with TUI and GUI |
This project is licensed under the MIT License - see the LICENSE file for details