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助手
相关推荐
YuanDaima20482 小时前
大语言模型生命周期全链路解析:从架构基石到高效推理kronos.荒2 小时前
回溯(python)weixin_580614002 小时前
golang如何使用sync.WaitGroup_golang sync.WaitGroup并发等待使用方法kiku18182 小时前
NoSQL之Redis集群疯狂打码的少年2 小时前
单向循环链表 + 尾指针:让插入删除更高效的秘密武器2401_883600252 小时前
如何配置Oracle的外部口令存储_安全外部密码库Wallet自动登录2401_897190552 小时前
如何在MongoDB中实现连表查询_group与累计求和操作justjinji2 小时前
PHP源码运行是否受硬盘转速影响_7200转vs5400转对比【指南】2301_796588502 小时前
如何用 error 事件全局捕获页面图片或脚本加载失败状态