HTML5音频通过OscillatorNode产生基础波形测试

OscillatorNode 专用于实时生成基础波形(正弦/方波等),不能播放MP3/WAV;它无输入接口,只输出周期信号,需配合AudioBufferSourceNode实现音频文件播放。HTML5音频中,OscillatorNode 并不用于"播放"已有音频文件,而是专门用来**实时生成基础波形**(如正弦波、方波、锯齿波、三角波),是 Web Audio API 中实现声音合成的核心节点之一。它本身不加载任何音频资源,而是从零开始振荡输出信号。为什么不能直接用 OscillatorNode 播放 MP3/WAV?OscillatorNode 是一个**声源节点(AudioNode)**,但它没有输入接口,只产生固定频率/波形的周期性信号。它和 AudioBufferSourceNode(用于播放预加载的音频缓冲区)职责不同:OscillatorNode:适合做音效生成、调制、教学演示、简单蜂鸣器、音高测试等; AudioBufferSourceNode:适合播放录制好的音频文件(需先解码为 AudioBuffer); 试图把 MP3 数据喂给 OscillatorNode 会报错------它根本无法接收外部音频数据。用 OscillatorNode 生成并播放正弦波(最简示例)以下代码在用户手势触发后启动一个 440Hz 的纯正弦波(标准 A4 音):const audioContext = new (window.AudioContext || window.webkitAudioContext)();const oscillator = audioContext.createOscillator();const gainNode = audioContext.createGain();oscillator.type = 'sine'; // 可选:'sine' | 'square' | 'sawtooth' | 'triangle'oscillator.frequency.value = 440;gainNode.gain.value = 0.3; // 控制音量,避免爆音oscillator.connect(gainNode);gainNode.connect(audioContext.destination);// 必须在用户交互(如点击)中启动,防止自动播放策略拦截document.querySelector('#startBtn').addEventListener('click', () => { if (audioContext.state === 'suspended') { audioContext.resume(); // iOS/Safari 等需要显式 resume } oscillator.start();});常见波形特点与听感差异同一频率下,不同 type 产生的谐波成分不同,直接影响音色: RedClaw 百度推出的手机端万能AI Agent助手

相关推荐
無限進步D1 分钟前
MySQL 子查询
数据库·mysql
大数据魔法师1 分钟前
Streamlit(二十)- API 参考文档(十三)- 缓存与状态管理组件
python·web
Dxy123931021612 分钟前
Django 模型查询中的数据库连接池配置指南
数据库·django·sqlite
Byron__16 分钟前
数据库高频面试核心知识点
数据库·面试
Cloud_Shy61819 分钟前
解读《Effective Python 3rd Edition》:从练气到老魔(第一章 Item 7 - 9)
开发语言·数据库·python
weixin_BYSJ198720 分钟前
基于Django的非物质文化遗产管理系统设计与实现(源码 + 文档)98950
java·javascript·spring boot·python·django·flask·php
小张小张爱学习24 分钟前
JVM高频面试题
java·jvm
Yvonne爱编码27 分钟前
数据库---Day10 索引
数据库·sql·mysql
Wonderful U28 分钟前
基于Python+Django+psutil的轻量化服务器自动化监控平台实战
服务器·python·django
Jul1en_33 分钟前
【Redis】 集群概念
数据库·redis·哈希算法