pub struct StreamingSoundData<Error>where
Error: Send + 'static,{
pub(crate) decoder: Box<dyn Decoder<Error = Error>>,
pub settings: StreamingSoundSettings,
pub slice: Option<(usize, usize)>,
}
Expand description
A streaming sound that is not playing yet.
Fields§
§decoder: Box<dyn Decoder<Error = Error>>
§settings: StreamingSoundSettings
Settings for the streaming sound.
slice: Option<(usize, usize)>
The portion of the sound this StreamingSoundData
represents.
Note that the StreamingSoundData
holds the entire piece of audio
it was originally given regardless of the value of slice
, but
StreamingSoundData::num_frames
and StreamingSoundData::duration
will behave as if this StreamingSoundData
only contained the specified
portion of audio.
Implementations§
§impl<Error> StreamingSoundData<Error>where
Error: Send,
impl<Error> StreamingSoundData<Error>where
Error: Send,
pub fn from_decoder(
decoder: impl Decoder<Error = Error> + 'static,
) -> StreamingSoundData<Error>
pub fn from_decoder( decoder: impl Decoder<Error = Error> + 'static, ) -> StreamingSoundData<Error>
Creates a StreamingSoundData
for a Decoder
.
pub fn start_time(
self,
start_time: impl Into<StartTime>,
) -> StreamingSoundData<Error>
pub fn start_time( self, start_time: impl Into<StartTime>, ) -> StreamingSoundData<Error>
Sets when the sound should start playing.
§Examples
Configuring a sound to start 4 ticks after a clock’s current time:
use kira::{
manager::{AudioManager, AudioManagerSettings, backend::DefaultBackend},
sound::streaming::{StreamingSoundData, StreamingSoundSettings},
clock::ClockSpeed,
};
let mut manager = AudioManager::<DefaultBackend>::new(AudioManagerSettings::default())?;
let clock_handle = manager.add_clock(ClockSpeed::TicksPerMinute(120.0))?;
let sound = StreamingSoundData::from_file("sound.ogg")?
.start_time(clock_handle.time() + 4);
pub fn start_position(
self,
start_position: impl Into<PlaybackPosition>,
) -> StreamingSoundData<Error>
pub fn start_position( self, start_position: impl Into<PlaybackPosition>, ) -> StreamingSoundData<Error>
Sets where in the sound playback should start.
pub fn loop_region(
self,
loop_region: impl IntoOptionalRegion,
) -> StreamingSoundData<Error>
pub fn loop_region( self, loop_region: impl IntoOptionalRegion, ) -> StreamingSoundData<Error>
Sets the portion of the sound that should be looped.
§Examples
Configure a sound to loop the portion from 3 seconds in to the end:
let sound = StreamingSoundData::from_file("sound.ogg")?.loop_region(3.0..);
Configure a sound to loop the portion from 2 to 4 seconds:
let sound = StreamingSoundData::from_file("sound.ogg")?.loop_region(2.0..4.0);
pub fn volume(
self,
volume: impl Into<Value<Volume>>,
) -> StreamingSoundData<Error>
pub fn volume( self, volume: impl Into<Value<Volume>>, ) -> StreamingSoundData<Error>
Sets the volume of the sound.
§Examples
Set the volume as a factor:
let sound = StreamingSoundData::from_file("sound.ogg")?.volume(0.5);
Set the volume as a gain in decibels:
let sound = StreamingSoundData::from_file("sound.ogg")?.volume(kira::Volume::Decibels(-6.0));
Link the volume to a modulator:
use kira::{
manager::{AudioManager, AudioManagerSettings, backend::DefaultBackend},
modulator::tweener::TweenerBuilder,
sound::streaming::StreamingSoundData,
};
let mut manager = AudioManager::<DefaultBackend>::new(AudioManagerSettings::default())?;
let tweener = manager.add_modulator(TweenerBuilder {
initial_value: 0.5,
})?;
let sound = StreamingSoundData::from_file("sound.ogg")?.volume(&tweener);
pub fn playback_rate(
self,
playback_rate: impl Into<Value<PlaybackRate>>,
) -> StreamingSoundData<Error>
pub fn playback_rate( self, playback_rate: impl Into<Value<PlaybackRate>>, ) -> StreamingSoundData<Error>
Sets the playback rate of the sound.
Changing the playback rate will change both the speed and the pitch of the sound.
§Examples
Set the playback rate as a factor:
let sound = StreamingSoundData::from_file("sound.ogg")?.playback_rate(0.5);
Set the playback rate as a change in semitones:
use kira::sound::PlaybackRate;
let sound = StreamingSoundData::from_file("sound.ogg")?.playback_rate(PlaybackRate::Semitones(-2.0));
Link the playback rate to a modulator:
use kira::{
manager::{AudioManager, AudioManagerSettings, backend::DefaultBackend},
modulator::tweener::TweenerBuilder,
sound::streaming::StreamingSoundData,
};
let mut manager = AudioManager::<DefaultBackend>::new(AudioManagerSettings::default())?;
let tweener = manager.add_modulator(TweenerBuilder {
initial_value: 0.5,
})?;
let sound = StreamingSoundData::from_file("sound.ogg")?.playback_rate(&tweener);
pub fn panning(
self,
panning: impl Into<Value<f64>>,
) -> StreamingSoundData<Error>
pub fn panning( self, panning: impl Into<Value<f64>>, ) -> StreamingSoundData<Error>
Sets the panning of the sound, where 0 is hard left and 1 is hard right.
§Examples
Set the panning to a streaming value:
let sound = StreamingSoundData::from_file("sound.ogg")?.panning(0.25);
Link the panning to a modulator:
use kira::{
manager::{AudioManager, AudioManagerSettings, backend::DefaultBackend},
modulator::tweener::TweenerBuilder,
sound::streaming::StreamingSoundData,
};
let mut manager = AudioManager::<DefaultBackend>::new(AudioManagerSettings::default())?;
let tweener = manager.add_modulator(TweenerBuilder {
initial_value: 0.25,
})?;
let sound = StreamingSoundData::from_file("sound.ogg")?.panning(&tweener);
pub fn output_destination(
self,
output_destination: impl Into<OutputDestination>,
) -> StreamingSoundData<Error>
pub fn output_destination( self, output_destination: impl Into<OutputDestination>, ) -> StreamingSoundData<Error>
Sets the destination that this sound should be routed to.
§Examples
Set the output destination of a sound to a mixer track:
use kira::{
manager::{AudioManager, AudioManagerSettings, backend::DefaultBackend},
track::TrackBuilder,
sound::streaming::StreamingSoundData,
};
let mut manager = AudioManager::<DefaultBackend>::new(AudioManagerSettings::default())?;
let sub_track = manager.add_sub_track(TrackBuilder::new())?;
let sound = StreamingSoundData::from_file("sound.ogg")?.output_destination(&sub_track);
Set the output destination of a sound to an emitter in a spatial scene:
use kira::{
manager::{AudioManager, AudioManagerSettings, backend::DefaultBackend},
spatial::{scene::SpatialSceneSettings, emitter::EmitterSettings},
sound::streaming::StreamingSoundData,
};
let mut manager = AudioManager::<DefaultBackend>::new(AudioManagerSettings::default())?;
let mut scene = manager.add_spatial_scene(SpatialSceneSettings::default())?;
let emitter = scene.add_emitter(mint::Vector3 {
x: 0.0,
y: 0.0,
z: 0.0,
}, EmitterSettings::default())?;
let sound = StreamingSoundData::from_file("sound.ogg")?.output_destination(&emitter);
pub fn fade_in_tween(
self,
fade_in_tween: impl Into<Option<Tween>>,
) -> StreamingSoundData<Error>
pub fn fade_in_tween( self, fade_in_tween: impl Into<Option<Tween>>, ) -> StreamingSoundData<Error>
Sets the tween used to fade in the instance from silence.
pub fn with_settings(
self,
settings: StreamingSoundSettings,
) -> StreamingSoundData<Error>
pub fn with_settings( self, settings: StreamingSoundSettings, ) -> StreamingSoundData<Error>
Returns the StreamingSoundData
with the specified settings.
pub fn num_frames(&self) -> usize
pub fn num_frames(&self) -> usize
Returns the number of frames in the StreamingSoundData
.
If StreamingSoundData::slice
is Some
, this will be the number
of frames in the slice.
pub fn duration(&self) -> Duration
pub fn duration(&self) -> Duration
Returns the duration of the audio.
If StreamingSoundData::slice
is Some
, this will be the duration
of the slice.
pub fn slice(self, region: impl IntoOptionalRegion) -> StreamingSoundData<Error>
pub fn slice(self, region: impl IntoOptionalRegion) -> StreamingSoundData<Error>
Sets the portion of the audio this StreamingSoundData
represents.
§impl StreamingSoundData<FromFileError>
impl StreamingSoundData<FromFileError>
pub fn from_file(
path: impl AsRef<Path>,
) -> Result<StreamingSoundData<FromFileError>, FromFileError>
pub fn from_file( path: impl AsRef<Path>, ) -> Result<StreamingSoundData<FromFileError>, FromFileError>
Creates a StreamingSoundData
for an audio file.
pub fn from_cursor<T>(
cursor: Cursor<T>,
) -> Result<StreamingSoundData<FromFileError>, FromFileError>
pub fn from_cursor<T>( cursor: Cursor<T>, ) -> Result<StreamingSoundData<FromFileError>, FromFileError>
Creates a StreamingSoundData
for a cursor wrapping audio file data.
pub fn from_media_source(
media_source: impl MediaSource + 'static,
) -> Result<StreamingSoundData<FromFileError>, FromFileError>
pub fn from_media_source( media_source: impl MediaSource + 'static, ) -> Result<StreamingSoundData<FromFileError>, FromFileError>
Creates a StreamingSoundData
for a type that implements Symphonia’s
MediaSource
trait.
Trait Implementations§
§impl<Error> SoundData for StreamingSoundData<Error>where
Error: Send + 'static,
impl<Error> SoundData for StreamingSoundData<Error>where
Error: Send + 'static,
§type Handle = StreamingSoundHandle<Error>
type Handle = StreamingSoundHandle<Error>
§fn into_sound(
self,
) -> Result<(Box<dyn Sound>, <StreamingSoundData<Error> as SoundData>::Handle), <StreamingSoundData<Error> as SoundData>::Error>
fn into_sound( self, ) -> Result<(Box<dyn Sound>, <StreamingSoundData<Error> as SoundData>::Handle), <StreamingSoundData<Error> as SoundData>::Error>
Auto Trait Implementations§
impl<Error> Freeze for StreamingSoundData<Error>
impl<Error> !RefUnwindSafe for StreamingSoundData<Error>
impl<Error> Send for StreamingSoundData<Error>
impl<Error> !Sync for StreamingSoundData<Error>
impl<Error> Unpin for StreamingSoundData<Error>
impl<Error> !UnwindSafe for StreamingSoundData<Error>
Blanket Implementations§
§impl<T, U> AsBindGroupShaderType<U> for T
impl<T, U> AsBindGroupShaderType<U> for T
§fn as_bind_group_shader_type(&self, _images: &RenderAssets<Image>) -> U
fn as_bind_group_shader_type(&self, _images: &RenderAssets<Image>) -> U
T
[ShaderType
] for self
. When used in [AsBindGroup
]
derives, it is safe to assume that all images in self
exist.§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Conv for T
impl<T> Conv for T
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
fn into_sample(self) -> T
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self
from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self
is actually part of its subset T
(and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset
but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self
to the equivalent element of its superset.§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.