Skip to content

Channel

class Channel

An object that represents a single channel of audio.

The Channel class is a lightweight reference to a ChannelInternalState object which is managed by the Engine. Multiple channels may point to the same underlying data.

Functions

Name Description
Channel Construct an uninitialized Channel.
Channel Creates a wrapper instance over the provided state.
Clear Uninitializes this Channel.
Valid Checks whether this Channel has been initialized.
GetId Gets the ID of this Channel.
Playing Checks if the sound associated to this Channel is playing.
Stop Stops the Channel.
Pause Pauses the Channel.
Resume Resumes the Channel.
GetLocation Gets the location of this Channel.
SetLocation Sets the location of this Channel.
SetGain Sets the gain on this Channel.
GetGain Returns the gain on this Channel.
GetPlaybackState Returns the playback state of this Channel.
GetEntity Returns the Entity associated with this Channel.
GetListener Returns the Listener associated with this Channel.
GetRoom Returns the Room associated with this Channel.
GetState Returns the internal state of this Channel.
On Registers a callback for a channel event.

Function Details

Channel

Channel()

Construct an uninitialized Channel.

An uninitialized Channel cannot have its data set or queried.

explicit Channel(ChannelInternalState* state)

Creates a wrapper instance over the provided state.

Parameter state
The internal state to wrap.

Warning

This constructor is for internal usage only.

Clear

void Clear()

Uninitializes this Channel.

Note that this does not stop the audio or destroy the internal state it references, it just removes this reference to it.

GetEntity

[[nodiscard]] Entity GetEntity() const

Returns the Entity associated with this Channel.

Note

If no Entity is associated with this Channel, this method will return an uninitialized Entity object. You should check if the entity is valid before using it.

Return
The entity associated with this Channel.
See
Entity

GetGain

[[nodiscard]] AmReal32 GetGain() const

Returns the gain on this Channel.

Return
The channel's gain.

GetId

[[nodiscard]] AmUInt64 GetId() const

Gets the ID of this Channel.

Return
The ID of this Channel.

GetListener

[[nodiscard]] Listener GetListener() const

Returns the Listener associated with this Channel.

Note

If no Listener is associated with this Channel, this method will return an uninitialized Listener object. You should check if the listener is valid before using it.

Return
The listener associated with this Channel.
See
Listener

GetLocation

[[nodiscard]] const AmVec3& GetLocation() const

Gets the location of this Channel.

If the audio on this channel is not set to be Positional, this method will return an invalid location.

Return
The location of this Channel.

GetPlaybackState

[[nodiscard]] eChannelPlaybackState GetPlaybackState() const

Returns the playback state of this Channel.

Return
A ChannelPlaybackState enumeration value representing the current state of the Channel.

GetRoom

[[nodiscard]] Room GetRoom() const

Returns the Room associated with this Channel.

Note

If no Room is associated with this Channel, this method will return an uninitialized Room object. You should check if the room is valid before using it.

Return
The room associated with this Channel.

GetState

[[nodiscard]] ChannelInternalState* GetState() const

Returns the internal state of this Channel.

Return
The internal state of this Channel.

Warning

This method is for internal usage only.

On

void On(ChannelEvent event, ChannelEventCallback callback, void* userData = nullptr) const

Registers a callback for a channel event.

Parameter event
The channel event.
Parameter callback
The callback function.
Parameter userData
The user data to pass to the callback.
See
ChannelEvent
See
ChannelEventCallback

Pause

void Pause(AmTime duration = kMinFadeDuration) const

Pauses the Channel.

A paused channel may be resumed where it left off.

Parameter duration
The fade out duration before to pause the channel.

Playing

[[nodiscard]] bool Playing() const

Checks if the sound associated to this Channel is playing.

Return
Whether the channel is currently playing.

Resume

void Resume(AmTime duration = kMinFadeDuration) const

Resumes the Channel.

If this channel was paused it will continue where it left off.

Parameter duration
The fade in duration after resuming the channel.

SetGain

void SetGain(AmReal32 gain) const

Sets the gain on this Channel.

Parameter gain
The new gain value.

SetLocation

void SetLocation(const AmVec3& location) const

Sets the location of this Channel.

If the audio on this channel is not set to be Positional, this method does nothing.

Parameter location
The new location of the Channel.

Stop

void Stop(AmTime duration = kMinFadeDuration) const

Stops the Channel.

A sound will stop on its own if its not set to loop. Looped audio must be explicitly stopped.

Parameter duration
The fade out duration before to stop the channel.

Valid

[[nodiscard]] bool Valid() const

Checks whether this Channel has been initialized.

Return
true if this Channel has been initialized.