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 >
2018-03-31 07:11:14 +08:00
Plays 3D 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].
2020-08-25 21:59:57 +08:00
By default, audio is heard from the camera position. This can be changed by adding a [Listener3D] node to the scene and enabling it by calling [method Listener3D.make_current] on it.
2017-09-13 04:42:36 +08:00
</description>
<tutorials >
2020-08-05 20:43:40 +08:00
<link title= "Audio streams" > https://docs.godotengine.org/en/latest/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" >
2017-09-13 04:42:36 +08:00
<return type= "float" >
</return>
<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" >
<return type= "AudioStreamPlayback" >
</return>
<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" >
<return type= "void" >
</return>
2017-09-10 21:37:49 +08:00
<argument index= "0" name= "from_position" type= "float" default= "0.0" >
2017-09-13 04:42:36 +08:00
</argument>
<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" >
<return type= "void" >
</return>
2017-09-10 21:37:49 +08:00
<argument index= "0" name= "to_position" type= "float" >
2017-09-13 04:42:36 +08:00
</argument>
<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" >
<return type= "void" >
</return>
<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>
2020-02-22 21:59:09 +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" >
2019-06-22 07:04:47 +08:00
Sets the distance from which the [member out_of_range_mode] takes effect. Has no effect if set to 0.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "out_of_range_mode" type= "int" setter= "set_out_of_range_mode" getter= "get_out_of_range_mode" enum= "AudioStreamPlayer3D.OutOfRangeMode" default= "0" >
2019-06-22 07:04:47 +08:00
Decides if audio should pause when source is outside of [member max_distance] range.
2017-09-13 04:42:36 +08:00
</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>
2019-06-29 18:38:01 +08:00
<member name= "unit_size" type= "float" setter= "set_unit_size" getter= "get_unit_size" default= "1.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" >
2020-11-23 23:56:05 +08:00
No dampening of loudness according to distance. The sound will still be heard positionally, unlike an [AudioStreamPlayer].
2019-03-10 21:25:54 +08:00
</constant>
2017-11-25 06:16:30 +08:00
<constant name= "OUT_OF_RANGE_MIX" value= "0" enum= "OutOfRangeMode" >
2020-11-23 23:56:05 +08:00
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 [member max_distance] radius.
2017-09-13 04:42:36 +08:00
</constant>
2017-11-25 06:16:30 +08:00
<constant name= "OUT_OF_RANGE_PAUSE" value= "1" enum= "OutOfRangeMode" >
2020-11-23 23:56:05 +08:00
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 [member max_distance] radius.
2017-09-13 04:42:36 +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>