js-基于AudioContext在canvas上显示声音波形

2024-09-05 11:48

本文主要是介绍js-基于AudioContext在canvas上显示声音波形,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

js-基于AudioContext在canvas上显示声音波形 目录

文章目录

  • 前言
  • 效果展示
  • 代码展示
    • `index.html`
    • `Aud.js`


前言

  • ES7后开始启用AudioContex
  • 常用API是:createScriptProcessor, onaudioprocess, getChannelData
  • 注意:onaudioprocess已经废弃,开始改用AnalyserNode,MDN-AnalyserNode

效果展示

在这里插入图片描述

代码展示

index.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Canvas Audio</title><style>body, div {margin: 0px;padding: 0px;text-align: center;}#cav {border: 1px solid black;border-radius: 4px;margin: 10px auto;}</style>
</head>
<body>
<canvas id="cav" width="400" height="300"></canvas>
</body>
<script src="Aud.js"></script>
<script>
let ctx = document.getElementById('cav').getContext('2d');
let SampleSize = 1024;window.onload = function (){init();
};function init() {AudManager.urls = ["test.mp3"];AudManager.init();AudManager.load(()=>{let jNode = AudManager.createNode(2, [SampleSize, 1, 1]);let pNode = AudManager.createNode();ctx.strokeStyle = "red";jNode.onaudioprocess = function (e){renderWave(e);};let sound1 = AudManager.items[0];sound1.addNode(pNode);sound1.addNode(jNode, 1);sound1.play();});
}function renderWave(e){ctx.clearRect(0,0,400,300);let bufData = e.inputBuffer.getChannelData(0);ctx.beginPath();ctx.moveTo(0,150);for (let i = 0, len = bufData.length, mix = Math.min(400, len); i < mix; i++){ctx.lineTo(i, bufData[i]*150+150);}ctx.stroke();ctx.closePath();
}
</script>
</html>

Aud.js

let Aud = function (ctx, url) {this.ctx = ctx;this.url = url;//    source节点this.src = ctx.createBufferSource();//    多个处理节点组this.pNode = [];
};Aud.prototype = {output(){for (let i = 0; i < this.pNode.length; i++){let tNode = this.src;for (let j = 0; j < this.pNode[i].length; j++){tNode.connect(this.pNode[i][j]);tNode = this.pNode[i][j];}tNode.connect(this.ctx.destination);}},play(loop){this.src.loop = loop || false;this.output();this.src.start(0);},stop() {this.src.stop();},addNode(node, groupIdx = 0){this.pNode[groupIdx] = this.pNode[groupIdx] || [];this.pNode[groupIdx].push(node);}
};//设置节点类型
Aud.NODETYPE = {GNODE: 0 // 表示gainNode节点
}//Aud管理对象
AudManager = {urls: [],items: [],ctx: null,init(){try{this.ctx = new AudioContext();}catch (e) {console.log(`${e}`);}},load(callback){for (let i = 0; i < this.urls.length; i++){this.loadSingle(this.urls[i], callback);}},loadSingle(url, callback){let req = new XMLHttpRequest();req.open('GET', url, true);req.responseType = 'arraybuffer';let self = this;req.onload = function () {self.ctx.decodeAudioData(this.response).then(buf => {let aud = new Aud(self.ctx, url);aud.src.buffer = buf;self.items.push(aud);if (self.items.length == self.urls.length){callback();}},err => {console.log(`decode error:${err}`);})};req.send();},createNode(nodeType, param){let node = null;switch (nodeType) {case 1:node = this.ctx.createPanner();break;case 2:node = this.ctx.createScriptProcessor(param[0], param[1], param[2]);break;default:node = this.ctx.createGain();}return node;}
};

这篇关于js-基于AudioContext在canvas上显示声音波形的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1138876

相关文章

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

在Node.js中使用.env文件管理环境变量的全过程

《在Node.js中使用.env文件管理环境变量的全过程》Node.js应用程序通常依赖于环境变量来管理敏感信息或配置设置,.env文件已经成为一种流行的本地管理这些变量的方法,本文将探讨.env文件... 目录引言为什么使php用 .env 文件 ?如何在 Node.js 中使用 .env 文件最佳实践引

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

SpringSecurity显示用户账号已被锁定的原因及解决方案

《SpringSecurity显示用户账号已被锁定的原因及解决方案》SpringSecurity中用户账号被锁定问题源于UserDetails接口方法返回值错误,解决方案是修正isAccountNon... 目录SpringSecurity显示用户账号已被锁定的解决方案1.问题出现前的工作2.问题出现原因各

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

RedisTemplate默认序列化方式显示中文乱码的解决

《RedisTemplate默认序列化方式显示中文乱码的解决》本文主要介绍了SpringDataRedis默认使用JdkSerializationRedisSerializer导致数据乱码,文中通过示... 目录1. 问题原因2. 解决方案3. 配置类示例4. 配置说明5. 使用示例6. 验证存储结果7.

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1