soundtouch

Crates.iosoundtouch
lib.rssoundtouch
version0.4.2
sourcesrc
created_at2023-10-15 03:26:28.19681
updated_at2024-08-31 06:27:29.263264
descriptionA utility wrapper around the SoundTouch C++ audio library
homepage
repositoryhttps://github.com/Cyanistic/soundtouch
max_upload_size
id1003444
size582,670
Cyanism (Cyanistic)

documentation

README

soundtouch

Crates.io Documentation

A safe utility wrapper around the SoundTouch C++ audio library. The API is very similar to the original C++ API.

Most of the documentation is copied from the SoundTouch repository.

High Level Example

use soundtouch::{SoundTouch, Setting};

let mut soundtouch = SoundTouch::new();
soundtouch
    .set_channels(2)
    .set_sample_rate(44100)
    .set_tempo(1.10)
    // Recommended setting to speed up processing
    .set_setting(Setting::UseQuickseek, 1);

// use actual audio samples here
let samples = vec![0.0; 44100 * 2];
let output_samples = soundtouch.generate_audio(&samples);

// do something with output_samples

Low Level Example

use soundtouch::{SoundTouch, Setting};

let mut soundtouch = SoundTouch::new();
soundtouch
    .set_channels(2)
    .set_sample_rate(44100)
    .set_tempo(1.10)    
    // Recommended setting to speed up processing
    .set_setting(Setting::UseQuickseek, 1);

// use actual audio samples here
let mut samples = vec![0.0; 44100 * 2];

const BUF_SIZE: usize = 6720;
let mut new_samples: [f32; BUF_SIZE] = [0.0; BUF_SIZE];
let mut output_samples: Vec<f32> = Vec::with_capacity(samples.len());
soundtouch.put_samples(&samples, samples.len() / 2);
let mut n_samples = 1;
while n_samples != 0 {
    n_samples = soundtouch.receive_samples(
        new_samples.as_mut_slice(),
        BUF_SIZE / 2
        );
    output_samples.extend_from_slice(&new_samples);
}
soundtouch.flush();

// do something with output_samples

Both examples should produce the same output.

Commit count: 10

cargo fmt