【音频可视化】通过canvas绘制音频波形图

前言

这两天写项目刚好遇到Ai对话相关的需求,需要录音功能,绘制录制波形图,写了一个函数用canvas实现可视化,保留分享一下,有需要的直接粘贴即可,使用时传入一个1024长的,0-255大小的Uint8Array类型音频数据源

javascript 复制代码
<canvas ref="canvasRef" width="800" height="200"></canvas>
javascript 复制代码
const drawWaveform = (audioArray) => {
  const canvas = canvasRef.value;
  if (!canvas || !audioArray) return;

  const ctx = canvas.getContext('2d');
  if (!ctx) return;

  const width = canvas.width;
  const height = canvas.height;
  const bufferLength = audioArray.length;

  // 清除画布
  ctx.clearRect(0, 0, width, height);

  // 设置线条样式
  ctx.strokeStyle = '#4f35b5';
  ctx.lineWidth = 2;
  ctx.beginPath();

  const sliceWidth = width / bufferLength;
  let x = 0;

  for (let i = 0; i < bufferLength; i++) {
    const value = audioArray[i] / 255.0;  // 将0-255的值归一化为0-1
    const y = value * height;

    if (i === 0) {
      ctx.moveTo(x, y);
    } else {
      ctx.lineTo(x, y);
    }

    x += sliceWidth;
  }

  ctx.stroke();
};

通过requestAnimationFrame调用即可

示例:

javascript 复制代码
// 持续更新波形
const updateWaveform = () => {
  ensureRecorder(() => {
    audioArray.value = recorder!.getRecordAnalyseData();
    drawWaveform(audioArray.value);
    animationFrameId = requestAnimationFrame(updateWaveform);
  });
};
相关推荐
Hello.Reader6 分钟前
Leptos + Tauri 2 前端配置Trunk + SSG + 移动端热重载一次打通(Leptos 0.6 口径)
前端
岱宗夫up13 分钟前
【前端基础】HTML + CSS + JavaScript 进阶(一)
开发语言·前端·javascript·css·html
源代码•宸18 分钟前
简版抖音项目——项目需求、项目整体设计、Gin 框架使用、视频模块方案设计、用户与鉴权模块方案设计、JWT
经验分享·后端·golang·音视频·gin·jwt·gorm
qq_242188633226 分钟前
【零基础使用Trae CN编写第一个AI游戏教程】
开发语言·前端·人工智能·python·游戏·html
a11177627 分钟前
3D赛车躲避游戏(html threeJS开源)
前端·游戏·3d·开源·html·threejs
PD我是你的真爱粉31 分钟前
Vue Router 4 路由进阶
前端·javascript·vue.js
木子欢儿32 分钟前
在 Debian 13(以及 12)上安装和配置 tightvncserver 并让普通用户使
运维·前端·debian
SakitamaX1 小时前
Nginx安装与实验
服务器·前端·nginx
用户新1 小时前
V8引擎 精品漫游指南--Ignition篇(中) AST详解 字节码的生成
前端·javascript
岱宗夫up1 小时前
【前端基础】HTML + CSS + JavaScript 基础(三)
开发语言·前端·javascript·css·html