<?xml version="1.0" encoding="UTF-8" ?> <class name="AudioServer" inherits="Object" category="Core" version="3.2"> <brief_description> Server interface for low-level audio access. </brief_description> <description> AudioServer is a low-level server interface for audio access. It is in charge of creating sample data (playable audio) as well as its playback via a voice interface. </description> <tutorials> <link>https://docs.godotengine.org/en/latest/tutorials/audio/audio_buses.html</link> </tutorials> <methods> <method name="add_bus"> <return type="void"> </return> <argument index="0" name="at_position" type="int" default="-1"> </argument> <description> Adds a bus at [code]at_position[/code]. </description> </method> <method name="add_bus_effect"> <return type="void"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="effect" type="AudioEffect"> </argument> <argument index="2" name="at_position" type="int" default="-1"> </argument> <description> Adds an [AudioEffect] effect to the bus [code]bus_idx[/code] at [code]at_position[/code]. </description> </method> <method name="capture_get_device_list"> <return type="Array"> </return> <description> Returns the names of all audio input devices detected on the system. </description> </method> <method name="capture_start"> <return type="int" enum="Error"> </return> <description> Attempts to start recording from the audio driver's capture device. On success, the return value is [constant OK]. </description> </method> <method name="capture_stop"> <return type="int" enum="Error"> </return> <description> Attempts to stop recording from the audio driver's capture device. On success, the return value is [constant OK]. </description> </method> <method name="generate_bus_layout" qualifiers="const"> <return type="AudioBusLayout"> </return> <description> Generates an [AudioBusLayout] using the available buses and effects. </description> </method> <method name="get_bus_channels" qualifiers="const"> <return type="int"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <description> Returns the amount of channels of the bus at index [code]bus_idx[/code]. </description> </method> <method name="get_bus_effect"> <return type="AudioEffect"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="effect_idx" type="int"> </argument> <description> Returns the [AudioEffect] at position [code]effect_idx[/code] in bus [code]bus_idx[/code]. </description> </method> <method name="get_bus_effect_count"> <return type="int"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <description> Returns the number of effects on the bus at [code]bus_idx[/code]. </description> </method> <method name="get_bus_effect_instance"> <return type="AudioEffectInstance"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="effect_idx" type="int"> </argument> <argument index="2" name="channel" type="int" default="0"> </argument> <description> </description> </method> <method name="get_bus_index" qualifiers="const"> <return type="int"> </return> <argument index="0" name="bus_name" type="String"> </argument> <description> Returns the index of the bus with the name [code]bus_name[/code]. </description> </method> <method name="get_bus_name" qualifiers="const"> <return type="String"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <description> Returns the name of the bus with the index [code]bus_idx[/code]. </description> </method> <method name="get_bus_peak_volume_left_db" qualifiers="const"> <return type="float"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="channel" type="int"> </argument> <description> Returns the peak volume of the left speaker at bus index [code]bus_idx[/code] and channel index [code]channel[/code]. </description> </method> <method name="get_bus_peak_volume_right_db" qualifiers="const"> <return type="float"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="channel" type="int"> </argument> <description> Returns the peak volume of the right speaker at bus index [code]bus_idx[/code] and channel index [code]channel[/code]. </description> </method> <method name="get_bus_send" qualifiers="const"> <return type="String"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <description> Returns the name of the bus that the bus at index [code]bus_idx[/code] sends to. </description> </method> <method name="get_bus_volume_db" qualifiers="const"> <return type="float"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <description> Returns the volume of the bus at index [code]bus_idx[/code] in dB. </description> </method> <method name="get_capture_buffer"> <return type="PoolIntArray"> </return> <description> Returns an [PoolIntArray] containing audio frames from the capture device. </description> </method> <method name="get_capture_position"> <return type="int"> </return> <description> Returns the write position of the capture device buffer. </description> </method> <method name="get_capture_size"> <return type="int"> </return> <description> Returns the size of the capture device buffer. </description> </method> <method name="get_device_list"> <return type="Array"> </return> <description> Returns the names of all audio output devices detected on the system. </description> </method> <method name="get_mix_rate" qualifiers="const"> <return type="float"> </return> <description> Returns the sample rate at the output of the [AudioServer]. </description> </method> <method name="get_output_latency" qualifiers="const"> <return type="float"> </return> <description> Returns the audio driver's output latency. </description> </method> <method name="get_speaker_mode" qualifiers="const"> <return type="int" enum="AudioServer.SpeakerMode"> </return> <description> Returns the speaker configuration. </description> </method> <method name="get_time_since_last_mix" qualifiers="const"> <return type="float"> </return> <description> </description> </method> <method name="get_time_to_next_mix" qualifiers="const"> <return type="float"> </return> <description> </description> </method> <method name="is_bus_bypassing_effects" qualifiers="const"> <return type="bool"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <description> If [code]true[/code], the bus at index [code]bus_idx[/code] is bypassing effects. </description> </method> <method name="is_bus_effect_enabled" qualifiers="const"> <return type="bool"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="effect_idx" type="int"> </argument> <description> If [code]true[/code], the effect at index [code]effect_idx[/code] on the bus at index [code]bus_idx[/code] is enabled. </description> </method> <method name="is_bus_mute" qualifiers="const"> <return type="bool"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <description> If [code]true[/code], the bus at index [code]bus_idx[/code] is muted. </description> </method> <method name="is_bus_solo" qualifiers="const"> <return type="bool"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <description> If [code]true[/code], the bus at index [code]bus_idx[/code] is in solo mode. </description> </method> <method name="lock"> <return type="void"> </return> <description> Locks the audio driver's main loop. Remember to unlock it afterwards. </description> </method> <method name="move_bus"> <return type="void"> </return> <argument index="0" name="index" type="int"> </argument> <argument index="1" name="to_index" type="int"> </argument> <description> Moves the bus from index [code]index[/code] to index [code]to_index[/code]. </description> </method> <method name="remove_bus"> <return type="void"> </return> <argument index="0" name="index" type="int"> </argument> <description> Removes the bus at index [code]index[/code]. </description> </method> <method name="remove_bus_effect"> <return type="void"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="effect_idx" type="int"> </argument> <description> Removes the effect at index [code]effect_idx[/code] from the bus at index [code]bus_idx[/code]. </description> </method> <method name="set_bus_bypass_effects"> <return type="void"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="enable" type="bool"> </argument> <description> If [code]true[/code], the bus at index [code]bus_idx[/code] is bypassing effects. </description> </method> <method name="set_bus_effect_enabled"> <return type="void"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="effect_idx" type="int"> </argument> <argument index="2" name="enabled" type="bool"> </argument> <description> If [code]true[/code], the effect at index [code]effect_idx[/code] on the bus at index [code]bus_idx[/code] is enabled. </description> </method> <method name="set_bus_layout"> <return type="void"> </return> <argument index="0" name="bus_layout" type="AudioBusLayout"> </argument> <description> Overwrites the currently used [AudioBusLayout]. </description> </method> <method name="set_bus_mute"> <return type="void"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="enable" type="bool"> </argument> <description> If [code]true[/code], the bus at index [code]bus_idx[/code] is muted. </description> </method> <method name="set_bus_name"> <return type="void"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="name" type="String"> </argument> <description> Sets the name of the bus at index [code]bus_idx[/code] to [code]name[/code]. </description> </method> <method name="set_bus_send"> <return type="void"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="send" type="String"> </argument> <description> Connects the output of the bus at [code]bus_idx[/code] to the bus named [code]send[/code]. </description> </method> <method name="set_bus_solo"> <return type="void"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="enable" type="bool"> </argument> <description> If [code]true[/code], the bus at index [code]bus_idx[/code] is in solo mode. </description> </method> <method name="set_bus_volume_db"> <return type="void"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="volume_db" type="float"> </argument> <description> Sets the volume of the bus at index [code]bus_idx[/code] to [code]volume_db[/code]. </description> </method> <method name="swap_bus_effects"> <return type="void"> </return> <argument index="0" name="bus_idx" type="int"> </argument> <argument index="1" name="effect_idx" type="int"> </argument> <argument index="2" name="by_effect_idx" type="int"> </argument> <description> Swaps the position of two effects in bus [code]bus_idx[/code]. </description> </method> <method name="unlock"> <return type="void"> </return> <description> Unlocks the audio driver's main loop. (After locking it, you should always unlock it.) </description> </method> </methods> <members> <member name="bus_count" type="int" setter="set_bus_count" getter="get_bus_count" default="1"> Number of available audio buses. </member> <member name="capture_device" type="String" setter="capture_set_device" getter="capture_get_device" default=""""> Name of the current device for audio input (see [method capture_get_device_list]). </member> <member name="device" type="String" setter="set_device" getter="get_device" default=""Default""> Name of the current device for audio output (see [method get_device_list]). </member> <member name="global_rate_scale" type="float" setter="set_global_rate_scale" getter="get_global_rate_scale" default="1.0"> Scales the rate at which audio is played (i.e. setting it to [code]0.5[/code] will make the audio be played twice as fast). </member> </members> <signals> <signal name="audio_mix_callback"> <description> </description> </signal> <signal name="audio_update_callback"> <description> </description> </signal> <signal name="bus_layout_changed"> <description> Emitted when the [AudioBusLayout] changes. </description> </signal> </signals> <constants> <constant name="SPEAKER_MODE_STEREO" value="0" enum="SpeakerMode"> Two or fewer speakers were detected. </constant> <constant name="SPEAKER_SURROUND_31" value="1" enum="SpeakerMode"> A 3.1 channel surround setup was detected. </constant> <constant name="SPEAKER_SURROUND_51" value="2" enum="SpeakerMode"> A 5.1 channel surround setup was detected. </constant> <constant name="SPEAKER_SURROUND_71" value="3" enum="SpeakerMode"> A 7.1 channel surround setup was detected. </constant> </constants> </class>