根据ID判断当前正在播放的

This commit is contained in:
灌糖包子 2023-01-16 00:33:27 +08:00
parent 64bedfbfff
commit ecb42b2c72
Signed by: sookie
GPG Key ID: 691E688C160D3188
2 changed files with 14 additions and 12 deletions

View File

@ -26,7 +26,7 @@ export interface MusicLyricModel {
}
export interface MusicPlayerItem {
id?: number
id: number
title: string
artist: string | undefined
album?: string | undefined

View File

@ -142,7 +142,7 @@
</template>
</el-dialog>
<el-drawer v-model="musicPlaying" :close-on-click-modal="false" size="40%" title="播放音乐">
<a-player v-if="musicPlaying" ref="player" autoplay showLrc :list="musicList" :music="musicList[0]" @play="musicPlay"/>
<a-player v-if="musicPlaying" ref="player" autoplay showLrc :list="musicList" :music="currentMusic" @play="musicPlay"/>
</el-drawer>
</div>
</template>
@ -187,6 +187,7 @@ export default class Music extends BaseList<MusicPage> {
//
musicPlaying: boolean = false
musicList: MusicPlayerItem[] = []
currentMusic?: MusicPlayerItem
created() {
this.$http.get<never, any>('/api/v1/music/listLibs').then(data => {
this.musicLibs = data
@ -215,8 +216,9 @@ export default class Music extends BaseList<MusicPage> {
async playMusic() {
try {
const data = await this.$http.get<any, any>('/api/v1/music/list/all', {params: selectedIds.length ? {ids: selectedIds} : this.search})
this.musicList = data.map((item: MusicModel) => {
this.musicList = data.map((item: MusicModel, index: number) => {
const musicItem: MusicPlayerItem = {
id: index,
title: item.title || item.name,
artist: item.artist,
src: `/api/v2/common/music/load/${item._id}`,
@ -227,7 +229,7 @@ export default class Music extends BaseList<MusicPage> {
}
return musicItem
})
// ( )
this.currentMusic = this.musicList[0]
this.musicPlaying = true
} catch (err) {
console.error(err)
@ -307,23 +309,23 @@ export default class Music extends BaseList<MusicPage> {
* 创建媒体信息
*/
musicPlay() {
if(!('mediaSession' in window.navigator)) return;
if(!('mediaSession' in window.navigator) || !this.currentMusic) return;
const player = <any>this.$refs.player
const currentMusic = player.currentMusic
const mediaSession: any = navigator.mediaSession
const currentId = this.currentMusic.id
mediaSession.metadata = new MediaMetadata({
title: currentMusic.title,
artist: currentMusic.artist,
album: currentMusic.album,
artwork: [{src: currentMusic.pic}]
});
title: this.currentMusic.title,
artist: this.currentMusic.artist,
album: this.currentMusic.album,
artwork: [{src: this.currentMusic.pic}]
})
const currentIndex = this.musicList.findIndex(item => item.id === currentId)
mediaSession.setActionHandler('play', () => { //
player.play()
})
mediaSession.setActionHandler('pause', () => { //
player.pause()
})
const currentIndex = this.musicList.findIndex(item => item.src === currentMusic.src)
mediaSession.setActionHandler('previoustrack', () => { //
if (currentIndex === 0) { //
player.switch(this.musicList.length - 1)