Wavesurfer.js音频播放器插件的使用教程
Wavesurfer.js是一款基于HTML5 canvas和Web Audio的音频播放器插件,本文主要记录它及其视觉效果插件Regions插件的使用方法。
1、创建实例
- 引入插件
import WaveSurfer from "wavesurfer.js";
- 创建实例对象
this.wavesurfer = WaveSurfer.create(options);
options
| 参数 | 默认值 | 说明 |
|---|---|---|
| audioRate | 1 | 音频的播放速度,数值越小越慢 |
| barWidth | none | 如果设置,波纹的样式将变成类似柱状图的形状 |
| barHeight | 1 | 波纹柱状图的高度,当大于1的时候,将增加设置的高度 |
| barGap | none | 波纹柱状图之间的间距 |
| container | none | 必填参数,指定渲染的dom的id名、类名或者dom本身 |
| cursorColor | none | 鼠标点击的颜色 |
| cursorWidth | 1 | 鼠标点击显示的宽度 |
| height | 128 | 音频的显示高度 |
| hideScrollbar | false | 当出现横坐标的时候,设置是否显示 |
| mediaType | audio | 音频的类型,支持video |
| plugins | [] | 使用的插件 |
| progressColor | #555 | 光标后面的波形部分的填充颜色 |
| waveColor | #555 | 光标后面的波形的填充颜色 |
| xhr | {} | 额外的请求XHR参数 |
实例演示:
this.wavesurfer = WaveSurfer.create({
container: "#wave",
waveColor: "#368666",
progressColor: "#6d9e8b",
cursorColor: "#fff",
height: 80,
plugins: [RegionsPlugin.create()]
});

2、方法调用
| 方法 | 说明 |
|---|---|
| load(url) | 加载音频 |
| loadBlob(url) | 从Bolb或者file对象中调用音频 |
| play([start[, end]]) | 从当前位置开始播放音频文件。结合使用start和end可以指定一个音频播放范围 |
| playPause() | 如果当前为状态状态开始播放,反之暂停播放 |
| pause() | 停止播放 |
| stop() | 停止播放并回到音频文件的起始处 |
| empty() | 清空waveform |
| destroy() | 销毁waveform,移除事件,元素和关联节点 |
| getCurrentTime() | 获取当前播放的进度,单位:秒 |
| getDuration() | 获取音频的总时长,单位:秒 |
| getVolume() | 获取音量 |
| setVolume(v) | 设置音量[0-1] |
| skip(offset) | 调到offset的位置 |
| skipBackward() | 倒退skipLength秒 |
| skipForward() | 前进skipLength秒 |
| isPlaying() | 判断音频是否在播放 |
| on(eventName, callback) | 绑定事件 |
| un(eventName, callback) | 解绑事件 |
| unAll | 绑定所有的事件 |
实例演示:
// 音频加载
this.wavesurfer.load(audioUrl);
// 获取总时长
let duration = parseInt(this.wavesurfer.getDuration());
// 停止播放并回到起始点
this.wavesurfer.stop();
3、事件绑定
使用on()和un()对事件进行绑定和解绑操作。
| 事件 | 说明 |
|---|---|
| audioprocess | 音频播放时触发 |
| destroy | 音频销毁时触发 |
| error | 音频出错时触发 |
| finish | 音频播放结束时触发 |
| loading | 音频加载时触发 |
| ready | 音频加载成功时触发 |
| play | 音频开始播放时触发 |
| pause | 音频暂停时触发 |
| scroll | 当有滚动条滚动的时候触发 |
| volume | 声音调整时触发 |
| seek | 鼠标点击某个位置的时候触发 |
实例演示:
// 加载时候
this.wavesurfer.on("loading", percents => {
// 当前加载的进度
this.percent = percents;
});
// 加载成功
this.wavesurfer.on("ready", () => {
this.progress = false;
});
// 播放中
this.wavesurfer.on("audioprocess", () => {
this.currentTime = this.getCurrentTime();
});
// 结束播放
this.wavesurfer.on("finish", () => {
this.wavesurfer.pause();
});
4、Regions插件
Regions用于音频播放器waveform视觉效果部分,可以用它来标注某个区域。Regions可以被拖拽和改变尺寸大小。
- 引入插件
import RegionsPlugin from "wavesurfer.js/dist/plugin/wavesurfer.regions.min.js";
- 插件定义
this.wavesurfer = WaveSurfer.create({
plugins: [RegionsPlugin.create()]
});
- Regions方法
| 方法 | 说明 |
|---|---|
| addRegion(options) | 在waveform中创建一个Region。返回一个Region对象 |
| clearRegions() | 移除所有的regions |
| enableDragSelection(options) | 可以通过选择来创建支持拖拽和改变大小的Regin |
- Regions的options
| 参数 | 默认值 | 说明 |
|---|---|---|
| id | region的id | |
| start | 0 | region的开始位置,单位秒 |
| end | 0 | region的开始位置,单位秒 |
| loop | false | 播放完毕后是否循环播放 |
| drag | true | 是否支持拖拽 |
| resize | true | 是否支持改变region的大小 |
| color | "rgba(0, 0, 0, 0.1)" | region的颜色 |
实例演示:
this.currentRegion = this.wavesurfer.addRegion({
id: id,
start: startTime,
end: endTime,
loop: false,
drag: false,
resize: false,
color: "rgba(254, 255, 255, 0.4)"
});

- Regions的方法
| 方法 | 说明 |
|---|---|
| play() | 播放region |
| playLoop() | 循环播放region |
| remove() | 移除region |
- Regions的事件
| 事件 | 说明 |
|---|---|
| remove | 在region被移除前触发 |
| update | 当region被更新时触发 |
| click | 当region点击时触发 |
| dbclick | 当region被双击时触发 |
| over | 当region被鼠标滑入时触发 |
| leave | 当在region上的鼠标离开时触发 |
// 更新起始时间
this.currentRegion.update({ start: newStartTime });
// 移除region
this.currentRegion.remove();
更多方法请看官网:wavesurfer官网
Wavesurfer.js音频播放器插件的使用教程的更多相关文章
- js插件---10个免费开源的JS音乐播放器插件
js插件---10个免费开源的JS音乐播放器插件 一.总结 一句话总结:各种插件都有很多,多去找. 二.js插件---10个免费开源的JS音乐播放器插件 亲测可用 音乐播放器在网页设计中有时候会用到, ...
- 10个免费开源的JS音乐播放器插件
点这里 音乐播放器在网页设计中有时候会用到,比如一些时尚类.音乐或影视类等项目,但这些 网页播放器 插件比较少见,所以这里为大家整理一个集合,也许会有用到的时候. 下面整理的播放器有些是支持自适应的, ...
- 基于canvas和Web Audio的音频播放器
wavesurfer.js是一款基于HTML5 canvas和Web Audio的音频播放器插件.通过wavesurfer.js你能够使用它来制作各种HTML5音频播放器,它能够在各种支持 Web A ...
- 【jquery】一款不错的音频播放器——Amazing Audio Player
前段时间分享了一款视频播放器,点击这里.今天介绍一款不错的音频播放器——Amazing Audio Player. 介绍: Amazing Audio Player 是一个使用很方便的 Windows ...
- 小型音乐播放器插件APlayer.js的简单使用例子
本篇博客将会给出一个小型音乐播放器插件APlayer.js的使用例子.关于APlayer.js的具体介绍和Github地址,可以参考: https://github.com/MoePlayer/A ...
- 使用EasyNVR无插件流媒体服务器接口和EasyPlayer.js播放器插件实现web网页H5播放无插件
1.背景需求 很多客户在使用EasyNVR无插件流媒体服务器时,不喜欢产品化的界面,有时可能满足不了日常观看使用的需求.因此软件提供丰富的HTTP接口,供第三方平台调用集成.但是有时客户这边可能没有专 ...
- (原创)jQuery Media Plugin-jQuery的网页媒体播放器插件的使用心得
jQuery Media Plugin是一款基于jQuery的网页媒体播放器插件,它支持大部分的网络多媒体播放器和多媒体格式,比如:Flash, Windows Media Player, Real ...
- Asp.Net MVC中Aplayer.js音乐播放器的使用
1.前言: Aplater.js是一款可爱.漂亮的Js音乐播放器,以前就了解过也弄过一些,现在就用mp3的格式来在.Net里面开发.管网 https://aplayer.js.org/ 2.入手: 在 ...
- HTML5 音频播放器-Javascript代码(短小精悍)
直接上干货咯! //HTML5 音频播放器 lzpong 2015/01/19 var wavPlayer = function () { if(window.parent.wavPlayer) re ...
随机推荐
- 常用的自动化测试框架及测试框架的发展(Alpha)
前言:自动化测试在过去的20年已经有了很大的发展.最初的测试工具只提供了简单的捕捉/回访功能,维护性较差.而且脚本工具实现需要很强的开发技术和经验,而且数量众多的测试脚本加上没有文档记录因此维护起来较 ...
- axure rp8.1 注册码
授权人:University of Science and Technology of China (CLASSROOM)授权密钥:DTXRAnPn1P65Rt0xB4eTQ+4bF5IUF0gu0X ...
- Jarsigner签名使用
转载请标明出处: http://www.cnblogs.com/why168888/p/6548544.html 本文出自:[Edwin博客园] 如何签名: jarsgner-verbose-keys ...
- (六)Linux下的压缩命令
======================================================================================== .zip格式的压缩和解 ...
- cogs 2355. [HZOI 2015] 有标号的DAG计数 II
题目分析 来自2013年王迪的论文<浅谈容斥原理> 设\(f_{n,S}\)表示n个节点,入度为0的点集恰好为S的方案数. 设\(g_{n,S}\)表示n个节点,入度为0的点集至少为S的方 ...
- 【【模板】严格次小生成树[BJWC2010]】
树上的路径怎么能没有树剖 显然,次小生成树和最小生成树只在一条边上有差距,于是我们就可以枚举这一条边,将所有边加入最小生成树,之后再来从这些并不是那么小的生成树中找到那个最小的 我们往最小生成树里加入 ...
- Django中模型(四)
Django中模型(四) 五.创建对象 1.目的 向数据库中添加数据.当创建对象时,Django不会对数据库进行读写操作,当调用save()方法时,才与数据库交互,将对象保存到数据库中 2.注意 __ ...
- LayIM.AspNetCore Middleware 开发日记(五)Init接口实现细节
前言 “一旦开始了就要坚持下去“.为什么本文的第一句话是这么一句话呢,因为我经常就是开头轰轰烈烈,结果越来越枯燥,就不想做下去了.但是版图就放弃又那么不甘心,继续加油吧. 吐槽完毕,进入正题.在上一篇 ...
- virtualbox+vagrant学习-2(command cli)-1-vagrant box命令
vagrant box 这是用于管理(添加.删除等)boxes的命令. box 是一个打包好的操作系统,是一个后缀名为 .box 的文件,其实是一个压缩包,里面包含了 Vagrant 的配置信息和 V ...
- XCODE7 和IOS9适配后的一些问题
网上比较常规的几个问题就不细说了. 什么HTTPS.bitcode.什么什么的. 记录几个自己又遇到了但是网上没有说的. 启动应用报错, *** Terminating app due to unca ...