electron和vue开发的音乐播放器遇到的一些问题(本地音频文件的播放,文件信息的读取)

        最近在学习electron,尝试开发了一个音乐播放器。在播放器本地音乐的时候遇到了一些问题。
在获取到本地的音频文件路径之后,audio不会向网络路径一样直接去缓存播放。废话不多说,直接上代码。

获取本地视频文件的时长 需要用到一个插件 music-metadata,点击进入。

 import fs from 'fs';
 import path from 'path';
 import {remote} from 'electron';
 import * as mm from 'music-metadata';


//...




readLocalFiles() {
                //获取文件的一些关键信息
                const me = this;
                const url = remote.app.getPath('music');//文件夹路径;
                fs.readdir(url, function (err, files) {
                    files.forEach(item => {
                        if (path.extname(item).toLowerCase() !== '.mp3') return;//遍历每一个文件,遇到非mp3文件直接返回(当然音频文件不止mp3,有需要可以多做判断)
                        mm.parseFile(path.join(url, item), {//利用music-metadata来获取文件的时长等信息 npm包地址 https://www.npmjs.com/package/music-metadata
                            duration: true
                        }).then(metadata => {
                            console.log(metadata);
                            me.localList.push({
                                name:item,
                                __dir_url:path.join(url, item),
                                duration:metadata.format.duration});
                        });

                    })
                })
            },

第二个关键部分就是去读取本地文件,本地文件需要用到fs模块。用fs模块读取文件,然后将缓存文件利用new Bolb()转化为bolb;

readFile1(item) {
                const me = this;
                const buf = fs.readFileSync(item.__dir_url);//读取文件,并将缓存区进行转换
                const uint8Buffer = Uint8Array.from(buf);
                const bolb = new Blob([uint8Buffer]);//转为一个新的Blob文件流
                console.log(bolb);
                me.url = window.URL.createObjectURL(bolb); //转换为url地址并直接给到audio
            },

这样本地的音频文件就可以利用audio进行读取了。

在查资料的过程中发现了前人的一些解决方案,使用 electron 做个播放器 · Issue #8 · whxaxes/blog · GitHub 。这里边介绍了两种方法。第一种方法不创建audio标签,直接利用

new window.AudioContext().createBufferSource() 去直接播放音频。第二种方法创建一个serve监听音频服务(一直没搞懂怎么实现的,node学得不够)。
  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,我们需要在Vue项目中安装一个依赖库:`vue-electron`,这个库可以让Vue项目支持Electron,从而实现本地文件读取和写入。 安装命令如下: ``` npm install --save vue-electron ``` 然后,在Vue项目的入口文件`main.js`中,引入`vue-electron`并使用它: ```js import Vue from 'vue' import App from './App.vue' import VueElectron from 'vue-electron' Vue.use(VueElectron) new Vue({ render: h => h(App) }).$mount('#app') ``` 接下来,我们可以在Vue组件中使用Node.js的`fs`模块来实现本地文件读取和写入。 假设我们要读取本地的一个名为`test.txt`的文件,代码如下: ```js const fs = require('fs') // 读取文件 fs.readFile('test.txt', 'utf-8', (err, data) => { if (err) { console.log(err) return } console.log(data) }) ``` 如果要写入文件,可以使用`fs.writeFile()`方法: ```js const fs = require('fs') // 写入文件 fs.writeFile('test.txt', 'Hello, world!', (err) => { if (err) { console.log(err) return } console.log('写入成功!') }) ``` 最后,如果需要获取本地文件路径,可以使用`dialog.showOpenDialog()`方法来弹出一个对话框,让用户选择文件。代码如下: ```js const { dialog } = require('electron').remote // 弹出对话框 dialog.showOpenDialog({ properties: ['openFile'] }).then(result => { // 获取选择的文件路径 const filePath = result.filePaths[0] console.log(filePath) }).catch(err => { console.log(err) }) ``` 需要注意的是,上面的代码需要在Vue组件的`<script>`标签中使用,而不能在单独的`.js`文件中使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值