2023-01-12 20:49:14 +01:00
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Audio streams
|
|
|
|
=============
|
|
|
|
|
|
|
|
Introduction
|
|
|
|
------------
|
|
|
|
|
2023-01-12 19:29:11 +01:00
|
|
|
As you might have already read in `doc_audio_buses`, sound is sent to
|
2022-03-18 17:46:08 +01:00
|
|
|
each bus via an AudioStreamPlayer node. There are different kinds
|
|
|
|
of AudioStreamPlayers. Each one loads an AudioStream and plays it back.
|
|
|
|
|
|
|
|
AudioStream
|
|
|
|
-----------
|
|
|
|
|
|
|
|
An audio stream is an abstract object that emits sound. The sound can come from
|
|
|
|
many places, but is most commonly loaded from the filesystem. Audio files can be
|
|
|
|
loaded as AudioStreams and placed inside an AudioStreamPlayer. You can find
|
2023-01-12 19:29:11 +01:00
|
|
|
information on supported formats and differences in `doc_importing_audio_samples`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
There are other types of AudioStreams, such as AudioStreamRandomPitch.
|
|
|
|
This one makes a random adjustment to the sound's pitch every time it's
|
|
|
|
played back. This can be helpful for adding variation to sounds that are
|
|
|
|
played back often.
|
|
|
|
|
|
|
|
AudioStreamPlayer
|
|
|
|
-----------------
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
data:image/s3,"s3://crabby-images/4d213/4d213f2729600caa2b701a52bb649ae8489d7e76" alt=""
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
This is the standard, non-positional stream player. It can play to any bus.
|
|
|
|
In 5.1 sound setups, it can send audio to stereo mix or front speakers.
|
|
|
|
|
|
|
|
AudioStreamPlayer2D
|
|
|
|
-------------------
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
data:image/s3,"s3://crabby-images/e43cc/e43cc9bcbb715e959148901951bf56d01955d4ca" alt=""
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
This is a variant of AudioStreamPlayer, but emits sound in a 2D positional
|
|
|
|
environment. When close to the left of the screen, the panning will go left.
|
|
|
|
When close to the right side, it will go right.
|
|
|
|
|
2023-01-12 20:55:57 +01:00
|
|
|
Note:
|
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Area2Ds can be used to divert sound from any AudioStreamPlayer2Ds they
|
|
|
|
contain to specific buses. This makes it possible to create buses with
|
|
|
|
different reverb or sound qualities to handle action happening in a
|
|
|
|
particular parts of your game world.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
data:image/s3,"s3://crabby-images/ec2bf/ec2bf92cdeac2b63b5690365b0bf06d0d9a8f44b" alt=""
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
AudioStreamPlayer3D
|
|
|
|
-------------------
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
data:image/s3,"s3://crabby-images/fb178/fb17888195165da8fd4e8b12f907244630fd5443" alt=""
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
This is a variant of AudioStreamPlayer, but emits sound in a 3D positional
|
|
|
|
environment. Depending on the location of the player relative to the screen,
|
|
|
|
it can position sound in stereo, 5.1 or 7.1 depending on the chosen audio setup.
|
|
|
|
|
|
|
|
Similar to AudioStreamPlayer2D, an Area can divert the sound to an audio bus.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
data:image/s3,"s3://crabby-images/9d2bc/9d2bc983a8828451a75233ab258e1c34d8da26bd" alt=""
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Unlike for 2D, the 3D version of AudioStreamPlayer has a few more advanced options:
|
|
|
|
|
2023-01-12 20:49:14 +01:00
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Reverb buses
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Godot allows for 3D audio streams that enter a specific Area node to send dry
|
|
|
|
and wet audio to separate buses. This is useful when you have several reverb
|
|
|
|
configurations for different types of rooms. This is done by enabling this type
|
|
|
|
of reverb in the **Reverb Bus** section of the Area's properties:
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
data:image/s3,"s3://crabby-images/f5903/f59033b3618484d93590cabe3fc6313a7e433c65" alt=""
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
At the same time, a special bus layout is created where each area receives the
|
|
|
|
reverb info from each area. A Reverb effect needs to be created and configured
|
|
|
|
in each reverb bus to complete the setup for the desired effect:
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
data:image/s3,"s3://crabby-images/f1ae4/f1ae47204462a85c9af63e2f5cd4bc9b82694b59" alt=""
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
The Area's **Reverb Bus** section also has a parameter named **Uniformity**.
|
|
|
|
Some types of rooms bounce sounds more than others (like a warehouse), so
|
|
|
|
reverberation can be heard almost uniformly across the room even though the
|
|
|
|
source may be far away. Playing around with this parameter can simulate
|
|
|
|
that effect.
|
|
|
|
|
|
|
|
Doppler
|
|
|
|
~~~~~~~
|
|
|
|
|
|
|
|
When the relative velocity between an emitter and listener changes, this is
|
|
|
|
perceived as an increase or decrease in the pitch of the emitted sound.
|
|
|
|
Godot can track velocity changes in the AudioStreamPlayer3D and Camera nodes.
|
|
|
|
Both nodes have this property, which must be enabled manually:
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
data:image/s3,"s3://crabby-images/36ad7/36ad7e174bdbe0f9fc221197fc235678e37a61dd" alt=""
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Enable it by setting it depending on how objects will be moved:
|
2023-01-12 20:57:31 +01:00
|
|
|
use **Idle** for objects moved using `process`, or **Physics**
|
|
|
|
for objects moved using `physics_process`. The tracking will
|
2022-03-18 17:46:08 +01:00
|
|
|
happen automatically.
|