Audio streaming
You can stream audio from a URL. This is useful to play music directly from an internet radio, or stream a conference into your scene.
The audio in the source must be in one of the following formats: .mp3
, ogg
, or aac
. The source must also be an https URL (http URLs aren’t supported), and the source should have
CORS policies (Cross Origin Resource Sharing)
that permit externally accessing it. If this is not the case, you might need to set up a server to act as a proxy and expose the stream in a valid way.
📔 Note: To instead play a pre-recorded sound in your scene, see Sounds .
To add an audio stream into your scene, simply add an AudioStream
component to an entity:
const streamEntity = engine.addEntity()
AudioStream.create(streamEntity, {
url: 'https://icecast.ravepartyradio.org/ravepartyradio-192.mp3',
playing: true,
volume: 0.8,
})
📔 Note: The streamed sound isn’t positional, it will be heard at a consistent volume throughout your entire scene. If a player steps out of the scene, they will not hear the streaming at all.
Set the volume of the AudioStream
component by changing its volume
property.
Switch the AudioStream
component on or off by setting its playing
property to true or false.
📔 Note: Not all streaming services allow you to play their audio outside their site. The following are some examples that work in Decentraland:
RAVE = "https://icecast.ravepartyradio.org/ravepartyradio-192.mp3" << not working DELTA = "https://cdn.instream.audio/:9069/stream?_=171cd6c2b6e" GRAFFITI = "https://n07.radiojar.com/2qm1fc5kb.m4a?1617129761=&rj-tok=AAABeIR7VqwAilDFeUM39SDjmw&rj-ttl=5" SIGNS = "https://edge.singsingmusic.net/MC2.mp3" << not working JAZZ = "https://live.vegascity.fm/radio/8010/the_flamingos.mp3" << not working
Stream state #
Query the state of an audio stream using the function AudioStream.getAudioState()
, passing the entity that owns the AudioStream
component.
The returned state is a value of the MediaState
enum. This enum has the following possible values:
MS_BUFFERING
MS_ERROR
MS_LOADING
MS_NONE
MS_PAUSED
MS_PLAYING
MS_READY
MS_SEEKING
The following example checks on the state of a stream, and logs when there’s a change.
export function main() {
const entity = engine.addEntity()
AudioStream.create(entity, {
playing: true,
volume: 1,
url: 'https://audio-edge-es6pf.mia.g.radiomast.io/ref-128k-mp3-stereo',
})
let lastState: ReturnType<typeof AudioStream.getAudioState> = undefined
engine.addSystem(() => {
const currentState = AudioStream.getAudioState(entity)
if (lastState !== currentState) {
console.log('Stream state: ', currentState)
if (currentState == MediaState.MS_ERROR) {
// Attempt reconnection
}
}
})
}