Electron+vue打造一个本地播放器(附项目代码)(1)

本文介绍如何利用Electron和Vue.js创建一个本地音乐播放器,包括加载本地文件播放、上一首下一首功能、音量控制、自定义标题栏以及处理多个实例和自动更新的实现。详细讲解了关键代码实现,如stream转换为Blob加载音乐,以及通过Node.js的path和fs模块处理文件操作。此外,还涉及自定义标题栏、音量调节和防止多实例问题的方法,以及集成自动更新功能。
摘要由CSDN通过智能技术生成

throw new Error(‘Invalid mimetype, expected string.’)

}

return new Promise((resolve, reject) => {

const chunks = []

stream

.on(‘data’, chunk => chunks.push(chunk))

.once(‘end’, () => {

const blob = mimeType != null

? new Blob(chunks, { type: mimeType })

: new Blob(chunks)

resolve(blob)

})

.once(‘error’, reject)

})

}

转blob

let fileUrl; // blob对象

streamToBlob(stream)

.then(res => {

fileUrl = res;

// console.log(fileUrl);

//将blob对象转成blob链接

let filePath = window.URL.createObjectURL(fileUrl);

// console.log(filePath);

this.wavesurfer.load(filePath);

// 自动播放

this.wavesurfer.play();

this.playing = true;

})

.catch(err => {

console.log(err);

});

这样就实现了加载本地文件播放了

上一首下一首功能

这里的上一首下一首的功能是基于上面获取到的文件的绝对路径,通过node的path模块,path.dirname获取到文件的父级目录。

const dirPath = path.dirname(diskPath);

然后通过fs.readdir读取目录下所有文件,会返回一个文件名数组,找到该目录下正在播放的文件的下标,通过数组下标判断前一首和后一首歌曲的名称,然后再组装成绝对路径,读取资源播放

playFileList(diskPath, pos) {

let isInFiles;

let fileIndex;

let preIndex;

let nextIndex;

let fullPath;

let dirPath = path.dirname(diskPath);

let basename = path.basename(diskPath);

fs.readdir(dirPath, (err, files) => {

isInFiles = files.includes(basename);

if (isInFiles &

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值