-
Notifications
You must be signed in to change notification settings - Fork 513
AudioEmitter
DirectXTK | Audio |
---|
AudioEmitter is a helper object derived from X3DAUDIO_EMITTER that can be used with the Apply3D method of SoundEffectInstance, SoundStreamInstance, and DynamicSoundEffectInstance.
See AudioListener.
Related tutorial: Using positional audio
#include <Audio.h>
The default constructor creates a point omnidirectional emitter located at 0,0,0 facing -z
and an up vector of +y
for a mono source.
CurveDistanceScaler and DopplerScaler are set to 1 by default. InnerRadius is set to 0, and InnerRadiusAngle is set to X3DAUDIO_PI/4.0
(45 degrees).
When using left-handed coordinates, be sure to set
OrientFront
In addition to setting the members of X3DAUDIO_EMITTER
directly, these helper functions are provided:
-
SetPosition (XMVECTOR) or (XMFLOAT3): Sets the Position of the emitter.
-
SetVelocity (XMVECTOR) or (XMFLOAT3): Sets the Velocity of the emitter.
-
SetOrientation (XMVECTOR forward, XMVECTOR up) or (XMFLOAT3 forward, XMFLOAT3 up)
-
SetOrientationFromQuaternion (XMVECTOR): Sets the OrientFront/OrientTop of the emitter.
-
Update (XMVECTOR newPos, XMVECTOR upDir, float dt): Computes a direction and velocity for the emitter based on the existing Position and the newPos, updating the OrientFront/OrientTop to match, and then setting the Position to the newPos. If dt is 0, the update is skipped.
You must use a distinct instance of
AudioEmitter
for each active 3D sound if using the Update method. Otherwise, if you reuse the emitter instance for multiple sounds you need to explicitly initialize both the position and velocity before eachApply3D
call.
X3DAudio supports multi-channel sound sources for 3D audio (i.e. stereo, quad, etc.). The default constructor for AudioEmitter sets the source up for mono (i.e. single-channel), so to use multi-channel sources, you should set the ChannelCount member to match the number of channels in your source, and adjust ChannelRadius and the EmitterAzimuths array as desired.
std::unique_ptr<SoundEffect> soundEffect;
AudioEmitter emitter;
soundEffect = std::make_unique<SoundEffect>( audEngine.get(), L"sound.wav" );
emitter.SetPosition(x, y, z);
emitter.ChannelCount = soundEffect->GetFormat()->nChannels;
You can also set the channel count from the sound instance:
effect = soundEffect->CreateInstance(SoundEffectInstance_Use3D);
emitter.SetPosition(x, y, z);
emitter.ChannelCount = effect->GetChannelCount();
For multi-channel emitters, OrientTop
must be valid.
AudioEmitter includes an EmitterAzimuths array which is pointed to by pChannelAzimuths and defaults to all 0. This is because pChannelAzimuths cannot be a nullptr for multi-channel sound emitters.
The helper EnableDefaultMultiChannel can be used to set up a default set of emitter azimuths based on common speaker configurations for up to 8 channels, and sets the channel radius:
emitter.SetPosition(x, y, z);
emitter.EnableDefaultMultiChannel(effect->GetChannelCount(), 10.f);
AudioEmitter defaults to an omnidirectional emitter. To create a sound-cone, set the pCone member to point to a X3DAUDIO_CONE
structure. The pointer must point to valid memory at the time Apply3D is called.
Be aware that pCone
is ignored for multi-channel emitters.
The AudioEmitter constructor sets pVolumeCurve, pLFECurve, pLPFDirectCurve, pLPFReverbCurve, and pReverbCurve to nullptr which uses XAudio2 default curves. Any custom curve definitions must have a pointer to valid memory at the time Apply3D is called.
GameFest 2010: The (3D) Sound of Success: X3DAudio and Sound Positioning
All content and source code for this package are subject to the terms of the MIT License.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.
- Universal Windows Platform apps
- Windows desktop apps
- Windows 11
- Windows 10
- Windows 8.1
- Xbox One
- x86
- x64
- ARM64
- Visual Studio 2022
- Visual Studio 2019 (16.11)
- clang/LLVM v12 - v18
- MinGW 12.2, 13.2
- CMake 3.20