DirectSound Interfaces
[The feature associated with this page, DirectSound, is a legacy feature. It has been superseded by XAudio2 and Audio Graphs. These newer frameworks have been optimized for Windows 10 and Windows 11. Microsoft strongly recommends that new code use XAudio2 and Audio Graphs instead of DirectSound, when possible. Microsoft suggests that existing code that uses the legacy APIs be rewritten to use the new APIs if possible.]
This section contains reference information about interfaces provided by the Microsoft DirectSound API.
Function | Description |
---|---|
IDirectSound8 | Used to create buffer objects and set up the environment. |
IDirectSound3DBuffer8 | Used to retrieve and set parameters that describe the position, orientation, and environment of a sound buffer in 3-D space. |
IDirectSound3DListener8 | Used to retrieve and set parameters that describe a listener's position, orientation, and listening environment in 3-D space. |
IDirectSoundBuffer8 | Used to manage sound buffers. |
IDirectSoundCapture8 | Used to create sound capture buffers. |
IDirectSoundCaptureBuffer8 | Used to manipulate sound capture buffers. |
IDirectSoundCaptureFXAec8 | Used to set and retrieve parameters on a capture buffer that supports acoustic echo cancellation. |
IDirectSoundCaptureFXNoiseSuppress8 | Used to set and retrieve parameters on a capture buffer that supports noise suppression. |
IDirectSoundFullDuplex8 | Represents a full-duplex stream. |
IDirectSoundFXChorus8 | Used to set and retrieve effect parameters on a buffer that supports chorus. |
IDirectSoundFXCompressor8 | Used to set and retrieve effect parameters on a buffer that supports compression. |
IDirectSoundFXDistortion8 | Used to set and retrieve effect parameters on a buffer that supports distortion. |
IDirectSoundFXEcho8 | Used to set and retrieve effect parameters on a buffer that supports echo. |
IDirectSoundFXFlanger8 | Used to set and retrieve effect parameters on a buffer that supports flange. |
IDirectSoundFXGargle8 | Used to set and retrieve effect parameters on a buffer that supports amplitude modulation. |
IDirectSoundFXI3DL2Reverb8 | Used to set and retrieve effect parameters on a buffer that supports I3DL2 (Interactive 3D Audio Level 2) reverberation effects. |
IDirectSoundFXParamEq8 | Used to set and retrieve effect parameters on a buffer that supports parametric equalizer effects. |
IDirectSoundFXWavesReverb8 | Used to set and retrieve effect parameters on a buffer that supports Waves reverberation effects. |
IDirectSoundNotify8 | Sets up notification events for a playback or capture buffer. |
IKsPropertySet | Enables drivers to provide extended capabilities that can be used without API extensions. |
For DirectX 8.0 and later, only IDirectSound8, IDirectSoundBuffer8, and IDirectSoundCaptureBuffer8 are new interfaces that supersede interfaces with similar, unnumbered names. Other interface names ending in 8 are simple defines for unchanged or new unnumbered interfaces. For example, IDirectSoundCapture8 is exactly equivalent to IDirectSoundCapture.
All interfaces that have a defined name ending in 8 are documented under that defined name, and it is recommended that you always use this name in your code.
For information on which methods are supported by an earlier version of an interface, see the declaration of the interface in Dsound.h.
When a method takes an interface pointer as an in parameter, you can pass in the newer version even where the parameter type is declared as the earlier version. For example, a pointer to either IDirectSoundBuffer or IDirectSoundBuffer8 can be passed to IDirectSound8::DuplicateSoundBuffer as the pDSBufferOriginal parameter.
When a method returns an interface, however, it is usually the earlier interface, and to obtain the newer interface you must use QueryInterface. This is the case, for example, with the ppDSBuffer parameter of IDirectSound8::CreateSoundBuffer.