2017-09-13 04:42:36 +08:00
<?xml version="1.0" encoding="UTF-8" ?>
2020-03-31 00:22:57 +08:00
<class name= "AudioStreamPlayer3D" inherits= "Node3D" version= "4.0" >
2017-09-13 04:42:36 +08:00
<brief_description >
2021-05-06 02:37:35 +08:00
Plays positional sound in 3D space.
2017-09-13 04:42:36 +08:00
</brief_description>
<description >
2020-11-23 23:56:05 +08:00
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 [member attenuation_filter_cutoff_hz] to [code]20500[/code].
2021-09-17 03:28:20 +08:00
By default, audio is heard from the camera position. This can be changed by adding a [AudioListener3D] node to the scene and enabling it by calling [method AudioListener3D.make_current] on it.
2021-05-06 02:37:35 +08:00
See also [AudioStreamPlayer] to play a sound non-positionally.
[b]Note:[/b] Hiding an [AudioStreamPlayer3D] node does not disable its audio output. To temporarily disable an [AudioStreamPlayer3D]'s audio output, set [member unit_db] to a very low value like [code]-100[/code] (which isn't audible to human hearing).
2017-09-13 04:42:36 +08:00
</description>
<tutorials >
2021-11-15 17:43:07 +08:00
<link title= "Audio streams" > $DOCS_URL/tutorials/audio/audio_streams.html</link>
2017-09-13 04:42:36 +08:00
</tutorials>
<methods >
2017-09-21 11:31:36 +08:00
<method name= "get_playback_position" >
2021-07-30 21:28:05 +08:00
<return type= "float" />
2017-09-13 04:42:36 +08:00
<description >
2017-10-10 22:00:10 +08:00
Returns the position in the [AudioStream].
2017-09-13 04:42:36 +08:00
</description>
</method>
2019-04-15 20:49:41 +08:00
<method name= "get_stream_playback" >
2021-07-30 21:28:05 +08:00
<return type= "AudioStreamPlayback" />
2019-04-15 20:49:41 +08:00
<description >
2020-01-09 05:51:16 +08:00
Returns the [AudioStreamPlayback] object associated with this [AudioStreamPlayer3D].
2019-04-15 20:49:41 +08:00
</description>
</method>
2017-09-13 04:42:36 +08:00
<method name= "play" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
<argument index= "0" name= "from_position" type= "float" default= "0.0" />
2017-09-13 04:42:36 +08:00
<description >
2019-06-22 07:04:47 +08:00
Plays the audio from the given position [code]from_position[/code], in seconds.
2017-09-13 04:42:36 +08:00
</description>
</method>
<method name= "seek" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
<argument index= "0" name= "to_position" type= "float" />
2017-09-13 04:42:36 +08:00
<description >
2017-09-16 19:33:58 +08:00
Sets the position from which audio will be played, in seconds.
2017-09-13 04:42:36 +08:00
</description>
</method>
<method name= "stop" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2017-09-13 04:42:36 +08:00
<description >
2017-09-16 19:33:58 +08:00
Stops the audio.
2017-09-13 04:42:36 +08:00
</description>
</method>
</methods>
<members >
2019-06-29 18:38:01 +08:00
<member name= "area_mask" type= "int" setter= "set_area_mask" getter= "get_area_mask" default= "1" >
2017-09-16 19:33:58 +08:00
Areas in which this sound plays.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "attenuation_filter_cutoff_hz" type= "float" setter= "set_attenuation_filter_cutoff_hz" getter= "get_attenuation_filter_cutoff_hz" default= "5000.0" >
2020-11-23 23:56:05 +08:00
Dampens audio using a low-pass filter above this frequency, in Hz. To disable the dampening effect entirely, set this to [code]20500[/code] as this frequency is above the human hearing limit.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "attenuation_filter_db" type= "float" setter= "set_attenuation_filter_db" getter= "get_attenuation_filter_db" default= "-24.0" >
2020-11-23 23:56:05 +08:00
Amount how much the filter affects the loudness, in decibels.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "attenuation_model" type= "int" setter= "set_attenuation_model" getter= "get_attenuation_model" enum= "AudioStreamPlayer3D.AttenuationModel" default= "0" >
2019-03-10 21:25:54 +08:00
Decides if audio should get quieter with distance linearly, quadratically, logarithmically, or not be affected by distance, effectively disabling attenuation.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "autoplay" type= "bool" setter= "set_autoplay" getter= "is_autoplay_enabled" default= "false" >
2020-11-23 23:56:05 +08:00
If [code]true[/code], audio plays when the AudioStreamPlayer3D node is added to scene tree.
2017-09-13 04:42:36 +08:00
</member>
2021-06-06 03:24:24 +08:00
<member name= "bus" type= "StringName" setter= "set_bus" getter= "get_bus" default= "&"Master"" >
2020-11-23 23:56:05 +08:00
The bus on which this audio is playing.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "doppler_tracking" type= "int" setter= "set_doppler_tracking" getter= "get_doppler_tracking" enum= "AudioStreamPlayer3D.DopplerTracking" default= "0" >
2017-09-16 19:33:58 +08:00
Decides in which step the Doppler effect should be calculated.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "emission_angle_degrees" type= "float" setter= "set_emission_angle" getter= "get_emission_angle" default= "45.0" >
2017-09-16 19:33:58 +08:00
The angle in which the audio reaches cameras undampened.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "emission_angle_enabled" type= "bool" setter= "set_emission_angle_enabled" getter= "is_emission_angle_enabled" default= "false" >
2018-12-20 20:46:54 +08:00
If [code]true[/code], the audio should be dampened according to the direction of the sound.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08: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" >
2020-11-23 23:56:05 +08:00
Dampens audio if camera is outside of [member emission_angle_degrees] and [member emission_angle_enabled] is set by this factor, in decibels.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "max_db" type= "float" setter= "set_max_db" getter= "get_max_db" default= "3.0" >
2020-11-23 23:56:05 +08:00
Sets the absolute maximum of the soundlevel, in decibels.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "max_distance" type= "float" setter= "set_max_distance" getter= "get_max_distance" default= "0.0" >
2021-09-17 16:05:31 +08: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-13 04:42:36 +08:00
</member>
2021-08-28 12:51:03 +08: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>
2019-06-29 18:38:01 +08:00
<member name= "pitch_scale" type= "float" setter= "set_pitch_scale" getter= "get_pitch_scale" default= "1.0" >
2020-04-26 22:37:22 +08:00
The pitch and the tempo of the audio, as a multiplier of the audio sample's sample rate.
2018-02-19 17:47:16 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "playing" type= "bool" setter= "_set_playing" getter= "is_playing" default= "false" >
2017-09-16 19:33:58 +08:00
If [code]true[/code], audio is playing.
2017-09-13 04:42:36 +08:00
</member>
2019-07-16 02:42:47 +08:00
<member name= "stream" type= "AudioStream" setter= "set_stream" getter= "get_stream" >
2020-11-23 23:56:05 +08:00
The [AudioStream] resource to be played.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "stream_paused" type= "bool" setter= "set_stream_paused" getter= "get_stream_paused" default= "false" >
2020-11-23 23:56:05 +08: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 17:56:21 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "unit_db" type= "float" setter= "set_unit_db" getter= "get_unit_db" default= "0.0" >
2020-11-23 23:56:05 +08:00
The base sound level unaffected by dampening, in decibels.
2017-09-13 04:42:36 +08:00
</member>
2020-04-26 20:26:01 +08:00
<member name= "unit_size" type= "float" setter= "set_unit_size" getter= "get_unit_size" default= "10.0" >
2020-11-23 23:56:05 +08:00
The factor for the attenuation effect. Higher values make the sound audible over a larger distance.
2017-09-13 04:42:36 +08:00
</member>
</members>
<signals >
<signal name= "finished" >
<description >
2019-06-22 07:04:47 +08:00
Emitted when the audio stops playing.
2017-09-13 04:42:36 +08:00
</description>
</signal>
</signals>
<constants >
2017-11-25 06:16:30 +08:00
<constant name= "ATTENUATION_INVERSE_DISTANCE" value= "0" enum= "AttenuationModel" >
2017-09-16 19:33:58 +08:00
Linear dampening of loudness according to distance.
2017-09-13 04:42:36 +08:00
</constant>
2017-11-25 06:16:30 +08:00
<constant name= "ATTENUATION_INVERSE_SQUARE_DISTANCE" value= "1" enum= "AttenuationModel" >
2017-09-16 19:33:58 +08:00
Squared dampening of loudness according to distance.
2017-09-13 04:42:36 +08:00
</constant>
2017-11-25 06:16:30 +08:00
<constant name= "ATTENUATION_LOGARITHMIC" value= "2" enum= "AttenuationModel" >
2017-09-16 19:33:58 +08:00
Logarithmic dampening of loudness according to distance.
2017-09-13 04:42:36 +08:00
</constant>
2019-03-10 21:25:54 +08:00
<constant name= "ATTENUATION_DISABLED" value= "3" enum= "AttenuationModel" >
2021-09-17 16:14:32 +08:00
No dampening 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 21:25:54 +08:00
</constant>
2017-11-25 06:16:30 +08:00
<constant name= "DOPPLER_TRACKING_DISABLED" value= "0" enum= "DopplerTracking" >
2017-09-16 19:33:58 +08:00
Disables doppler tracking.
2017-09-13 04:42:36 +08:00
</constant>
2017-11-25 06:16:30 +08:00
<constant name= "DOPPLER_TRACKING_IDLE_STEP" value= "1" enum= "DopplerTracking" >
2017-10-14 18:45:26 +08:00
Executes doppler tracking in idle step.
2017-09-13 04:42:36 +08:00
</constant>
2017-11-25 06:16:30 +08:00
<constant name= "DOPPLER_TRACKING_PHYSICS_STEP" value= "2" enum= "DopplerTracking" >
2017-10-12 05:54:43 +08:00
Executes doppler tracking in physics step.
2017-09-13 04:42:36 +08:00
</constant>
</constants>
</class>