Struct web_audio_api::node::AudioBufferSourceNode
source · [−]pub struct AudioBufferSourceNode { /* private fields */ }
Expand description
AudioBufferSourceNode
represents an audio source that consists of an
in-memory audio source (i.e. an audio file completely loaded in memory),
stored in an AudioBuffer
.
- MDN documentation: https://developer.mozilla.org/en-US/docs/Web/API/AudioBufferSourceNode
- specification: https://webaudio.github.io/web-audio-api/#AudioBufferSourceNode
- see also:
BaseAudioContext::create_buffer_source
Usage
use std::fs::File;
use web_audio_api::context::{BaseAudioContext, AudioContext};
use web_audio_api::node::{AudioNode, AudioScheduledSourceNode};
// create an `AudioContext`
let context = AudioContext::new(None);
// load and decode a soundfile
let file = File::open("samples/sample.wav").unwrap();
let audio_buffer = context.decode_audio_data_sync(file).unwrap();
// play the sound file
let src = context.create_buffer_source();
src.set_buffer(audio_buffer);
src.connect(&context.destination());
src.start();
Examples
cargo run --release --example trigger_soundfile
cargo run --release --example granular
Implementations
sourceimpl AudioBufferSourceNode
impl AudioBufferSourceNode
sourcepub fn new<C: BaseAudioContext>(
context: &C,
options: AudioBufferSourceOptions
) -> Self
pub fn new<C: BaseAudioContext>(
context: &C,
options: AudioBufferSourceOptions
) -> Self
Create a new AudioBufferSourceNode
instance
sourcepub fn start_at_with_offset(&self, start: f64, offset: f64)
pub fn start_at_with_offset(&self, start: f64, offset: f64)
Start the playback at the given time and with a given offset
Panics
Panics if the source was already started
sourcepub fn start_at_with_offset_and_duration(
&self,
start: f64,
offset: f64,
duration: f64
)
pub fn start_at_with_offset_and_duration(
&self,
start: f64,
offset: f64,
duration: f64
)
Start the playback at the given time, with a given offset, for a given duration
Panics
Panics if the source was already started
sourcepub fn buffer(&self) -> Option<&AudioBuffer>
pub fn buffer(&self) -> Option<&AudioBuffer>
Current buffer value (nullable)
sourcepub fn set_buffer(&self, audio_buffer: AudioBuffer)
pub fn set_buffer(&self, audio_buffer: AudioBuffer)
Provide an AudioBuffer
as the source of data to be played bask
Panics
Panics if a buffer has already been given to the source (though new
or through
set_buffer
)
sourcepub fn playback_rate(&self) -> &AudioParam
pub fn playback_rate(&self) -> &AudioParam
K-rate AudioParam
that defines the speed at which the AudioBuffer
will be played, e.g.:
0.5
will play the file at half speed-1
will play the file in reverse
Note that playback rate will also alter the pitch of the AudioBuffer
sourcepub fn detune(&self) -> &AudioParam
pub fn detune(&self) -> &AudioParam
K-rate AudioParam
that defines a pitch transposition of the file,
expressed in cents
sourcepub fn loop_(&self) -> bool
pub fn loop_(&self) -> bool
Defines if the playback the AudioBuffer
should be looped
pub fn set_loop(&self, value: bool)
sourcepub fn loop_start(&self) -> f64
pub fn loop_start(&self) -> f64
Defines the loop start point, in the time reference of the AudioBuffer
pub fn set_loop_start(&self, value: f64)
sourcepub fn loop_end(&self) -> f64
pub fn loop_end(&self) -> f64
Defines the loop end point, in the time reference of the AudioBuffer
pub fn set_loop_end(&self, value: f64)
Trait Implementations
sourceimpl AudioNode for AudioBufferSourceNode
impl AudioNode for AudioBufferSourceNode
fn registration(&self) -> &AudioContextRegistration
fn channel_config_raw(&self) -> &ChannelConfig
sourcefn number_of_inputs(&self) -> u32
fn number_of_inputs(&self) -> u32
The number of inputs feeding into the AudioNode. For source nodes, this will be 0.
sourcefn number_of_outputs(&self) -> u32
fn number_of_outputs(&self) -> u32
The number of outputs coming out of the AudioNode.
fn id(&self) -> &AudioNodeId
fn channel_config_cloned(&self) -> ChannelConfig
sourcefn context(&self) -> &ConcreteBaseAudioContext
fn context(&self) -> &ConcreteBaseAudioContext
The BaseAudioContext which owns this AudioNode.
sourcefn connect<'a>(&self, dest: &'a dyn AudioNode) -> &'a dyn AudioNode
fn connect<'a>(&self, dest: &'a dyn AudioNode) -> &'a dyn AudioNode
Connect the output of this AudioNode to the input of another node. Read more
sourcefn connect_at<'a>(
&self,
dest: &'a dyn AudioNode,
output: u32,
input: u32
) -> &'a dyn AudioNode
fn connect_at<'a>(
&self,
dest: &'a dyn AudioNode,
output: u32,
input: u32
) -> &'a dyn AudioNode
Connect a specific output of this AudioNode to a specific input of another node. Read more
sourcefn disconnect_from<'a>(&self, dest: &'a dyn AudioNode) -> &'a dyn AudioNode
fn disconnect_from<'a>(&self, dest: &'a dyn AudioNode) -> &'a dyn AudioNode
Disconnects all outputs of the AudioNode that go to a specific destination AudioNode.
sourcefn disconnect(&self)
fn disconnect(&self)
Disconnects all outgoing connections from the AudioNode.
sourcefn channel_count_mode(&self) -> ChannelCountMode
fn channel_count_mode(&self) -> ChannelCountMode
Represents an enumerated value describing the way channels must be matched between the node’s inputs and outputs. Read more
fn set_channel_count_mode(&self, v: ChannelCountMode)
sourcefn channel_interpretation(&self) -> ChannelInterpretation
fn channel_interpretation(&self) -> ChannelInterpretation
Represents an enumerated value describing the meaning of the channels. This interpretation will define how audio up-mixing and down-mixing will happen. Read more
fn set_channel_interpretation(&self, v: ChannelInterpretation)
sourcefn channel_count(&self) -> usize
fn channel_count(&self) -> usize
Represents an integer used to determine how many channels are used when up-mixing and down-mixing connections to any inputs to the node. Read more
fn set_channel_count(&self, v: usize)
Auto Trait Implementations
impl RefUnwindSafe for AudioBufferSourceNode
impl Send for AudioBufferSourceNode
impl Sync for AudioBufferSourceNode
impl Unpin for AudioBufferSourceNode
impl UnwindSafe for AudioBufferSourceNode
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more