`
mixer_a
  • 浏览: 368697 次
社区版块
存档分类
最新评论

用HTML5 Audio API开发游戏音乐

 
阅读更多

支持的浏览器:

难度:中等

注意:本文讨论的API尚未最终确定,仍在不断变化。请在自己的项目中谨慎使用。

介绍

音频在很大程度上使得多媒体体验非常引人注目。如果你曾经尝试在关闭声音的情况下看电影,你就很可能已经注意到了这一点。

游戏也不例外!我最喜爱的视频游戏的回忆里包含了音乐和声效。在二十年后的今天,大多情况下,当玩我最爱的游戏时,我仍然不能把“塞尔达”里近藤浩二乐曲马特大气的暗黑配乐从我的头脑里驱逐掉。这同样适用于音效,例如魔兽里单位实时点击的响应,以及任天堂的经典例子。

游戏的音频提出了一些有趣的挑战。要创建令人着迷的游戏音乐,设计人员需要调节潜在的不可预知的状态。实际上,部分游戏能持续未知的时间长度,声音可以与环境互动,并以复杂的方式混合起来,例如室内效果和相对声音定位。最后,可能有大量的一次播放声效,这需要不错的混合效果和在渲染时没有性能损失。

网页上的游戏音频

简单的游戏使用<audio>标签可能就足够了。然而,许多浏览器提供的简陋实现导致音频毛刺和高延迟的出现。这可能只是暂时性的问题,因为厂商们都在努力改进各自的实现。要了解<audio>标签的支持情况,我们可以使用areweplayingyet.org所提供的优秀测试工具

一旦深入<audio>标签规范,就会清楚了解到有很多事情根本不能用它实现。这并不奇怪,因为它主要被设计来支持多媒体播放。这些限制包括:

  • 无法为声音信号使用滤波器
  • 无法访问原始的PCM(宇捷:即WAV)数据
  • 没有来源和听众位置、方向的概念
  • 没有细粒度的计时

在下文中,我将深入介绍一些用WebAudio API编写游戏音频方面的内容。在入门教程里可以了解到此API的简单介绍。

背景音乐

游戏里往往有循环播放的背景音乐。例如,一个背景音轨如下:


如果你的循环音乐很短并且已知,会相当的烦人。当玩家被困在一个区域或者关卡上,会同时连续播放相同的背景音乐,我们可能需要逐渐淡出来防止让玩家厌烦。另一种策略是,根据游戏中的上下文,把不同的音效强度通过逐渐的淡入淡出混合起来。

如果你的玩家在一个史诗般的BOSS关卡里,可能需要对几个不同的情绪范围进行混音,例如从艺术氛围到有心理暗示的氛围再到激烈的氛围。音乐合成软件通常允许你通过选择音轨集合来导出几种混音(它们具有同样长度)。这样音轨之间就有某种内部一致性,避免出现从一个音轨切换到另一个时出现不和谐的转换过渡。


然后,利用WebAudio API,你可以使用某些类例如BufferLoader通过XHR导入所有这些音效样本(这在介绍网络音频API的文章中进行了深入介绍。加载音效需要时间,所以这些在游戏中使用的音效在每一关开始时,应该在页面加载时同时载入,或者在播放器播放时增量加载。

接下来,你需要为每个节点创建一个源,并为每个源创建一个增益节点,连接图如下:


完成之后,你可以在一个循环中同时回放这些音效源,因为它们都具有相同的长度,WebAudio API将保证它们保持一致。由于最后的BOSS战时音效风格会变得相近或更不同,游戏可以使用类似于下面的增量算法来改变链中各节点对应的增益值:

在上述方法中,有两个音效源同时播放,我们使用同等功率的曲线(如介绍所述)从它们之间淡入淡出。下面的示例使用了这一策略,演示的背景音乐在魔兽争霸2的主题上逐渐增强:


完整源代码

缺少的环节:Web AudioAudio标签

现在许多游戏开发商为背景音乐使用<audio>标签,因为它非常适合流媒体内容。现在你可以通过<audio>标签把内容带入网络音频的上下文。

<audio>标签支持流媒体相当有用,因为它可以让你立即播放背景音乐,而无须等待下载所有内容。在网络音频API支持音频流之后,你可以操作或分析它们。下面的例子为通过<audio>标签播放的音乐使用了一个低通滤波器:

关于<audio>标签和网络音频API整合更多的讨论,可以看看这篇短文

音效

游戏经常在响应用户输入或者游戏状态改变时播放声音效果。但是像背景音乐一样,音效可以很快的让用户厌倦。为了避免这种情况,最好有一个音效池放置相似但是不同的音效。这可以从轻微变化到急剧变化间通过固定长度来过渡,像魔兽系列里点击各单位的时候。

游戏音效的另外一个关键点是可以同时有多个。想象一下,你与多个演员拍摄枪战时。每个机枪每秒触发多次,造成几十个音效同时播放。从多个源同时播放音效,还要对音效源精确计时,是网络音频API真正的亮点。

下面的例子演示了由多个单独子弹样本组成的机枪,其创建了多个播放时间错开的声源。

下面是这个代码的效果:


如果你觉得声音太响了,我感到抱歉。我们将在后面的章节讨论测量和动态压缩。

现在,如果你游戏里所有的机枪都像这样响起,那将相当无聊。当然,它们会基于目标的距离和相对位置而有所差异(稍后讨论),但即使这样做可能还不够。幸运的是,网络音频API提供了对上面的示例进行轻松调整的方式,主要有两种:

1.发射子弹时间上微妙的变化

2.改变每个音效的播放速率(同时改变音高),以更好地模拟现实世界中的随机性。

这两种方法的效果如下:


完整源代码

对于这些技术在现实生活中的实际例子,可以看看台球桌的演示,它采用了随机抽样和变化的播放速率来表现更有趣的球的碰撞声。

3D定位音效

游戏往往设定在一个2D或者3D的世界里。在这样的情况下,立体定位的音频可以大大增加沉浸感的体验。幸运的是,网络音频API带来了内置硬件加速的位置音频特性,可以直接的使用。顺便说一下,你应该确保有立体声扬声器(最好是耳机)来运行下面的例子。在下面的示例中,你可以通过在画布上滚动鼠标滚轮来更改声源的角度。


完整源代码

上面的例子中,有一个监听者在画布正中(人的图标),同时鼠标控制声源(喇叭图标)的位置,这是使用AudioPannerNode实现这种效果的简单例子。它的基本思想是通过设置音频信号源的位置响应鼠标的移动,如下所示:

关于网络音频空间化处理需要了解的事情:

  • 监听者默认在原点(000)。
  • 网络音频位置API没有单位,所以我引入了一个乘数使得演示的声效更好。
  • 网络音频采用Y-型直角坐标系(和大多数计算机图形系统相反)。这就是为什么我在上面的代码片段进行了y轴的变换。

高级:音锥

定位模型非常强大,而且相当先进,主要基于OpenAL。详细信息请查看上述规范的第3和第4节。


在有单一的AudioListener连接到网络音频API的情况下,它可以通过位置和方向配置空间。每个源可以通过一个AudioPannerNode(音频声像节点)来使得音频输入空间化。声像节点有位置和方向,以及距离和方向性模型。

距离模型指定的增益取决于和源的接近程度,而方向模型可以通过指定内外锥来配置,以决定监听者在内部锥里,在内外锥之间,或在外部锥之外时增益的大小(通常为负值)。

虽然我的例子在2D空间,但是这种模式很容易推广到三维。例如3D声音空间化的例子可以看看这个位置演示。另外对于位置来说,网络音频模型也可以选择多普勒频移的速度。这个例子展示了多普勒效应的详细信息

关于这一主题的更多信息,可以阅读混合定位音频和WebGL的详细教程

室内效果和滤波器

在现实中,声音被感觉的方式很大程度上取决于声音所在的房间。相同吱吱作响的门在地下室与大型的开放式大厅里相比会发出相当不同的声音。高产值的游戏将会模仿这些影响,因为为每个环境创建一套独立的音效是相当昂贵的,并且会产生相当多的材料和大量的游戏数据。

严格地说,描述原始声音和现实中所听到之间不同的音频术语是脉冲响应。这些脉冲响应可以被精心录制,其实也有网站为了方便你的使用存放了许多这种预先录制的脉冲响应文件(作为音频方式存储)。

对于如何从一个给定的环境创建脉冲响应的更多信息,可以通读网络音频API规范卷积部分的“录音设置”一节。

更重要的是针对我们的目标,网络音频API提供了一个简单的方法来在我们的声音里应用脉冲响应,即通过使用ConvolverNode的方式

下面的示例展示了一些不同脉冲响应下的军事演讲:


完整源代码

还可以看看网络音频API规范页面上的房间效果演示,以及这个让你控制通过一个伟大的爵士标准混合干(原料)和湿(通过卷积处理)的例子

最后的倒计时

现在你已经创建了一个游戏,添加了位置音频,而且现在在你的图里有大量的同时播放的AudioNodes太棒了,但是还有一件事要考虑:

由于多种声音互相叠加起来播放,你可能会发现在某种情况下,声音超过了扬声器的最大承受能力。就像图像超出了画布边界的情况一样,声音也会在波形超过最大阈值时进行削波,导致明显的失真。波形看起来会像下面这样:


这里有一个真实削波的例子。波形看起来相当糟糕:


听起来也很糟糕:


听到像上面这样严重扭曲的音乐是很严重的事,或者与此相反,过分的混合会迫使听众调大音量。如果你现在有这种情况,你真的需要立即解决它!

检测削波

从技术角度看,削波发生在任何一个通道的信号值超出有效范围即-11之间时。一旦检测到削波反生时,视觉反馈会非常有用。要可靠的实现这点,可以把JavaScriptAudioNode放到你的图里。音频图将会按如下进行设置:

同时通过下面的processAudio方法可以检测到削波:

在通常情况下要小心,因为性能方面的原因,不要过度的使用JavaScriptAudioNode在这种情况下,一种替代的方法是为getByteFrequencyData在音频图里加入RealtimeAnalyserNode,在渲染时通过requestAnimationFrame来检测。这个方法更有效,但会错过多数信号(包括有可能削波的地方),因为渲染最多发生60次,而音频信号的变化更为迅速。

因为削波的检测非常重要,未来我们很可能将看到网络音频API节点内置MeterNode

防止削波

通过调整主要AudioGainNode的增益,你可以控制混音的水平来防止削波。然而在实践中,因为你游戏中所播放的声音可能取决于大量因素,所以决定主增益值来防止所有情况下的削波是相当困难的。在通常情况下,你应该调整增益来预期最坏的情况,但这是一门艺术,而不是科学。

要知道这是具体如何实现的,下面是一个示例,在此你可以调整主增益。如果增益设置过高,会导致声音削波。监视器会变成红色来给出削波的视觉反馈。下面的音响生态环境是Disco Dan混音作品,原曲是由Yasunori Mitsuda所做的伟大的“超时空之轮”。


完整源代码

加一点糖

音乐和游戏制作中经常使用效果器来平滑信号和控制尖峰。此功能在网络音频世界里可以通过DynamicsCompressorNode来实现,可以在你的音频图加入一个更响亮,更丰富,更饱满的音色,这也有利于削波。直接引用规范里的话,这个节点

...降低了信号最响亮部分的体积,并提升了最柔软部分的音量...尤其重要的是在游戏和音乐应用里,当大量独立的声音播放时,控制信号整体水平,并有助于避免削波。”

使用动态压缩通常来说是一个好主意,尤其是在游戏的设置里,正如前面所讨论的一样,你并不知道到底此时什么声音将会何时播放。DinahMoe实验室的Plink是很好的例子,因为声音的回放完全取决于你和其他参与者。效果器在大多数情况下是有用的,除了一些罕见的情况外,而这种情况下你可以使用已经精心调整过,并且听起来“恰到好处”的曲目。

它的实现是一件简单的事情,只需要在你的音频图里把DynamicsCompressorNode作为目标前的最后一个节点添加进去。

关于动态压缩的更多细节,Wikipedia上的这篇文章非常翔实。

总结一下,仔细检查削波,通过插入主增益节点来防止它的出现。然后使用动态效果器节点来收紧整个混音。你的音频图可能看起来像这样:


结论

以上内容涵盖了我认为使用网络音频API来开发游戏音乐最重要的方面。有了这些技术,可以在你的浏览器上构建真正有吸引力的音频体验。在我结束本文之前,给你一个提示:如果你的浏览器标签使用page visibility API切换到了后台,一定要让声音暂停,否则你会为用户提供一个潜在的令人厌烦的体验。

对于关于网络音频的其他信息,需要在入门的文章进行更多了解。如果你有问题,看看它是否已经在网络音频FAQ里得到解答。最后,如果你有其他问题,可以在Stack Overflow上的web-audio标签下提问。

在本文结束前,让我为你展示网络音频API现在在实际游戏里的用途:

译自:http://www.html5rocks.com/en/tutorials/webaudio/games/

转载请注明:来自蒋宇捷的博客

分享到:
评论

相关推荐

    基于html5 webaudio api 实现的播放器.zip

    这个"基于html5 webaudio api 实现的播放器.zip"压缩包内容可能包含了一个使用WebAudio API构建的音乐播放器项目的源代码。下面将详细介绍HTML5 WebAudio API及其在多媒体开发中的应用。 一、HTML5 WebAudio API ...

    基于HTML5的audio 音乐播放器.zip

    6. 音频API:HTML5 Audio API允许开发者访问和控制音频的更底层属性,如创建音频缓冲区、处理音频流、添加音效等,这对于实现复杂的音频应用(如游戏音效、音乐编辑工具)非常有用。 综上所述,这个"WiseAudio-...

    Web Audio API 中文文档(官方pdf)

    这个API允许开发者创建复杂的音频处理管道,包括混音、效果处理、音效生成等,为网页游戏、音乐应用、教育软件等提供了丰富的音频功能。在本文中,我们将深入探讨Web Audio API的主要概念、核心组件以及如何在实际...

    html5参考手册 api.zip_Html5API

    这款"html5参考手册 api.zip_Html5API"压缩包提供了一份详尽的HTML5 API开发手册,即使在没有互联网连接的情况下也能供开发者参考使用。这份手册以.chm( Compiled HTML Help)格式存储,是一种由微软开发的帮助文件...

    [Web.Audio.API

    这一部分可能会探讨在Web Audio API出现之前,网页上的音频是如何实现的,包括早期的和标签使用,以及HTML5的&lt;audio&gt;元素。 **2. 游戏与交互性(Games and Interactivity)** 这部分内容可能会讨论如何利用Web ...

    HTML5 api 调用示例

    HTML5 API调用示例是现代网页开发中的关键部分,它极大地扩展了Web应用程序的功能,使其可以实现更多原生应用的特性。W3C(万维网联盟)是定义HTML5标准的权威组织,它的API规范为开发者提供了丰富的工具集,以创建...

    html5 audiojs控制音乐播放器开关声音_网页音乐播放器

    AudioJS是一个基于HTML5 Audio API的JavaScript库,旨在帮助开发者更方便地控制网页中的音乐播放器,包括开关声音、播放、暂停等操作。在这个主题中,我们将深入探讨HTML5的Audio元素以及AudioJS库在实现网页音乐...

    html5 audiojs网页音乐播放器-控制音乐开关声音和获取文件名

    HTML5的Audio API是现代网页开发中用于处理音频内容的核心技术。audio.js是一个JavaScript库,它扩展了HTML5 Audio的功能,使得在网页上播放、控制音频变得更加简单和灵活。在这个项目中,我们将深入探讨如何使用...

    html5 audio demo

    这个“html5 audio demo”是一个示例,展示了如何使用HTML5的`&lt;audio&gt;`标签来创建自定义样式的音频播放器,并实现播放控制功能。 一、HTML5 `&lt;audio&gt;` 标签 `&lt;audio&gt;`标签是HTML5引入的新元素,用于在网页上嵌入...

    html5_API文档

    HTML5 API文档是Web开发领域中的重要参考资料,它详尽地介绍了HTML5中引入的各种新的API接口和技术标准,旨在帮助开发者充分利用这些功能来构建更强大、更具交互性的网页应用。HTML5 API的出现极大地扩展了网页开发...

    HTML5 Audio制作的录音机

    HTML5 Audio是Web开发中的一个重要组成部分,它使得在网页中集成音频播放和录制功能成为可能,无需依赖外部插件如Flash。本项目“HTML5 Audio制作的录音机”旨在创建一个用户友好的在线录音工具,它能够直接在浏览器...

    html5中文api

    通过这个中文版的HTML5 API开发手册,开发者可以深入理解这些特性和API的使用方法,从而更好地利用HTML5来构建现代、高性能的网页应用。CHM格式的文档通常包含索引、搜索和书签功能,便于快速查找和学习所需信息。...

    html5开发的塔防游戏.zip_HTML5 塔防 游戏_HTML5游戏_solution4ht

    这个"html5开发的塔防游戏.zip"资源提供了一个基于HTML5构建的塔防游戏的完整解决方案,名为"HTML5 塔防 游戏_HTML5游戏_solution4ht"。塔防游戏是一种策略类游戏,玩家通过在地图上建立防御塔来抵御一波波敌人的...

    html5 audio demo【修复拖动进度条bug】

    HTML5的Audio API是Web开发中的一个重要组成部分,它允许开发者在网页中集成音频播放功能,提供了丰富的交互性和自定义可能性。在这个"html5 audio demo【修复拖动进度条bug】"中,我们可以深入探讨以下几个关键知识...

    jquery html5 api

    例如,开发一个音乐播放器应用,可以使用HTML5的Audio API处理音频播放,同时利用jQuery来控制界面的响应,如进度条的更新、播放按钮的切换状态等。 总的来说,jQuery和HTML5 API的融合为Web开发带来了无限可能。...

    html5+canvas+audio开发仙剑记忆翻牌小游戏

    在这个“html5+canvas+audio开发仙剑记忆翻牌小游戏”中,开发者利用Canvas API实现了游戏的图形渲染部分,而audio标签则用于处理游戏的音效和背景音乐。 Canvas API是一个强大的绘图工具,它允许开发者通过...

    HTML5小游戏源代码大全(300M)

    4. **使用框架的游戏**:许多HTML5游戏使用了库或框架,如Phaser、Three.js或CreateJS,这些工具简化了游戏开发,提供了预置的动画、物理引擎等功能。 5. **基于Web Storage的游戏**:HTML5的Web Storage(包括...

    html5音频游戏

    HTML5音频游戏是一种基于Web技术开发的游戏,利用HTML5的新特性,尤其是其音频处理和多媒体支持,为玩家提供丰富的互动体验。HTML5是超文本标记语言的第五个主要版本,它在2014年被正式标准化,为网页开发者带来了...

    cocos2d-html5 API

    总之,Cocos2d-html5为HTML5游戏开发提供了丰富的工具和资源,其API覆盖了游戏开发的各个方面,从基本的游戏对象到复杂的动画和物理模拟,让开发者能够轻松创建高质量的2D游戏。通过深入理解和实践这些API,开发者...

    HTML5_Audio_Visualizer:使用HTML5 Audio API构建的音频频谱可视化器

    HTML5 Audio API是现代网页开发中的一个重要组成部分,它允许开发者在浏览器环境中处理音频内容。API提供了丰富的功能,包括播放、暂停、控制音量、读取音频数据等。在音频可视化器中,关键的API接口如`AudioContext...

Global site tag (gtag.js) - Google Analytics