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助手

相关推荐
倔强的石头_28 分钟前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
兵慌码乱13 小时前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析
python·opencv·计算机视觉·人机交互·手势识别·mediapipe·pyside2
luckdewei16 小时前
FastAPI 资产管理系统实战:复杂 ORM 关联、Alembic 迁移与 N+1 查询优化
python
aqi001 天前
15天学会AI应用开发(八)使用向量数据库实现RAG功能
人工智能·python·大模型·ai编程·ai应用
Csvn1 天前
`functools.lru_cache` —— 一行代码搞定缓存加速
后端·python
金銀銅鐵2 天前
[Python] 从《千字文》中随机挑选汉字
后端·python
cup112 天前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南
python·ai·环境变量·ci·nuitka·skill
aqi002 天前
15天学会AI应用开发(七)有了大模型为什么还要引入RAG
人工智能·python·大模型·ai编程·ai应用