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自定义插件封装,实现简易的elementUi的Message和MessageBox的示例
Nov 20 Vue.js
在Vue中使用mockjs代码实例
Nov 25 Vue.js
vue表单验证之禁止input输入框输入空格
Dec 03 Vue.js
vue使用exif获取图片经纬度的示例代码
Dec 11 Vue.js
vue下拉刷新组件的开发及slot的使用详解
Dec 23 Vue.js
vue+openlayers绘制省市边界线
Dec 24 Vue.js
vue3中轻松实现switch功能组件的全过程
Jan 07 Vue.js
vue.js实现点击图标放大离开时缩小的代码
Jan 27 Vue.js
vue完美实现el-table列宽自适应
May 08 Vue.js
vite+vue3.0+ts+element-plus快速搭建项目的实现
Jun 24 Vue.js
Vue的生命周期一起来看看
Feb 24 Vue.js
解决vue中provide inject的响应式监听
Apr 19 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
ajax缓存问题解决途径
2006/12/06 PHP
PHP教程 变量定义
2009/10/23 PHP
php删除数组中重复元素的方法
2015/12/22 PHP
php实现替换手机号中间数字为*号及隐藏IP最后几位的方法
2016/11/16 PHP
javascript不同类型数据之间的运算的转换方法
2014/02/13 Javascript
ECMAScript5(ES5)中bind方法使用小结
2015/05/07 Javascript
javascript获取本机操作系统类型的方法
2015/08/13 Javascript
三种AngularJS中获取数据源的方式
2016/02/02 Javascript
详解vue组件化开发-vuex状态管理库
2017/04/10 Javascript
深入理解Angular.JS中的Scope继承
2017/06/04 Javascript
vue 实现 ios 原生picker 效果及实现思路解析
2017/12/06 Javascript
完美解决iview 的select下拉框选项错位的问题
2018/03/02 Javascript
解决vue处理axios post请求传参的问题
2018/03/05 Javascript
解决Angular2 router.navigate刷新页面的问题
2018/08/31 Javascript
react-native滑动吸顶效果的实现过程
2019/06/03 Javascript
Node.js操作MongoDB数据库实例分析
2020/01/19 Javascript
JavaScript实现栈结构Stack过程详解
2020/03/07 Javascript
js获取url页面id,也就是最后的数字文件名
2020/09/25 Javascript
Python自动化运维和部署项目工具Fabric使用实例
2016/09/18 Python
python和ruby,我选谁?
2017/09/13 Python
Python使用pickle模块存储数据报错解决示例代码
2018/01/26 Python
Python3 XML 获取雅虎天气的实现方法
2018/02/01 Python
Python 3.x 安装opencv+opencv_contrib的操作方法
2018/04/02 Python
解决python 输出是省略号的问题
2018/04/19 Python
Python 中字符串拼接的多种方法
2018/07/30 Python
详解numpy.meshgrid()方法使用
2019/08/01 Python
用python实现一个简单计算器(完整DEMO)
2020/10/14 Python
CSS3网格的三个新特性详解
2014/04/04 HTML / CSS
大韩航空官方网站:Korean Air
2017/10/25 全球购物
澳大利亚设计的优质鞋类和适合澳大利亚生活方式的服装:Rivers
2019/04/23 全球购物
关于Java String的一道面试题
2013/09/29 面试题
2016寒假社会实践心得体会范文
2015/10/09 职场文书
观看《筑梦中国》纪录片心得体会
2016/01/18 职场文书
《世界多美呀》教学反思
2016/02/22 职场文书
Python移位密码、仿射变换解密实例代码
2021/06/27 Python
Vue Element plus使用方法梳理
2022/12/24 Vue.js