2017-09-12 22:42:36 +02:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-07-05 22:07:03 +02:00
<class name= "AudioStreamPlayer3D" inherits= "Node3D" version= "4.2" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2017-09-12 22:42:36 +02:00
<brief_description >
2021-05-05 20:37:35 +02:00
Plays positional sound in 3D space.
2017-09-12 22:42:36 +02:00
</brief_description>
<description >
2022-10-29 14:38:05 +02:00
Plays audio with positional sound effects, based on the relative position of the audio listener. Positional effects include distance attenuation, directionality, and the Doppler effect. For greater realism, a low-pass filter is applied to distant sounds. This can be disabled by setting [member attenuation_filter_cutoff_hz] to [code]20500[/code].
2022-08-10 02:31:12 +02:00
By default, audio is heard from the camera position. This can be changed by adding an [AudioListener3D] node to the scene and enabling it by calling [method AudioListener3D.make_current] on it.
2021-05-05 20:37:35 +02:00
See also [AudioStreamPlayer] to play a sound non-positionally.
2022-09-17 14:34:43 +02:00
[b]Note:[/b] Hiding an [AudioStreamPlayer3D] node does not disable its audio output. To temporarily disable an [AudioStreamPlayer3D]'s audio output, set [member volume_db] to a very low value like [code]-100[/code] (which isn't audible to human hearing).
2017-09-12 22:42:36 +02:00
</description>
<tutorials >
2021-11-15 10:43:07 +01:00
<link title= "Audio streams" > $DOCS_URL/tutorials/audio/audio_streams.html</link>
2017-09-12 22:42:36 +02:00
</tutorials>
<methods >
2017-09-21 05:31:36 +02:00
<method name= "get_playback_position" >
2021-07-30 15:28:05 +02:00
<return type= "float" />
2017-09-12 22:42:36 +02:00
<description >
2017-10-10 16:00:10 +02:00
Returns the position in the [AudioStream].
2017-09-12 22:42:36 +02:00
</description>
</method>
2019-04-15 14:49:41 +02:00
<method name= "get_stream_playback" >
2021-07-30 15:28:05 +02:00
<return type= "AudioStreamPlayback" />
2019-04-15 14:49:41 +02:00
<description >
2020-01-08 22:51:16 +01:00
Returns the [AudioStreamPlayback] object associated with this [AudioStreamPlayer3D].
2019-04-15 14:49:41 +02:00
</description>
</method>
2023-01-27 19:25:49 +01:00
<method name= "has_stream_playback" >
<return type= "bool" />
<description >
Returns whether the [AudioStreamPlayer] can return the [AudioStreamPlayback] object or not.
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "play" >
2021-07-30 15:28:05 +02:00
<return type= "void" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "from_position" type= "float" default= "0.0" />
2017-09-12 22:42:36 +02:00
<description >
2022-09-05 22:08:12 +02:00
Queues the audio to play on the next physics frame, from the given position [param from_position], in seconds.
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "seek" >
2021-07-30 15:28:05 +02:00
<return type= "void" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "to_position" type= "float" />
2017-09-12 22:42:36 +02:00
<description >
2017-09-16 13:33:58 +02:00
Sets the position from which audio will be played, in seconds.
2017-09-12 22:42:36 +02:00
</description>
</method>
<method name= "stop" >
2021-07-30 15:28:05 +02:00
<return type= "void" />
2017-09-12 22:42:36 +02:00
<description >
2017-09-16 13:33:58 +02:00
Stops the audio.
2017-09-12 22:42:36 +02:00
</description>
</method>
</methods>
<members >
2019-06-29 12:38:01 +02:00
<member name= "area_mask" type= "int" setter= "set_area_mask" getter= "get_area_mask" default= "1" >
2022-02-10 23:25:33 +01:00
Determines which [Area3D] layers affect the sound for reverb and audio bus effects. Areas can be used to redirect [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.
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "attenuation_filter_cutoff_hz" type= "float" setter= "set_attenuation_filter_cutoff_hz" getter= "get_attenuation_filter_cutoff_hz" default= "5000.0" >
2022-10-29 14:38:05 +02:00
The cutoff frequency of the attenuation low-pass filter, in Hz. A sound above this frequency is attenuated more than a sound below this frequency. To disable this effect, set this to [code]20500[/code] as this frequency is above the human hearing limit.
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "attenuation_filter_db" type= "float" setter= "set_attenuation_filter_db" getter= "get_attenuation_filter_db" default= "-24.0" >
2020-11-23 16:56:05 +01:00
Amount how much the filter affects the loudness, in decibels.
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "attenuation_model" type= "int" setter= "set_attenuation_model" getter= "get_attenuation_model" enum= "AudioStreamPlayer3D.AttenuationModel" default= "0" >
2019-03-10 14:25:54 +01:00
Decides if audio should get quieter with distance linearly, quadratically, logarithmically, or not be affected by distance, effectively disabling attenuation.
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "autoplay" type= "bool" setter= "set_autoplay" getter= "is_autoplay_enabled" default= "false" >
2020-11-23 16:56:05 +01:00
If [code]true[/code], audio plays when the AudioStreamPlayer3D node is added to scene tree.
2017-09-12 22:42:36 +02:00
</member>
2021-06-05 21:24:24 +02:00
<member name= "bus" type= "StringName" setter= "set_bus" getter= "get_bus" default= "&"Master"" >
2020-11-23 16:56:05 +01:00
The bus on which this audio is playing.
2022-07-08 09:33:25 +02:00
[b]Note:[/b] 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 [code]"Master"[/code].
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "doppler_tracking" type= "int" setter= "set_doppler_tracking" getter= "get_doppler_tracking" enum= "AudioStreamPlayer3D.DopplerTracking" default= "0" >
2017-09-16 13:33:58 +02:00
Decides in which step the Doppler effect should be calculated.
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "emission_angle_degrees" type= "float" setter= "set_emission_angle" getter= "get_emission_angle" default= "45.0" >
2022-10-29 14:38:05 +02:00
The angle in which the audio reaches a listener unattenuated.
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "emission_angle_enabled" type= "bool" setter= "set_emission_angle_enabled" getter= "is_emission_angle_enabled" default= "false" >
2022-10-29 14:38:05 +02:00
If [code]true[/code], the audio should be attenuated according to the direction of the sound.
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "emission_angle_filter_attenuation_db" type= "float" setter= "set_emission_angle_filter_attenuation_db" getter= "get_emission_angle_filter_attenuation_db" default= "-12.0" >
2022-10-29 14:38:05 +02:00
Attenuation factor used if listener is outside of [member emission_angle_degrees] and [member emission_angle_enabled] is set, in decibels.
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "max_db" type= "float" setter= "set_max_db" getter= "get_max_db" default= "3.0" >
2020-11-23 16:56:05 +01:00
Sets the absolute maximum of the soundlevel, in decibels.
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "max_distance" type= "float" setter= "set_max_distance" getter= "get_max_distance" default= "0.0" >
2021-09-17 10:05:31 +02:00
The distance past which the sound can no longer be heard at all. Only has an effect if set to a value greater than [code]0.0[/code]. [member max_distance] works in tandem with [member unit_size]. However, unlike [member unit_size] whose behavior depends on the [member attenuation_model], [member max_distance] always works in a linear fashion. This can be used to prevent the [AudioStreamPlayer3D] from requiring audio mixing when the listener is far away, which saves CPU resources.
2017-09-12 22:42:36 +02:00
</member>
2021-08-28 06:51:03 +02:00
<member name= "max_polyphony" type= "int" setter= "set_max_polyphony" getter= "get_max_polyphony" default= "1" >
The maximum number of sounds this node can play at the same time. Playing additional sounds after this value is reached will cut off the oldest sounds.
</member>
2022-03-06 17:53:56 +01:00
<member name= "panning_strength" type= "float" setter= "set_panning_strength" getter= "get_panning_strength" default= "1.0" >
Scales the panning strength for this node by multiplying the base [member ProjectSettings.audio/general/3d_panning_strength] with this factor. Higher values will pan audio from left to right more dramatically than lower values.
</member>
2019-06-29 12:38:01 +02:00
<member name= "pitch_scale" type= "float" setter= "set_pitch_scale" getter= "get_pitch_scale" default= "1.0" >
2020-04-26 16:37:22 +02:00
The pitch and the tempo of the audio, as a multiplier of the audio sample's sample rate.
2018-02-19 10:47:16 +01:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "playing" type= "bool" setter= "_set_playing" getter= "is_playing" default= "false" >
2022-09-05 22:08:12 +02:00
If [code]true[/code], audio is playing or is queued to be played (see [method play]).
2017-09-12 22:42:36 +02:00
</member>
2019-07-15 20:42:47 +02:00
<member name= "stream" type= "AudioStream" setter= "set_stream" getter= "get_stream" >
2020-11-23 16:56:05 +01:00
The [AudioStream] resource to be played.
2017-09-12 22:42:36 +02:00
</member>
2019-06-29 12:38:01 +02:00
<member name= "stream_paused" type= "bool" setter= "set_stream_paused" getter= "get_stream_paused" default= "false" >
2020-11-23 16:56:05 +01:00
If [code]true[/code], the playback is paused. You can resume it by setting [member stream_paused] to [code]false[/code].
2018-07-26 11:56:21 +02:00
</member>
2020-04-26 14:26:01 +02:00
<member name= "unit_size" type= "float" setter= "set_unit_size" getter= "get_unit_size" default= "10.0" >
2020-11-23 16:56:05 +01:00
The factor for the attenuation effect. Higher values make the sound audible over a larger distance.
2017-09-12 22:42:36 +02:00
</member>
2022-09-17 14:34:43 +02:00
<member name= "volume_db" type= "float" setter= "set_volume_db" getter= "get_volume_db" default= "0.0" >
2022-10-29 14:38:05 +02:00
The base sound level before attenuation, in decibels.
2022-09-17 14:34:43 +02:00
</member>
2017-09-12 22:42:36 +02:00
</members>
<signals >
<signal name= "finished" >
<description >
2019-06-22 01:04:47 +02:00
Emitted when the audio stops playing.
2017-09-12 22:42:36 +02:00
</description>
</signal>
</signals>
<constants >
2017-11-24 23:16:30 +01:00
<constant name= "ATTENUATION_INVERSE_DISTANCE" value= "0" enum= "AttenuationModel" >
2022-10-29 14:38:05 +02:00
Attenuation of loudness according to linear distance.
2017-09-12 22:42:36 +02:00
</constant>
2017-11-24 23:16:30 +01:00
<constant name= "ATTENUATION_INVERSE_SQUARE_DISTANCE" value= "1" enum= "AttenuationModel" >
2022-10-29 14:38:05 +02:00
Attenuation of loudness according to squared distance.
2017-09-12 22:42:36 +02:00
</constant>
2017-11-24 23:16:30 +01:00
<constant name= "ATTENUATION_LOGARITHMIC" value= "2" enum= "AttenuationModel" >
2022-10-29 14:38:05 +02:00
Attenuation of loudness according to logarithmic distance.
2017-09-12 22:42:36 +02:00
</constant>
2019-03-10 14:25:54 +01:00
<constant name= "ATTENUATION_DISABLED" value= "3" enum= "AttenuationModel" >
2022-10-29 14:38:05 +02:00
No attenuation of loudness according to distance. The sound will still be heard positionally, unlike an [AudioStreamPlayer]. [constant ATTENUATION_DISABLED] can be combined with a [member max_distance] value greater than [code]0.0[/code] to achieve linear attenuation clamped to a sphere of a defined size.
2019-03-10 14:25:54 +01:00
</constant>
2017-11-24 23:16:30 +01:00
<constant name= "DOPPLER_TRACKING_DISABLED" value= "0" enum= "DopplerTracking" >
2017-09-16 13:33:58 +02:00
Disables doppler tracking.
2017-09-12 22:42:36 +02:00
</constant>
2017-11-24 23:16:30 +01:00
<constant name= "DOPPLER_TRACKING_IDLE_STEP" value= "1" enum= "DopplerTracking" >
2023-06-01 01:38:19 +02:00
Executes doppler tracking during process frames (see [constant Node.NOTIFICATION_INTERNAL_PROCESS]).
2017-09-12 22:42:36 +02:00
</constant>
2017-11-24 23:16:30 +01:00
<constant name= "DOPPLER_TRACKING_PHYSICS_STEP" value= "2" enum= "DopplerTracking" >
2023-06-01 01:38:19 +02:00
Executes doppler tracking during physics frames (see [constant Node.NOTIFICATION_INTERNAL_PHYSICS_PROCESS]).
2017-09-12 22:42:36 +02:00
</constant>
</constants>
</class>