使用javascript读取波形文件数据,并生成动态的波形图

代码如下:

javascript 复制代码
// HTML5 Canvas 动态波形生成器
// 使用JS读取波形文件并生成动态波形

// 创建Canvas并设置上下文
const canvas = document.createElement('canvas');
canvas.width = 800;
canvas.height = 400;
document.body.appendChild(canvas);
const ctx = canvas.getContext('2d');

// 波形数据
let waveform = [];

// 加载波形文件数据
async function loadWaveformData(url) {
  try {
    const response = await fetch(url);
    if (!response.ok) {
      throw new Error(`HTTP error! status: ${response.status}`);
    }
    const arrayBuffer = await response.arrayBuffer();
    const audioContext = new AudioContext();
    const audioBuffer = await audioContext.decodeAudioData(arrayBuffer);
    waveform = audioBuffer.getChannelData(0); // 获取左声道数据
    console.log('Waveform data loaded:', waveform);
    drawWaveform();
  } catch (error) {
    console.error('Error loading waveform data:', error);
  }
}

// 动态波形绘制参数
const waveParams = {
  sampleRate: 800, // 每帧波形的采样点数
  offset: 0, // 动态偏移
  speed: 2 // 波形滚动速度
};

// 动态绘制波形
function drawWaveform() {
  ctx.clearRect(0, 0, canvas.width, canvas.height);
  ctx.beginPath();

  const step = Math.max(1, Math.floor(waveform.length / waveParams.sampleRate)); // 每步采样间隔
  const centerY = canvas.height / 2;

  for (let i = 0; i < canvas.width; i++) {
    const sampleIndex = (waveParams.offset + i * step) % waveform.length;
    const sampleValue = waveform[Math.floor(sampleIndex)];
    const y = centerY + sampleValue * centerY; // 将样本值映射到画布高度
    if (i === 0) {
      ctx.moveTo(i, y);
    } else {
      ctx.lineTo(i, y);
    }
  }

  ctx.strokeStyle = '#007BFF';
  ctx.lineWidth = 2;
  ctx.stroke();

  waveParams.offset += waveParams.speed; // 波形滚动

  requestAnimationFrame(drawWaveform);
}

// 加载波形文件(将 `example.wav` 替换为你的文件路径)
loadWaveformData('example.wav');
相关推荐
AI糊涂是福1 小时前
MATLAB语言教程:从入门到精通的全面指南
开发语言·matlab·信息可视化
jz_ddk2 小时前
[学习] C语言多维指针探讨(代码示例)
linux·c语言·开发语言·学习·算法
He_k4 小时前
‘js@https://registry.npmmirror.com/JS/-/JS-0.1.0.tgz‘ is not in this registry
开发语言·javascript·ecmascript
星夜9824 小时前
C++回顾 Day6
开发语言·数据结构·c++·算法
UpUpUp……6 小时前
C++复习
开发语言·c++·笔记
艾莉丝努力练剑6 小时前
深入详解编译与链接:翻译环境和运行环境,翻译环境:预编译+编译+汇编+链接,运行环境
c语言·开发语言·汇编·学习
汪子熙7 小时前
Angular i18n 资源加载利器解析: i18n-http-backend
前端·javascript·面试
天天扭码7 小时前
前端必备 | 一文掌握React的Token管理
前端·javascript·react.js
烛阴7 小时前
用Joi守住数据防线!Node.js/前端必备校验神器入门与进阶
前端·javascript
开发者工具分享8 小时前
Lua 的速度为什么比 Python 快
开发语言·python·lua