2019-02-14 06:19:29 -05:00
|
|
|
/**
|
|
|
|
* Audio handler object
|
|
|
|
* Taken from https://github.com/rainner/soma-fm-player (released under MIT licence)
|
|
|
|
*/
|
|
|
|
export default {
|
|
|
|
_audio: new Audio(),
|
2019-02-19 04:33:07 -05:00
|
|
|
_context: null,
|
2019-02-14 06:19:29 -05:00
|
|
|
_source: null,
|
|
|
|
_gain: null,
|
|
|
|
|
2023-06-07 15:25:54 -04:00
|
|
|
// Setup audio routing
|
2022-02-19 00:39:14 -05:00
|
|
|
setupAudio() {
|
2021-01-10 01:51:50 -05:00
|
|
|
const AudioContext = window.AudioContext || window.webkitAudioContext
|
2019-02-19 04:33:07 -05:00
|
|
|
this._context = new AudioContext()
|
2019-02-14 06:19:29 -05:00
|
|
|
this._source = this._context.createMediaElementSource(this._audio)
|
|
|
|
this._gain = this._context.createGain()
|
|
|
|
|
|
|
|
this._source.connect(this._gain)
|
|
|
|
this._gain.connect(this._context.destination)
|
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
this._audio.addEventListener('canplaythrough', (e) => {
|
2019-02-14 06:19:29 -05:00
|
|
|
this._audio.play()
|
|
|
|
})
|
2022-02-19 00:39:14 -05:00
|
|
|
this._audio.addEventListener('canplay', (e) => {
|
2019-02-18 06:47:09 -05:00
|
|
|
this._audio.play()
|
|
|
|
})
|
2019-02-14 06:19:29 -05:00
|
|
|
return this._audio
|
|
|
|
},
|
|
|
|
|
2023-06-07 15:25:54 -04:00
|
|
|
// Set audio volume
|
2022-02-19 00:39:14 -05:00
|
|
|
setVolume(volume) {
|
2019-02-14 06:19:29 -05:00
|
|
|
if (!this._gain) return
|
|
|
|
volume = parseFloat(volume) || 0.0
|
2022-02-19 00:39:14 -05:00
|
|
|
volume = volume < 0 ? 0 : volume
|
|
|
|
volume = volume > 1 ? 1 : volume
|
2019-02-14 06:19:29 -05:00
|
|
|
this._gain.gain.value = volume
|
|
|
|
},
|
|
|
|
|
2023-06-07 15:25:54 -04:00
|
|
|
// Play audio source url
|
2022-02-19 00:39:14 -05:00
|
|
|
playSource(source) {
|
2019-02-14 06:19:29 -05:00
|
|
|
this.stopAudio()
|
2019-02-18 06:47:09 -05:00
|
|
|
this._context.resume().then(() => {
|
2023-11-23 14:23:40 -05:00
|
|
|
this._audio.src = `${String(source || '')}?x=${Date.now()}`
|
2019-02-18 06:47:09 -05:00
|
|
|
this._audio.crossOrigin = 'anonymous'
|
|
|
|
this._audio.load()
|
|
|
|
})
|
2019-02-14 06:19:29 -05:00
|
|
|
},
|
|
|
|
|
2023-06-07 15:25:54 -04:00
|
|
|
// Stop playing audio
|
2022-02-19 00:39:14 -05:00
|
|
|
stopAudio() {
|
|
|
|
try {
|
|
|
|
this._audio.pause()
|
2022-02-19 01:05:59 -05:00
|
|
|
} catch (e) {
|
2023-06-07 15:25:54 -04:00
|
|
|
// Continue regardless of error
|
2022-02-19 01:05:59 -05:00
|
|
|
}
|
2022-02-19 00:39:14 -05:00
|
|
|
try {
|
|
|
|
this._audio.stop()
|
2022-02-19 01:05:59 -05:00
|
|
|
} catch (e) {
|
2023-06-07 15:25:54 -04:00
|
|
|
// Continue regardless of error
|
2022-02-19 01:05:59 -05:00
|
|
|
}
|
2022-02-19 00:39:14 -05:00
|
|
|
try {
|
|
|
|
this._audio.close()
|
2022-02-19 01:05:59 -05:00
|
|
|
} catch (e) {
|
2023-06-07 15:25:54 -04:00
|
|
|
// Continue regardless of error
|
2022-02-19 01:05:59 -05:00
|
|
|
}
|
2019-02-14 06:19:29 -05:00
|
|
|
}
|
|
|
|
}
|