Partilhar via


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