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使用vant中的checkbox实现全选功能
Nov 17 Vue.js
vue3使用vue-count-to组件的实现
Dec 25 Vue.js
浅析vue中的nextTick
Dec 28 Vue.js
vue实现简易的双向数据绑定
Dec 29 Vue.js
Vue项目中使用mock.js的完整步骤
Jan 12 Vue.js
vue组件是如何解析及渲染的?
Jan 13 Vue.js
vue集成一个支持图片缩放拖拽的富文本编辑器
Jan 29 Vue.js
详解Vue的options
May 15 Vue.js
vue-cropper插件实现图片截取上传组件封装
May 27 Vue.js
vue+springboot实现登录验证码
May 27 Vue.js
vue3中provide && inject的使用
Jul 01 Vue.js
vue中div禁止点击事件的实现
Apr 02 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实现将科学计数法转换为原始数字字符串的方法
2014/12/16 PHP
PHP用continue跳过本次循环中剩余代码的注意点
2017/06/27 PHP
用Javascript读取中文COOKIE的解决办法
2007/02/15 Javascript
百度留言本js 大家可以参考下
2009/10/13 Javascript
javascript showModalDialog模态对话框使用说明
2009/12/31 Javascript
Json2Template.js 基于jquery的插件 绑定JavaScript对象到Html模板中
2011/10/29 Javascript
使用js的replace()方法查找字符示例代码
2013/10/28 Javascript
通过onmouseover选项卡实现img图片的变化
2014/02/12 Javascript
基于BootStarp的Dailog
2016/04/28 Javascript
WebSocket+node.js创建即时通信的Web聊天服务器
2016/08/08 Javascript
livereload工具实现前端可视化开发【推荐】
2016/12/23 Javascript
微信小程序(三):网络请求
2017/01/13 Javascript
使用jQuery监听扫码枪输入并禁止手动输入的实现方法(推荐)
2017/03/21 jQuery
vue2.0 和 animate.css的结合使用
2017/12/12 Javascript
node puppeteer(headless chrome)实现网站登录
2018/05/09 Javascript
详解vue+webpack+express中间件接口使用
2018/07/17 Javascript
让 babel webpack vue 配置文件支持智能提示的方法
2019/06/22 Javascript
解决vue打包后vendor.js文件过大问题
2019/07/03 Javascript
更强大的vue ssr实现预取数据的方式
2019/07/19 Javascript
javascript实现的图片预览和上传功能示例【兼容IE 9】
2020/05/01 Javascript
echarts饼图各个板块之间的空隙如何实现
2020/12/01 Javascript
python插入排序算法实例分析
2015/07/03 Python
Python3 XML 获取雅虎天气的实现方法
2018/02/01 Python
便捷提取python导入包的属性方法
2018/10/15 Python
django echarts饼图数据动态加载的实例
2019/08/12 Python
详解在Python中以绝对路径或者相对路径导入文件的方法
2019/08/30 Python
Pytorch之parameters的使用
2019/12/31 Python
解析html5 canvas实现背景鼠标连线动态效果代码
2019/06/17 HTML / CSS
婴儿鞋,独特的婴儿服装和配件:Zutano
2018/11/03 全球购物
环保建议书
2014/03/12 职场文书
介绍信模板
2015/01/31 职场文书
违反纪律检讨书范文
2015/05/07 职场文书
行政上诉状范文
2015/05/23 职场文书
2016元旦晚会主持词开场白和结束语
2015/12/04 职场文书
2016年大学校运会广播稿件
2015/12/21 职场文书
Go语言基础map用法及示例详解
2021/11/17 Golang