vue使用wavesurfer.js解决音频可视化播放问题


Posted in Vue.js onApril 04, 2022

之前给大家介绍过vue中音频wavesurfer.js的使用方法,感兴趣的朋友可以点击查看,今天继续给大家普及vue解决音频可视化播放,使用wavesurfer.js问题,效果图如下所示:

上效果:

vue使用wavesurfer.js解决音频可视化播放问题

vue使用wavesurfer.js解决音频可视化播放问题

1.安装wavesurfer

npm install wavesurfer.js

2.在页面导入

import WaveSurfer from 'wavesurfer.js'

注:我没有使用时间轴,所以没有引入,如果需要再引入

import Timeline from 'wavesurfer.js/dist/plugin/wavesurfer.timeline.js'

3.上源码

<template>
  <el-row>
    <el-card class="card" :body-style="{ padding: '10px' }">
      <div id="waveform" ref="waveform">
      </div>
    </el-card>
  </el-row>
  <div>
        <el-button type="primary" @click="playMusic">
          <i class="el-icon-video-play"></i>
          播放 /
          <i class="el-icon-video-pausee"></i>
          暂停
        </el-button>
</template>
<script>
import WaveSurfer from "wavesurfer.js";
// import Timeline from "wavesurfer.js/dist/plugin/wavesurfer.timeline.js";
export default {
  name: "Details",
  data() {
    return {
      wavesurfer: null,
    };
  },
  mounted() {
    this.$nextTick(() => {
      this.wavesurfer = WaveSurfer.create({
        container: this.$refs.waveform,
        // waveColor: '#409EFF',
        barWidth: 1,
        cursorColor: "black",
        progressColor: "blue",
        backend: "MediaElement",
        // mediaControls: false,
        audioRate: "1",
        //使用时间轴插件
      });
      // 特别提醒:此处需要使用require(相对路径),否则会报错
      this.wavesurfer.load(require("../mp3/living.mp3"));
    });
  methods: {
    playMusic() {
      //"播放/暂停"按钮的单击触发事件,暂停的话单击则播放,正在播放的话单击则暂停播放
      this.wavesurfer.playPause.bind(this.wavesurfer)();
    },
};
</script>
<style >
.mixin-components-container {
  width: 100% !important;
  #f0f2f5;
  padding: 30px;
  /* min-height: calc(100vh - 84px); */
}
.el-card__body {
  height: 70px !important;
  padding: 0 auto !important;
.card {
  height: 70px;
#waveform {
wave {
  height: 50px !important;
</style>

4.注释:

这个插件实在太吊了,官方文档太厉害,上链接:https://wavesurfer-js.org/

我用到了几个方法:

4.1.

this.wavesurfer.play(0, 212); 指定开始时间和结束时间,以秒为单位,0秒开始,212秒结束

4.2.

this.wavesurfer.on("pause", () => {
console.log('我暂停了')
});

监听暂停

4.3.

this.wavesurfer.load(require("../mp3/living.mp3")); 读取目录路径里面的Mp3文件,可以测试用
this.wavesurfer.load('xxx.mp3')); 读取网络地址,有接口就用这个

到此这篇关于vue使用wavesurfer.js解决音频可视化播放的文章就介绍到这了,更多相关vue音频可视化播放内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
详解vue 组件注册
Nov 20 Vue.js
Vue与React的区别和优势对比
Dec 18 Vue.js
vue下拉刷新组件的开发及slot的使用详解
Dec 23 Vue.js
vue自定义组件实现双向绑定
Jan 13 Vue.js
vue keep-alive的简单总结
Jan 25 Vue.js
vue 组件基础知识总结
Jan 26 Vue.js
vue穿梭框实现上下移动
Jan 29 Vue.js
Vue SPA 首屏优化方案
Feb 26 Vue.js
Vue多选列表组件深入详解
Mar 02 Vue.js
浅谈vue2的$refs在vue3组合式API中的替代方法
Apr 18 Vue.js
Vue全家桶入门基础教程
May 14 Vue.js
vue报错function () { [native code] },无法出现我们想要的内容 Unknown custom element
Apr 11 Vue.js
vue中div禁止点击事件的实现
Apr 02 #Vue.js
Vue组件更新数据v-model不生效的解决
Apr 02 #Vue.js
Vue+TypeScript中处理computed方式
Apr 02 #Vue.js
Vue+Flask实现图片传输功能
Apr 01 #Vue.js
在vue中import()语法不能传入变量的问题及解决
Apr 01 #Vue.js
Vue中使用import进行路由懒加载的原理分析
Apr 01 #Vue.js
vue使用refs获取嵌套组件中的值过程
Mar 31 #Vue.js
You might like
PHP 增加了对 .ZIP 文件的读取功能
2006/10/09 PHP
php读取30天之内的根据算法排序的代码
2008/04/06 PHP
PHP中rename()函数的妙用讲解
2019/02/28 PHP
jQuery EasyUI API 中文文档 - NumberSpinner数值微调器使用介绍
2011/10/21 Javascript
15个款优秀的 jQuery 图片特效插件推荐
2011/11/21 Javascript
JavaScript面向对象知识串结(读JavaScript高级程序设计(第三版))
2012/07/17 Javascript
ff下JQuery无法监听input的keyup事件的解决方法
2013/12/12 Javascript
jQuery实现的精美平滑二级下拉菜单效果代码
2016/03/28 Javascript
JavaScript中的跨浏览器事件操作的基本方法整理
2016/05/20 Javascript
javascript动画系列之模拟滚动条
2016/12/13 Javascript
原生JS轮播图插件
2017/02/09 Javascript
jQuery图片切换动画效果
2017/02/28 Javascript
webpack 单独打包指定JS文件的方法
2018/02/22 Javascript
详解Vue2 添加对scss的支持
2019/01/02 Javascript
详解webpack4.x之搭建前端开发环境
2019/03/28 Javascript
bootstrap table.js动态填充单元格数据的多种方法
2019/07/18 Javascript
[43:43]完美世界DOTA2联赛PWL S2 LBZS vs Forest 第三场 11.29
2020/12/02 DOTA
python使用xpath中遇到:到底是什么?
2018/01/04 Python
pandas.DataFrame选取/排除特定行的方法
2018/07/03 Python
python基础学习之如何对元组各个元素进行命名详解
2018/07/12 Python
Python文件读写常见用法总结
2019/02/22 Python
python实现植物大战僵尸游戏实例代码
2019/06/10 Python
浅谈Python中的继承
2020/06/19 Python
俄罗斯美容和健康网上商店:Созвездие Красоты
2019/07/23 全球购物
英国No.1体育用品零售商:SportsDirect.com
2019/10/16 全球购物
智能钱包:Ekster
2019/11/21 全球购物
建筑施工实习自我鉴定
2013/09/19 职场文书
小学生环保演讲稿
2014/04/25 职场文书
传播学专业毕业生自荐书
2014/07/01 职场文书
技术股份合作协议书
2014/10/05 职场文书
2014年宣传工作总结
2014/11/18 职场文书
2014年生产部工作总结
2014/12/17 职场文书
银行实习推荐信
2015/03/27 职场文书
2015年销售助理工作总结
2015/05/11 职场文书
MySQL日期时间函数知识汇总
2022/03/17 MySQL
Android基础入门之dataBinding的简单使用教程
2022/06/21 Java/Android