mirror of
https://github.com/owntone/owntone-server.git
synced 2025-05-24 10:56:15 -04:00
[web] Fix unstoppable stream player
This commit is contained in:
parent
7548e4e059
commit
19399f3c08
@ -84,7 +84,7 @@
|
|||||||
:disabled="!playing"
|
:disabled="!playing"
|
||||||
:max="100"
|
:max="100"
|
||||||
:cursor="cursor"
|
:cursor="cursor"
|
||||||
@change="change_stream_volume"
|
@change="changeStreamVolume"
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -243,7 +243,7 @@
|
|||||||
:disabled="!playing"
|
:disabled="!playing"
|
||||||
:max="100"
|
:max="100"
|
||||||
:cursor="cursor"
|
:cursor="cursor"
|
||||||
@change="change_stream_volume"
|
@change="changeStreamVolume"
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -346,18 +346,12 @@ export default {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// On app mounted
|
|
||||||
mounted() {
|
|
||||||
this.setupAudio()
|
|
||||||
},
|
|
||||||
|
|
||||||
// On app destroyed
|
|
||||||
unmounted() {
|
unmounted() {
|
||||||
this.closeAudio()
|
this.closeAudio()
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
change_stream_volume() {
|
changeStreamVolume() {
|
||||||
audio.setVolume(this.stream_volume / 100)
|
audio.setVolume(this.stream_volume / 100)
|
||||||
},
|
},
|
||||||
change_volume() {
|
change_volume() {
|
||||||
@ -366,41 +360,33 @@ export default {
|
|||||||
closeAudio() {
|
closeAudio() {
|
||||||
audio.stop()
|
audio.stop()
|
||||||
this.playing = false
|
this.playing = false
|
||||||
|
this.loading = false
|
||||||
},
|
},
|
||||||
on_click_outside_outputs() {
|
on_click_outside_outputs() {
|
||||||
this.show_outputs_menu = false
|
this.show_outputs_menu = false
|
||||||
},
|
},
|
||||||
playChannel() {
|
playChannel() {
|
||||||
if (this.playing) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
this.loading = true
|
this.loading = true
|
||||||
audio.play('/stream.mp3')
|
audio.play('/stream.mp3')
|
||||||
audio.setVolume(this.stream_volume / 100)
|
this.changeStreamVolume()
|
||||||
},
|
const a = audio.audio
|
||||||
setupAudio() {
|
if (a) {
|
||||||
const a = audio.setup()
|
a.addEventListener('waiting', () => {
|
||||||
a.addEventListener('waiting', () => {
|
this.playing = false
|
||||||
this.playing = false
|
this.loading = true
|
||||||
this.loading = true
|
|
||||||
})
|
|
||||||
a.addEventListener('playing', () => {
|
|
||||||
this.playing = true
|
|
||||||
this.loading = false
|
|
||||||
})
|
|
||||||
a.addEventListener('ended', () => {
|
|
||||||
this.playing = false
|
|
||||||
this.loading = false
|
|
||||||
})
|
|
||||||
a.addEventListener('error', () => {
|
|
||||||
this.closeAudio()
|
|
||||||
this.notificationsStore.add({
|
|
||||||
text: this.$t('navigation.stream-error'),
|
|
||||||
type: 'danger'
|
|
||||||
})
|
})
|
||||||
this.playing = false
|
a.addEventListener('playing', () => {
|
||||||
this.loading = false
|
this.playing = true
|
||||||
})
|
this.loading = false
|
||||||
|
})
|
||||||
|
a.addEventListener('ended', () => {
|
||||||
|
this.playing = false
|
||||||
|
this.loading = false
|
||||||
|
})
|
||||||
|
a.addEventListener('error', () => {
|
||||||
|
this.closeAudio()
|
||||||
|
})
|
||||||
|
}
|
||||||
},
|
},
|
||||||
togglePlay() {
|
togglePlay() {
|
||||||
if (this.loading) {
|
if (this.loading) {
|
||||||
@ -408,8 +394,9 @@ export default {
|
|||||||
}
|
}
|
||||||
if (this.playing) {
|
if (this.playing) {
|
||||||
this.closeAudio()
|
this.closeAudio()
|
||||||
|
} else {
|
||||||
|
this.playChannel()
|
||||||
}
|
}
|
||||||
this.playChannel()
|
|
||||||
},
|
},
|
||||||
toggle_mute_volume() {
|
toggle_mute_volume() {
|
||||||
this.player.volume = this.player.volume > 0 ? 0 : this.old_volume
|
this.player.volume = this.player.volume > 0 ? 0 : this.old_volume
|
||||||
|
@ -1,59 +1,28 @@
|
|||||||
/**
|
|
||||||
* Audio handler object
|
|
||||||
* Inspired by https://github.com/rainner/soma-fm-player
|
|
||||||
* (released under MIT licence)
|
|
||||||
*/
|
|
||||||
export default {
|
export default {
|
||||||
audio: new Audio(),
|
audio: null,
|
||||||
context: null,
|
play(url) {
|
||||||
|
this.audio = new Audio(`${String(url || '')}?x=${Date.now()}`)
|
||||||
// Play audio source url
|
this.audio.crossOrigin = 'anonymous'
|
||||||
play(source) {
|
const context = new (window.AudioContext || window.webkitAudioContext)()
|
||||||
this.stop()
|
const source = context.createMediaElementSource(this.audio)
|
||||||
this.context.resume().then(() => {
|
source.connect(context.destination)
|
||||||
this.audio.src = `${String(source || '')}?x=${Date.now()}`
|
this.audio.addEventListener('canplay', () => {
|
||||||
this.audio.crossOrigin = 'anonymous'
|
context.resume().then(() => {
|
||||||
this.audio.load()
|
this.audio.play()
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
this.audio.load()
|
||||||
},
|
},
|
||||||
|
|
||||||
// Set audio volume
|
|
||||||
setVolume(volume) {
|
setVolume(volume) {
|
||||||
if (this.audio) {
|
if (this.audio) {
|
||||||
this.audio.volume = Math.min(1, Math.max(0, parseFloat(volume) || 0.0))
|
this.audio.volume = Math.max(0, Math.min(1, Number(volume) || 0))
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// Setup audio routing
|
|
||||||
setup() {
|
|
||||||
this.context = new (window.AudioContext || window.webkitAudioContext)()
|
|
||||||
const source = this.context.createMediaElementSource(this.audio)
|
|
||||||
source.connect(this.context.destination)
|
|
||||||
this.audio.addEventListener('canplaythrough', () => {
|
|
||||||
this.audio.play()
|
|
||||||
})
|
|
||||||
this.audio.addEventListener('canplay', () => {
|
|
||||||
this.audio.play()
|
|
||||||
})
|
|
||||||
return this.audio
|
|
||||||
},
|
|
||||||
|
|
||||||
// Stop playing audio
|
|
||||||
stop() {
|
stop() {
|
||||||
try {
|
try {
|
||||||
this.audio.pause()
|
this.audio?.pause()
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
// Continue regardless of error
|
//Do nothing
|
||||||
}
|
|
||||||
try {
|
|
||||||
this.audio.stop()
|
|
||||||
} catch (error) {
|
|
||||||
// Continue regardless of error
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
this.audio.close()
|
|
||||||
} catch (error) {
|
|
||||||
// Continue regardless of error
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user