:github_url: hide .. DO NOT EDIT THIS FILE!!! .. Generated automatically from Godot engine sources. .. Generator: https://github.com/godotengine/godot/tree/3.6/doc/tools/make_rst.py. .. XML source: https://github.com/godotengine/godot/tree/3.6/doc/classes/AudioStreamPlayer3D.xml. .. _class_AudioStreamPlayer3D: AudioStreamPlayer3D =================== **Inherits:** :ref:`Spatial` **<** :ref:`Node` **<** :ref:`Object` Plays positional sound in 3D space. .. rst-class:: classref-introduction-group Description ----------- Plays a sound effect with directed sound effects, dampens with distance if needed, generates effect of hearable position in space. For greater realism, a low-pass filter is automatically applied to distant sounds. This can be disabled by setting :ref:`attenuation_filter_cutoff_hz` to ``20500``. By default, audio is heard from the camera position. This can be changed by adding a :ref:`Listener` node to the scene and enabling it by calling :ref:`Listener.make_current` on it. See also :ref:`AudioStreamPlayer` to play a sound non-positionally. \ **Note:** Hiding an **AudioStreamPlayer3D** node does not disable its audio output. To temporarily disable an **AudioStreamPlayer3D**'s audio output, set :ref:`unit_db` to a very low value like ``-100`` (which isn't audible to human hearing). .. rst-class:: classref-introduction-group Tutorials --------- - :doc:`../tutorials/audio/audio_streams` .. rst-class:: classref-reftable-group Properties ---------- .. table:: :widths: auto +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`int` | :ref:`area_mask` | ``1`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`float` | :ref:`attenuation_filter_cutoff_hz` | ``5000.0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`float` | :ref:`attenuation_filter_db` | ``-24.0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`AttenuationModel` | :ref:`attenuation_model` | ``0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`bool` | :ref:`autoplay` | ``false`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`String` | :ref:`bus` | ``"Master"`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`DopplerTracking` | :ref:`doppler_tracking` | ``0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`float` | :ref:`emission_angle_degrees` | ``45.0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`bool` | :ref:`emission_angle_enabled` | ``false`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`float` | :ref:`emission_angle_filter_attenuation_db` | ``-12.0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`float` | :ref:`max_db` | ``3.0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`float` | :ref:`max_distance` | ``0.0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`OutOfRangeMode` | :ref:`out_of_range_mode` | ``0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`float` | :ref:`panning_strength` | ``1.0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`float` | :ref:`pitch_scale` | ``1.0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`bool` | :ref:`playing` | ``false`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`AudioStream` | :ref:`stream` | | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`bool` | :ref:`stream_paused` | ``false`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`float` | :ref:`unit_db` | ``0.0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ | :ref:`float` | :ref:`unit_size` | ``1.0`` | +--------------------------------------------------------------------+----------------------------------------------------------------------------------------------------------------------+--------------+ .. rst-class:: classref-reftable-group Methods ------- .. table:: :widths: auto +-------------------------------------------------------+------------------------------------------------------------------------------------------------------------+ | :ref:`float` | :ref:`get_playback_position` **(** **)** | +-------------------------------------------------------+------------------------------------------------------------------------------------------------------------+ | :ref:`AudioStreamPlayback` | :ref:`get_stream_playback` **(** **)** | +-------------------------------------------------------+------------------------------------------------------------------------------------------------------------+ | void | :ref:`play` **(** :ref:`float` from_position=0.0 **)** | +-------------------------------------------------------+------------------------------------------------------------------------------------------------------------+ | void | :ref:`seek` **(** :ref:`float` to_position **)** | +-------------------------------------------------------+------------------------------------------------------------------------------------------------------------+ | void | :ref:`stop` **(** **)** | +-------------------------------------------------------+------------------------------------------------------------------------------------------------------------+ .. rst-class:: classref-section-separator ---- .. rst-class:: classref-descriptions-group Signals ------- .. _class_AudioStreamPlayer3D_signal_finished: .. rst-class:: classref-signal **finished** **(** **)** Emitted when the audio stops playing. .. rst-class:: classref-section-separator ---- .. rst-class:: classref-descriptions-group Enumerations ------------ .. _enum_AudioStreamPlayer3D_AttenuationModel: .. rst-class:: classref-enumeration enum **AttenuationModel**: .. _class_AudioStreamPlayer3D_constant_ATTENUATION_INVERSE_DISTANCE: .. rst-class:: classref-enumeration-constant :ref:`AttenuationModel` **ATTENUATION_INVERSE_DISTANCE** = ``0`` Linear dampening of loudness according to distance. .. _class_AudioStreamPlayer3D_constant_ATTENUATION_INVERSE_SQUARE_DISTANCE: .. rst-class:: classref-enumeration-constant :ref:`AttenuationModel` **ATTENUATION_INVERSE_SQUARE_DISTANCE** = ``1`` Squared dampening of loudness according to distance. .. _class_AudioStreamPlayer3D_constant_ATTENUATION_LOGARITHMIC: .. rst-class:: classref-enumeration-constant :ref:`AttenuationModel` **ATTENUATION_LOGARITHMIC** = ``2`` Logarithmic dampening of loudness according to distance. .. _class_AudioStreamPlayer3D_constant_ATTENUATION_DISABLED: .. rst-class:: classref-enumeration-constant :ref:`AttenuationModel` **ATTENUATION_DISABLED** = ``3`` No dampening of loudness according to distance. The sound will still be heard positionally, unlike an :ref:`AudioStreamPlayer`. :ref:`ATTENUATION_DISABLED` can be combined with a :ref:`max_distance` value greater than ``0.0`` to achieve linear attenuation clamped to a sphere of a defined size. .. rst-class:: classref-item-separator ---- .. _enum_AudioStreamPlayer3D_OutOfRangeMode: .. rst-class:: classref-enumeration enum **OutOfRangeMode**: .. _class_AudioStreamPlayer3D_constant_OUT_OF_RANGE_MIX: .. rst-class:: classref-enumeration-constant :ref:`OutOfRangeMode` **OUT_OF_RANGE_MIX** = ``0`` Mix this audio in, even when it's out of range. This increases CPU usage, but keeps the sound playing at the correct position if the camera leaves and enters the **AudioStreamPlayer3D**'s :ref:`max_distance` radius. .. _class_AudioStreamPlayer3D_constant_OUT_OF_RANGE_PAUSE: .. rst-class:: classref-enumeration-constant :ref:`OutOfRangeMode` **OUT_OF_RANGE_PAUSE** = ``1`` Pause this audio when it gets out of range. This decreases CPU usage, but will cause the sound to restart if the camera leaves and enters the **AudioStreamPlayer3D**'s :ref:`max_distance` radius. .. rst-class:: classref-item-separator ---- .. _enum_AudioStreamPlayer3D_DopplerTracking: .. rst-class:: classref-enumeration enum **DopplerTracking**: .. _class_AudioStreamPlayer3D_constant_DOPPLER_TRACKING_DISABLED: .. rst-class:: classref-enumeration-constant :ref:`DopplerTracking` **DOPPLER_TRACKING_DISABLED** = ``0`` Disables doppler tracking. .. _class_AudioStreamPlayer3D_constant_DOPPLER_TRACKING_IDLE_STEP: .. rst-class:: classref-enumeration-constant :ref:`DopplerTracking` **DOPPLER_TRACKING_IDLE_STEP** = ``1`` Executes doppler tracking in idle step (every rendered frame). .. _class_AudioStreamPlayer3D_constant_DOPPLER_TRACKING_PHYSICS_STEP: .. rst-class:: classref-enumeration-constant :ref:`DopplerTracking` **DOPPLER_TRACKING_PHYSICS_STEP** = ``2`` Executes doppler tracking in physics step (every simulated physics frame). .. rst-class:: classref-section-separator ---- .. rst-class:: classref-descriptions-group Property Descriptions --------------------- .. _class_AudioStreamPlayer3D_property_area_mask: .. rst-class:: classref-property :ref:`int` **area_mask** = ``1`` .. rst-class:: classref-property-setget - void **set_area_mask** **(** :ref:`int` value **)** - :ref:`int` **get_area_mask** **(** **)** Determines which :ref:`Area` layers affect the sound for reverb and audio bus effects. Areas can be used to redirect :ref:`AudioStream`\ s so that they play in a certain audio bus. An example of how you might use this is making a "water" area so that sounds played in the water are redirected through an audio bus to make them sound like they are being played underwater. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_attenuation_filter_cutoff_hz: .. rst-class:: classref-property :ref:`float` **attenuation_filter_cutoff_hz** = ``5000.0`` .. rst-class:: classref-property-setget - void **set_attenuation_filter_cutoff_hz** **(** :ref:`float` value **)** - :ref:`float` **get_attenuation_filter_cutoff_hz** **(** **)** Dampens audio using a low-pass filter above this frequency, in Hz. To disable the dampening effect entirely, set this to ``20500`` as this frequency is above the human hearing limit. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_attenuation_filter_db: .. rst-class:: classref-property :ref:`float` **attenuation_filter_db** = ``-24.0`` .. rst-class:: classref-property-setget - void **set_attenuation_filter_db** **(** :ref:`float` value **)** - :ref:`float` **get_attenuation_filter_db** **(** **)** Amount how much the filter affects the loudness, in decibels. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_attenuation_model: .. rst-class:: classref-property :ref:`AttenuationModel` **attenuation_model** = ``0`` .. rst-class:: classref-property-setget - void **set_attenuation_model** **(** :ref:`AttenuationModel` value **)** - :ref:`AttenuationModel` **get_attenuation_model** **(** **)** Decides if audio should get quieter with distance linearly, quadratically, logarithmically, or not be affected by distance, effectively disabling attenuation. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_autoplay: .. rst-class:: classref-property :ref:`bool` **autoplay** = ``false`` .. rst-class:: classref-property-setget - void **set_autoplay** **(** :ref:`bool` value **)** - :ref:`bool` **is_autoplay_enabled** **(** **)** If ``true``, audio plays when the AudioStreamPlayer3D node is added to scene tree. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_bus: .. rst-class:: classref-property :ref:`String` **bus** = ``"Master"`` .. rst-class:: classref-property-setget - void **set_bus** **(** :ref:`String` value **)** - :ref:`String` **get_bus** **(** **)** The bus on which this audio is playing. \ **Note:** When setting this property, keep in mind that no validation is performed to see if the given name matches an existing bus. This is because audio bus layouts might be loaded after this property is set. If this given name can't be resolved at runtime, it will fall back to ``"Master"``. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_doppler_tracking: .. rst-class:: classref-property :ref:`DopplerTracking` **doppler_tracking** = ``0`` .. rst-class:: classref-property-setget - void **set_doppler_tracking** **(** :ref:`DopplerTracking` value **)** - :ref:`DopplerTracking` **get_doppler_tracking** **(** **)** Decides in which step the `Doppler effect `__ should be calculated. \ **Note:** Only effective if the current :ref:`Camera`'s :ref:`Camera.doppler_tracking` property is set to a value other than :ref:`Camera.DOPPLER_TRACKING_DISABLED`. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_emission_angle_degrees: .. rst-class:: classref-property :ref:`float` **emission_angle_degrees** = ``45.0`` .. rst-class:: classref-property-setget - void **set_emission_angle** **(** :ref:`float` value **)** - :ref:`float` **get_emission_angle** **(** **)** The angle in which the audio reaches cameras undampened. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_emission_angle_enabled: .. rst-class:: classref-property :ref:`bool` **emission_angle_enabled** = ``false`` .. rst-class:: classref-property-setget - void **set_emission_angle_enabled** **(** :ref:`bool` value **)** - :ref:`bool` **is_emission_angle_enabled** **(** **)** If ``true``, the audio should be dampened according to the direction of the sound. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_emission_angle_filter_attenuation_db: .. rst-class:: classref-property :ref:`float` **emission_angle_filter_attenuation_db** = ``-12.0`` .. rst-class:: classref-property-setget - void **set_emission_angle_filter_attenuation_db** **(** :ref:`float` value **)** - :ref:`float` **get_emission_angle_filter_attenuation_db** **(** **)** Dampens audio if camera is outside of :ref:`emission_angle_degrees` and :ref:`emission_angle_enabled` is set by this factor, in decibels. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_max_db: .. rst-class:: classref-property :ref:`float` **max_db** = ``3.0`` .. rst-class:: classref-property-setget - void **set_max_db** **(** :ref:`float` value **)** - :ref:`float` **get_max_db** **(** **)** Sets the absolute maximum of the soundlevel, in decibels. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_max_distance: .. rst-class:: classref-property :ref:`float` **max_distance** = ``0.0`` .. rst-class:: classref-property-setget - void **set_max_distance** **(** :ref:`float` value **)** - :ref:`float` **get_max_distance** **(** **)** Sets the distance from which the :ref:`out_of_range_mode` takes effect. Has no effect if set to 0. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_out_of_range_mode: .. rst-class:: classref-property :ref:`OutOfRangeMode` **out_of_range_mode** = ``0`` .. rst-class:: classref-property-setget - void **set_out_of_range_mode** **(** :ref:`OutOfRangeMode` value **)** - :ref:`OutOfRangeMode` **get_out_of_range_mode** **(** **)** Decides if audio should pause when source is outside of :ref:`max_distance` range. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_panning_strength: .. rst-class:: classref-property :ref:`float` **panning_strength** = ``1.0`` .. rst-class:: classref-property-setget - void **set_panning_strength** **(** :ref:`float` value **)** - :ref:`float` **get_panning_strength** **(** **)** Scales the panning strength for this node by multiplying the base :ref:`ProjectSettings.audio/3d_panning_strength` with this factor. Higher values will pan audio from left to right more dramatically than lower values. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_pitch_scale: .. rst-class:: classref-property :ref:`float` **pitch_scale** = ``1.0`` .. rst-class:: classref-property-setget - void **set_pitch_scale** **(** :ref:`float` value **)** - :ref:`float` **get_pitch_scale** **(** **)** The pitch and the tempo of the audio, as a multiplier of the audio sample's sample rate. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_playing: .. rst-class:: classref-property :ref:`bool` **playing** = ``false`` .. rst-class:: classref-property-setget - :ref:`bool` **is_playing** **(** **)** If ``true``, audio is playing. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_stream: .. rst-class:: classref-property :ref:`AudioStream` **stream** .. rst-class:: classref-property-setget - void **set_stream** **(** :ref:`AudioStream` value **)** - :ref:`AudioStream` **get_stream** **(** **)** The :ref:`AudioStream` resource to be played. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_stream_paused: .. rst-class:: classref-property :ref:`bool` **stream_paused** = ``false`` .. rst-class:: classref-property-setget - void **set_stream_paused** **(** :ref:`bool` value **)** - :ref:`bool` **get_stream_paused** **(** **)** If ``true``, the playback is paused. You can resume it by setting :ref:`stream_paused` to ``false``. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_unit_db: .. rst-class:: classref-property :ref:`float` **unit_db** = ``0.0`` .. rst-class:: classref-property-setget - void **set_unit_db** **(** :ref:`float` value **)** - :ref:`float` **get_unit_db** **(** **)** The base sound level unaffected by dampening, in decibels. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_property_unit_size: .. rst-class:: classref-property :ref:`float` **unit_size** = ``1.0`` .. rst-class:: classref-property-setget - void **set_unit_size** **(** :ref:`float` value **)** - :ref:`float` **get_unit_size** **(** **)** The factor for the attenuation effect. Higher values make the sound audible over a larger distance. .. rst-class:: classref-section-separator ---- .. rst-class:: classref-descriptions-group Method Descriptions ------------------- .. _class_AudioStreamPlayer3D_method_get_playback_position: .. rst-class:: classref-method :ref:`float` **get_playback_position** **(** **)** Returns the position in the :ref:`AudioStream`. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_method_get_stream_playback: .. rst-class:: classref-method :ref:`AudioStreamPlayback` **get_stream_playback** **(** **)** Returns the :ref:`AudioStreamPlayback` object associated with this **AudioStreamPlayer3D**. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_method_play: .. rst-class:: classref-method void **play** **(** :ref:`float` from_position=0.0 **)** Plays the audio from the given position ``from_position``, in seconds. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_method_seek: .. rst-class:: classref-method void **seek** **(** :ref:`float` to_position **)** Sets the position from which audio will be played, in seconds. .. rst-class:: classref-item-separator ---- .. _class_AudioStreamPlayer3D_method_stop: .. rst-class:: classref-method void **stop** **(** **)** Stops the audio. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)` .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)` .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)` .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`