SoundBank.PlayCue Method (String, AudioListener, AudioEmitter)
Plays a cue using 3D positional information specified in an AudioListener and AudioEmitter.
Namespace: Microsoft.Xna.Framework.Audio
Assembly: Microsoft.Xna.Framework (in microsoft.xna.framework.dll)
Syntax
public void PlayCue (
string name,
AudioListener listener,
AudioEmitter emitter
)
Parameters
- name
Name of the cue to play. - listener
AudioListener that specifies listener 3D audio information. - emitter
AudioEmitter that specifies emitter 3D audio information.
Exceptions
Exception type | Condition |
---|---|
ArgumentNullException | The name parameter is null. |
InvalidOperationException | The name parameter specifies a cue that does not exist. |
Remarks
The 3D audio information in the specified listener and emitter is used to initialize the cue instance and apply a static positional 3D audio effect (the direction from which the player hears the sound). Position and velocity are not updated over time; the 3D audio effects are calculated based on the emitter and listener position at the time of the call. Typically, this is used for short-lived sounds, or when the object and listener are stationary for the duration of the sound but placed somewhere in the world space.
For example, a sound that is played off to the right will continue to sound as if it is coming from the right, even if the listener moves or turns. For very short sounds, this may be imperceptable and thus acceptable. As another example, a voice that comes from the player's vehicle will always be the same distance and direction relative to the player, so static positioning in this case would be correct.
Attenuation and doppler effects, if enabled, will also be static for the duration of the sound.
To enable dynamic 3D audio when the emitter or listener are moving, use GetCue and Apply3D instead.
Each Cue instance that you play is unique, even when playing multiple cues with the same name. This allows multiple instances of the same Cue to play simultaneously.
Calling this method does not return a Cue object. Therefore, once the cue has started playing, it cannot be controlled through any methods of Cue, such as Stop, Pause, or Resume. The cue will play until its authored end, at which point it will be released.
Because no Cue object is retrieved, cues played using this method are also unable to use Apply3D to apply dynamic 3D effects to the cue. To retrieve a cue that you can control during playback, or apply dynamic 3D effects to, use GetCue.
For more information about 3D audio, see How To: Apply Basic 3D Positional Effects to a Cue and How To: Apply Attenuation and Doppler 3D Audio Effects.
See Also
Concepts
Audio Overview
Tutorial 3: Making Sounds with XNA Game Studio
Tasks
How To: Play a Sound
How To: Stop or Pause a Sound
How To: Apply Basic 3D Positional Effects to a Cue
How To: Apply Attenuation and Doppler 3D Audio Effects
Reference
SoundBank.PlayCue Method
SoundBank Class
SoundBank Members
Microsoft.Xna.Framework.Audio Namespace
Platforms
Xbox 360, Windows XP SP2, Windows Vista