-
Notifications
You must be signed in to change notification settings - Fork 512
Making use of wave banks
This lesson covers the basics of playing sounds with DirectX Tool Kit for Audio using of XACT-style wave banks.
First create a new project using the instructions from these four lessons to enable the audio engine for DirectX Tool Kit for Audio: The basic game loop, Adding the DirectX Tool Kit, Adding the DirectX Tool Kit for Audio, and Adding audio to your project. We'll be using the result of that process for this lesson.
In the previous tutorial we loaded the individual sound files as distinct SoundEffect objects, but games commonly have hundreds or thousands of distinct sounds, music, and voice recordings. A more efficient way to manage this data is to make of a 'wave bank' which is a single file that contains a collection of .wav
files that can be loaded all at once.
DirectX Tool Kit for Audio supports "wave banks" which were created for the Cross-platform Audio Creation Tool (XACT) from the legacy DirectX SDK. It makes no use of "sound banks" or "cues".
- Download the XWBTool.exe from the DirectX Tool Kit site and extract the EXE into your project's folder.
- Open a command-prompt and then change to your project's folder.
Run the following command-line
XWBTool -f -o sounds.xwb Explo1.wav Explo2.wav Explo3.wav Explo4.wav NightAmbienceSimple_02.wav
Then from the top menu in Visual Studio select Project / Add Existing Item.... Select sounds.xwb and click "OK".
If you are using a Universal Windows Platform app or Xbox One project rather than a Windows desktop app, you need to manually edit the Visual Studio project properties on the sounds.xwb
file and make sure "Content" is set to "Yes" so the data file will be included in your packaged build.
The
xactbld
tool from the legacy DirectX SDK can also create the samexwb
files.
In the Game.h file, add the following variables to the bottom of the Game class's private declarations:
std::unique_ptr<DirectX::WaveBank> m_sounds;
In Game.cpp, modify Initialize:
...
m_sounds = std::make_unique<WaveBank>( m_audEngine.get(), L"sounds.xwb" );
m_nightLoop = m_sounds->CreateInstance( "NightAmbienceSimple_02" );
if ( m_nightLoop )
m_nightLoop->Play(true);
...
In Game.cpp, modify Update as follows:
...
explodeDelay -= elapsedTime;
if (explodeDelay < 0.f)
{
std::uniform_int_distribution<unsigned int> dist2(0, 3);
m_sounds->Play( dist2(*m_random) );
std::uniform_real_distribution<float> dist(1.f, 10.f);
explodeDelay = dist(*m_random);
}
...
Build and run. This time the sounds are being played from the wave bank, and the explosion now selects from 4 different exploding sounds at random to provide some variation.
Once again,
WaveBank
must remain in memory as the audio data is played directly from that object.
Troubleshooting: If you get a runtime exception, then you may have the
sounds.xwb
file in the wrong folder, have modified the "Working Directory" in the "Debugging" configuration settings, or otherwise changed the expected paths at runtime of the application. You should set a break-point onstd::make_unique<WaveBank>
line and step into the code to find the exact problem.
To make use of wavebanks a bit more robust, calls to CreateInstance
for 'missing sounds' can return nullptr rather than throwing an exception. This is why we guard the use of m_nightLoop
elsewhere. This lets your audio developer mess around with the content of the wave banks without necessarily causing the game to crash.
Wavebank entries can be referenced by a 0-based index or by an optional friendly name if present in the wave bank--this is why we used -f
in our command-line to xwbtool above to have it include friendly names. You can also have xwbtool generate a C header with an enumeration for the indices by using -h
.
XWBTool -f -o sounds.xwb -h sounds.h Explo1.wav Explo2.wav Explo3.wav Explo4.wav NightAmbienceSimple_02.wav
which would generate a sounds.h
file you could use instead of having 'magic' numbers in your code:
#pragma once
enum XACT_WAVEBANK_SOUNDS
{
XACT_WAVEBANK_SOUNDS_EXPLO1 = 0,
XACT_WAVEBANK_SOUNDS_EXPLO2 = 1,
XACT_WAVEBANK_SOUNDS_EXPLO3 = 2,
XACT_WAVEBANK_SOUNDS_EXPLO4 = 3,
XACT_WAVEBANK_SOUNDS_NIGHTAMBIENCESIMPLE_02 = 4,
};
#define XACT_WAVEBANK_SOUNDS_ENTRY_COUNT 5
UNDER CONSTRUCTION
Next lesson: Using positional audio
DirectX Tool Kit docs SoundEffectInstance, SoundStreamInstance, WaveBank
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