基于wavesurfer,regions 封装的可视化音标标注控件

本文介绍了一个利用wavesurfer.js库和其regions插件封装的Vue组件,用于创建前端的可视化音标标注工具。用户需预先引入wavesurfer及regions相关文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

基于wavesurfer,regions 封装的可视化音标标注控件
在这里插入图片描述

/*!
 * wavesurfer.js regions plugin 5.1.0 (2021-08-05)
 * https://wavesurfer-js.org
 * @license BSD-3-Clause
 * @author huinian
 */

import WaveSurfer from '@/assets/js/wavesurfer';
import Regions from '@/assets/js/wavesurfer.regions';

type OptionsType = {
   
  el: string; // 播放器容器
  src: string; // 播放音频资源
  regions?: Array<RegionsType>; // 初始化区域数据
  isTightRegions?: boolean; // 连续的区域渲染
  regionUpdateCallBack?: any; // region 修改后的回调
  desabled?: boolean; // 如果是true,仅支持播放操作
}

type RegionsType = {
   
  start: number; // 开始时间
  end: number; // 结束时间
  resize: boolean; // 是否允许调整大小
  drag?: boolean; // 是否允许移动
  loop?: boolean; // 是否循环播放
  minLength?: number; // 区域最小长度
  color?: string; // 背景色
}

/**
 * region data 相关配置参数
 */
const normalColor = 'rgba(255, 83, 83, 0.22)';
const activeColor = 'rgba(255, 83, 83, 0.3)';
class InitWavesurfer {
   
  wavesurfer: any; // 播放器实例
  options: OptionsType // 初始化实例参数
  duration: string; // 音频总时长
  regions: any = null; // 这里是所有的region实例
  static waveIsReady: boolean = false; // wave渲染完成
  /**
   * 下面这5行,全部和拖拽手柄相关
   */
  static isMoveHandle: boolean = false; // 鼠标松开时重置
  targetElement: HTMLElement = null; // 拖拽手柄时的target,鼠标松开时清空
  prevElement: HTMLElement = null; // 拖拽手柄时的上一个region,鼠标松开时清空
  nextElement: HTMLElement = null; // 拖拽手柄时的下一个region,鼠标松开时清空
  currentRegion: any = null; // 被操作的region对象,点击region和拖动手柄时记录,但是拖动手柄后会被清除,而点击region时不会清空
  constructor (options: OptionsType) {
   
    if (new.target !== InitWavesurfer) {
   
      return Object.create(null);
    }
    this.options = options;
    this.options.regions.forEach(item => {
   
      if (options.desabled) {
   
        item.resize = false;
      }
      item.drag = false;
      item.minLength = 1;
      item.color = normalColor;
    })
    this.initAudio(); // 初始化音频实例,并加载音频
    /**
     * 将事件绑定的this指向改成构造函数,要不然remove时,this错误
     */
    this.regionBarMouseMove = this.regionBarMouseMove.bind(this);
    this.regionClickEvent = this.regionClickEvent.bind(this);
    this.regionBarMouseDown = this.regionBarMouseDown.bind(this);
    this.regionBarMouseUp = this.regionBarMouseUp.bind(this);
  }

  /**
   * 初始化音频和regions插件
   */
  initAudio () {
   
    this.wavesurfer = WaveSurfer.create({
   
      container: document.querySelector(this.options.el),
      backgroundColor: '#0b151c', // 容器的背景色
      waveColor: '#20BBB9', // 波形的填充颜色
      progressColor: '#03a2a0', // 光标后的波形颜色
      cursorColor: '#20BBB9', // 光标填充颜色
      height: 150, // 波形区域的高度
      barHeight: 1, // 波形条的高度,大于 1 的数字将增加波形条的高度
      partialRender: true, // PeakCache峰值缓存提高大波形的渲染速度
      normalize: true, // 如果true,则按最大峰值而不是 1.0 进行归一化
      plugins: [
        Regions.create({
   
          regions: this.options.regions,
          dragSelection: !this.options.desabled
        })
      ]
    });
    this.load(this.options.src); // 加载音频
    this.listenerWave(this.wavesurfer); // 监听音频是否加载完成
  }

  /**
   * 加载音频
   * @param src
   */
  load (src) {
   
    this.wavesurfer.load(src);
  }

  /**
   * wavesurfer 原生事件监听器
   * @param wavesurfer
   */
  listenerWave (wavesurfer) {
   
    wavesurfer.on('ready', function () {
    // 音频加载完毕
      this.duration = wavesurfer.getDuration(); // 总时长
      this.bindRegionEvents(); // 音频加载完成后,绑定元素事件
      this.waveIsReady = true; //
      this.regions = this.wavesurfer.regions.list;
      this.handleCallback();
    }.bind(this));

    wavesurfer.on('error', function (e) {
   
      console.warn(e); // 音频加载失败
    });

    // 监听新建和修改的re
### 如何在 CentOS 7 中停止挂载磁盘或目录 在 CentOS 7 中,可以使用 `umount` 命令来卸载已经挂载的文件系统。以下是关于如何操作的具体说明: #### 使用 `umount` 卸载已挂载的设备 要卸载一个特定的挂载点,只需运行以下命令: ```bash umount /path/to/mountpoint ``` 例如,如果之前通过命令 `mount -t cifs -o //192.168.31.101/XiaoMi /disk_r1d` 将远程共享挂载到了 `/disk_r1d`[^1],那么可以通过如下方式卸载它: ```bash umount /disk_r1d ``` #### 处理繁忙的挂载点 有时可能会遇到错误提示:“target is busy”,这通常是因为有进程正在访问该挂载点的内容。为了强制卸载,可以加上 `-l` 或 `-f` 参数。 - **懒惰卸载**:允许卸载即使某些进程仍在使用该文件系统。 ```bash umount -l /path/to/mountpoint ``` - **强制卸载**:适用于无法正常卸载的情况(需谨慎使用)。 ```bash umount -f /path/to/mountpoint ``` #### 修改 `/etc/fstab` 文件以禁用自动挂载 如果希望防止某挂载点在下次启动时被重新挂载,则需要编辑 `/etc/fstab` 文件并移除对应的条目。例如,在教程中提到过向 `/etc/fstab` 添加内容以便实现开机自动挂载的操作[^3],此时可删除对应行即可阻止其再次加载。 #### 验证是否成功卸载 完成上述步骤之后,可通过查看当前所有挂载状态确认目标路径已被正确解除绑定: ```bash df -hT ``` 或者更具体地针对单个位置查询: ```bash findmnt /path/to/mountpoint ``` 以上就是在 CentOS 7 上执行 umount 的基本流程以及注意事项。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值