Project Icon

web-audio-api-rs

纯Rust实现的Web Audio API库,支持非浏览器环境

web-audio-api-rs是一个纯Rust实现的Web Audio API库,适用于非浏览器环境。它支持在桌面应用、命令行工具和无头执行中进行音频处理。该项目兼容多种音频后端,如ALSA、WASAPI和CoreAudio,并提供Node.js绑定。web-audio-api-rs遵循W3C规范,为Rust开发者提供灵活、高性能的音频处理工具。

Rust Web音频API

crates.io docs.rs

Web音频API的纯Rust实现,用于非浏览器环境

关于Web音频API

Web音频API (MDN文档) 提供了一个强大而灵活的系统来控制Web上的音频,允许开发者选择音频源、为音频添加效果、创建音频可视化、应用空间效果(如声像)等等。

我们的Rust实现将Web音频API与Web解耦。现在你可以在桌面应用、命令行工具、无头执行等场景中使用它。

使用示例

use web_audio_api::context::{AudioContext, BaseAudioContext};
use web_audio_api::node::{AudioNode, AudioScheduledSourceNode};

// 根据你的硬件设置优化的音频上下文
let context = AudioContext::default();

// 对于背景音乐,从本地文件读取
let file = std::fs::File::open("samples/major-scale.ogg").unwrap();
let buffer = context.decode_audio_data_sync(file).unwrap();

// 设置AudioBufferSourceNode
let mut src = context.create_buffer_source();
src.set_buffer(buffer);
src.set_loop(true);

// 创建一个双二阶滤波器
let biquad = context.create_biquad_filter();
biquad.frequency().set_value(125.);

// 连接音频节点
src.connect(&biquad);
biquad.connect(&context.destination());

// 播放缓冲区
src.start();

// 欣赏音乐
std::thread::sleep(std::time::Duration::from_secs(4));

查看文档了解更多信息。

规范遵从性

我们尽可能严格遵守官方W3C规范,但一些偏差是不可避免的:

  • 命名:使用snake_case而不是CamelCase
  • 使用getter/setter方法而不是暴露属性
  • 引入了一些命名空间
  • 继承通过trait来建模

绑定

我们在https://github.com/ircam-ismm/node-web-audio-api提供了这个库的NodeJS绑定,因此你可以通过简单编写原生NodeJS代码来使用这个库。

这使我们能够运行官方的WebAudioAPI测试套件追踪我们的规范遵从性得分

音频后端

默认情况下,使用cpal库进行跨平台音频I/O。

我们通过cubeb特性标志为cubeb后端提供实验性支持。请注意,为了运行cubeb,必须在本地安装cmake

特性标志后端
cpal(默认)ALSA、WASAPI、CoreAudio、Oboe(Android)
cpal-jackJACK
cpal-asioASIO 参见 https://github.com/rustaudio/cpal#asio-on-windows
cubebPulseAudio、AudioUnit、WASAPI、OpenSL、AAudio、sndio、Sun、OSS

Linux用户注意事项

在Linux上使用ALSA后端的库可能会导致意外的刺耳声音(默认渲染大小为128帧)。在这种情况下,一个简单的解决方法是在创建音频上下文时传递AudioContextLatencyCategory::Playback延迟提示,这将增加渲染大小到1024帧:

let audio_context = AudioContext::new(AudioContextOptions {
    latency_hint: AudioContextLatencyCategory::Playback,
    ..AudioContextOptions::default()
});

对于需要低延迟的实时和交互式应用,你应该使用cpal提供的JACK后端。为此,你需要一个运行中的JACK服务器,并使用cpal-jack特性构建你的应用,例如cargo run --release --features "cpal-jack" --example microphone

针对浏览器

我们可以通过cpalwasm-bindgen后端将Rust WebAudio输出重新输入到浏览器中,从而完成全循环。查看一个WASM项目示例。 警告:实验性功能!

贡献

web-audio-api-rs欢迎所有人以建议、错误报告、拉取请求和反馈的形式做出贡献。💛

如果你需要贡献的想法,有几种方法可以开始:

  • 尝试我们的一些示例(位于examples/目录)并开始构建你自己的音频图
  • 发现了bug或有功能请求?提交一个问题
  • 标记为good first issue的问题是相对简单的入门问题。

除非你明确声明,否则你有意提交以包含在web-audio-api-rs中的任何贡献,均应根据MIT许可证授权,不附加任何其他条款或条件。

许可证

本项目根据MIT许可证授权。

致谢

用于HRTF空间化的IR文件是Ircam EAC团队创建的LISTEN数据库的一部分。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号