class_audioserver.rst 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. .. Generated automatically by doc/tools/makerst.py in Godot's source tree.
  2. .. DO NOT EDIT THIS FILE, but the AudioServer.xml source instead.
  3. .. The source is found in doc/classes or modules/<name>/doc_classes.
  4. .. _class_AudioServer:
  5. AudioServer
  6. ===========
  7. **Inherits:** :ref:`Object<class_Object>`
  8. **Category:** Core
  9. Brief Description
  10. -----------------
  11. Server interface for low level audio access.
  12. Methods
  13. -------
  14. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  15. | void | :ref:`add_bus<class_AudioServer_method_add_bus>` **(** :ref:`int<class_int>` at_position=-1 **)** |
  16. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  17. | void | :ref:`add_bus_effect<class_AudioServer_method_add_bus_effect>` **(** :ref:`int<class_int>` bus_idx, :ref:`AudioEffect<class_AudioEffect>` effect, :ref:`int<class_int>` at_position=-1 **)** |
  18. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  19. | :ref:`String<class_String>` | :ref:`capture_get_device<class_AudioServer_method_capture_get_device>` **(** **)** |
  20. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  21. | :ref:`Array<class_Array>` | :ref:`capture_get_device_list<class_AudioServer_method_capture_get_device_list>` **(** **)** |
  22. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  23. | void | :ref:`capture_set_device<class_AudioServer_method_capture_set_device>` **(** :ref:`String<class_String>` name **)** |
  24. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  25. | :ref:`AudioBusLayout<class_AudioBusLayout>` | :ref:`generate_bus_layout<class_AudioServer_method_generate_bus_layout>` **(** **)** const |
  26. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  27. | :ref:`int<class_int>` | :ref:`get_bus_channels<class_AudioServer_method_get_bus_channels>` **(** :ref:`int<class_int>` bus_idx **)** const |
  28. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  29. | :ref:`int<class_int>` | :ref:`get_bus_count<class_AudioServer_method_get_bus_count>` **(** **)** const |
  30. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  31. | :ref:`AudioEffect<class_AudioEffect>` | :ref:`get_bus_effect<class_AudioServer_method_get_bus_effect>` **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` effect_idx **)** |
  32. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  33. | :ref:`int<class_int>` | :ref:`get_bus_effect_count<class_AudioServer_method_get_bus_effect_count>` **(** :ref:`int<class_int>` bus_idx **)** |
  34. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  35. | :ref:`int<class_int>` | :ref:`get_bus_index<class_AudioServer_method_get_bus_index>` **(** :ref:`String<class_String>` bus_name **)** const |
  36. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  37. | :ref:`String<class_String>` | :ref:`get_bus_name<class_AudioServer_method_get_bus_name>` **(** :ref:`int<class_int>` bus_idx **)** const |
  38. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  39. | :ref:`float<class_float>` | :ref:`get_bus_peak_volume_left_db<class_AudioServer_method_get_bus_peak_volume_left_db>` **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` channel **)** const |
  40. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  41. | :ref:`float<class_float>` | :ref:`get_bus_peak_volume_right_db<class_AudioServer_method_get_bus_peak_volume_right_db>` **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` channel **)** const |
  42. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  43. | :ref:`String<class_String>` | :ref:`get_bus_send<class_AudioServer_method_get_bus_send>` **(** :ref:`int<class_int>` bus_idx **)** const |
  44. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  45. | :ref:`float<class_float>` | :ref:`get_bus_volume_db<class_AudioServer_method_get_bus_volume_db>` **(** :ref:`int<class_int>` bus_idx **)** const |
  46. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  47. | :ref:`String<class_String>` | :ref:`get_device<class_AudioServer_method_get_device>` **(** **)** |
  48. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  49. | :ref:`Array<class_Array>` | :ref:`get_device_list<class_AudioServer_method_get_device_list>` **(** **)** |
  50. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  51. | :ref:`float<class_float>` | :ref:`get_mix_rate<class_AudioServer_method_get_mix_rate>` **(** **)** const |
  52. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  53. | :ref:`SpeakerMode<enum_AudioServer_SpeakerMode>` | :ref:`get_speaker_mode<class_AudioServer_method_get_speaker_mode>` **(** **)** const |
  54. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  55. | :ref:`bool<class_bool>` | :ref:`is_bus_bypassing_effects<class_AudioServer_method_is_bus_bypassing_effects>` **(** :ref:`int<class_int>` bus_idx **)** const |
  56. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  57. | :ref:`bool<class_bool>` | :ref:`is_bus_effect_enabled<class_AudioServer_method_is_bus_effect_enabled>` **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` effect_idx **)** const |
  58. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  59. | :ref:`bool<class_bool>` | :ref:`is_bus_mute<class_AudioServer_method_is_bus_mute>` **(** :ref:`int<class_int>` bus_idx **)** const |
  60. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  61. | :ref:`bool<class_bool>` | :ref:`is_bus_solo<class_AudioServer_method_is_bus_solo>` **(** :ref:`int<class_int>` bus_idx **)** const |
  62. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  63. | void | :ref:`lock<class_AudioServer_method_lock>` **(** **)** |
  64. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  65. | void | :ref:`move_bus<class_AudioServer_method_move_bus>` **(** :ref:`int<class_int>` index, :ref:`int<class_int>` to_index **)** |
  66. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  67. | void | :ref:`remove_bus<class_AudioServer_method_remove_bus>` **(** :ref:`int<class_int>` index **)** |
  68. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  69. | void | :ref:`remove_bus_effect<class_AudioServer_method_remove_bus_effect>` **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` effect_idx **)** |
  70. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  71. | void | :ref:`set_bus_bypass_effects<class_AudioServer_method_set_bus_bypass_effects>` **(** :ref:`int<class_int>` bus_idx, :ref:`bool<class_bool>` enable **)** |
  72. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  73. | void | :ref:`set_bus_count<class_AudioServer_method_set_bus_count>` **(** :ref:`int<class_int>` amount **)** |
  74. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  75. | void | :ref:`set_bus_effect_enabled<class_AudioServer_method_set_bus_effect_enabled>` **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` effect_idx, :ref:`bool<class_bool>` enabled **)** |
  76. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  77. | void | :ref:`set_bus_layout<class_AudioServer_method_set_bus_layout>` **(** :ref:`AudioBusLayout<class_AudioBusLayout>` bus_layout **)** |
  78. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  79. | void | :ref:`set_bus_mute<class_AudioServer_method_set_bus_mute>` **(** :ref:`int<class_int>` bus_idx, :ref:`bool<class_bool>` enable **)** |
  80. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  81. | void | :ref:`set_bus_name<class_AudioServer_method_set_bus_name>` **(** :ref:`int<class_int>` bus_idx, :ref:`String<class_String>` name **)** |
  82. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  83. | void | :ref:`set_bus_send<class_AudioServer_method_set_bus_send>` **(** :ref:`int<class_int>` bus_idx, :ref:`String<class_String>` send **)** |
  84. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  85. | void | :ref:`set_bus_solo<class_AudioServer_method_set_bus_solo>` **(** :ref:`int<class_int>` bus_idx, :ref:`bool<class_bool>` enable **)** |
  86. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  87. | void | :ref:`set_bus_volume_db<class_AudioServer_method_set_bus_volume_db>` **(** :ref:`int<class_int>` bus_idx, :ref:`float<class_float>` volume_db **)** |
  88. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  89. | void | :ref:`set_device<class_AudioServer_method_set_device>` **(** :ref:`String<class_String>` device **)** |
  90. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  91. | void | :ref:`swap_bus_effects<class_AudioServer_method_swap_bus_effects>` **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` effect_idx, :ref:`int<class_int>` by_effect_idx **)** |
  92. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  93. | void | :ref:`unlock<class_AudioServer_method_unlock>` **(** **)** |
  94. +--------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  95. Signals
  96. -------
  97. .. _class_AudioServer_signal_bus_layout_changed:
  98. - **bus_layout_changed** **(** **)**
  99. Emitted when the :ref:`AudioBusLayout<class_AudioBusLayout>` changes.
  100. Enumerations
  101. ------------
  102. .. _enum_AudioServer_SpeakerMode:
  103. .. _class_AudioServer_constant_SPEAKER_MODE_STEREO:
  104. .. _class_AudioServer_constant_SPEAKER_SURROUND_31:
  105. .. _class_AudioServer_constant_SPEAKER_SURROUND_51:
  106. .. _class_AudioServer_constant_SPEAKER_SURROUND_71:
  107. enum **SpeakerMode**:
  108. - **SPEAKER_MODE_STEREO** = **0** --- Two or fewer speakers are detected.
  109. - **SPEAKER_SURROUND_31** = **1**
  110. - **SPEAKER_SURROUND_51** = **2** --- A 5.1 channel surround setup detected.
  111. - **SPEAKER_SURROUND_71** = **3** --- A 7.1 channel surround setup detected.
  112. Description
  113. -----------
  114. 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.
  115. Tutorials
  116. ---------
  117. - :doc:`../tutorials/audio/audio_buses`
  118. Method Descriptions
  119. -------------------
  120. .. _class_AudioServer_method_add_bus:
  121. - void **add_bus** **(** :ref:`int<class_int>` at_position=-1 **)**
  122. Adds a bus at ``at_position``.
  123. .. _class_AudioServer_method_add_bus_effect:
  124. - void **add_bus_effect** **(** :ref:`int<class_int>` bus_idx, :ref:`AudioEffect<class_AudioEffect>` effect, :ref:`int<class_int>` at_position=-1 **)**
  125. Adds an :ref:`AudioEffect<class_AudioEffect>` effect to the bus ``bus_idx`` at ``at_position``.
  126. .. _class_AudioServer_method_capture_get_device:
  127. - :ref:`String<class_String>` **capture_get_device** **(** **)**
  128. .. _class_AudioServer_method_capture_get_device_list:
  129. - :ref:`Array<class_Array>` **capture_get_device_list** **(** **)**
  130. .. _class_AudioServer_method_capture_set_device:
  131. - void **capture_set_device** **(** :ref:`String<class_String>` name **)**
  132. .. _class_AudioServer_method_generate_bus_layout:
  133. - :ref:`AudioBusLayout<class_AudioBusLayout>` **generate_bus_layout** **(** **)** const
  134. Generates an :ref:`AudioBusLayout<class_AudioBusLayout>` using the available busses and effects.
  135. .. _class_AudioServer_method_get_bus_channels:
  136. - :ref:`int<class_int>` **get_bus_channels** **(** :ref:`int<class_int>` bus_idx **)** const
  137. Returns the amount of channels of the bus at index ``bus_idx``.
  138. .. _class_AudioServer_method_get_bus_count:
  139. - :ref:`int<class_int>` **get_bus_count** **(** **)** const
  140. Returns the number of available busses.
  141. .. _class_AudioServer_method_get_bus_effect:
  142. - :ref:`AudioEffect<class_AudioEffect>` **get_bus_effect** **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` effect_idx **)**
  143. Returns the :ref:`AudioEffect<class_AudioEffect>` at position ``effect_idx`` in bus ``bus_idx``.
  144. .. _class_AudioServer_method_get_bus_effect_count:
  145. - :ref:`int<class_int>` **get_bus_effect_count** **(** :ref:`int<class_int>` bus_idx **)**
  146. Returns the number of effects on the bus at ``bus_idx``.
  147. .. _class_AudioServer_method_get_bus_index:
  148. - :ref:`int<class_int>` **get_bus_index** **(** :ref:`String<class_String>` bus_name **)** const
  149. Returns the index of the bus with the name ``bus_name``.
  150. .. _class_AudioServer_method_get_bus_name:
  151. - :ref:`String<class_String>` **get_bus_name** **(** :ref:`int<class_int>` bus_idx **)** const
  152. Returns the name of the bus with the index ``bus_idx``.
  153. .. _class_AudioServer_method_get_bus_peak_volume_left_db:
  154. - :ref:`float<class_float>` **get_bus_peak_volume_left_db** **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` channel **)** const
  155. Returns the peak volume of the left speaker at bus index ``bus_idx`` and channel index ``channel``.
  156. .. _class_AudioServer_method_get_bus_peak_volume_right_db:
  157. - :ref:`float<class_float>` **get_bus_peak_volume_right_db** **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` channel **)** const
  158. Returns the peak volume of the right speaker at bus index ``bus_idx`` and channel index ``channel``.
  159. .. _class_AudioServer_method_get_bus_send:
  160. - :ref:`String<class_String>` **get_bus_send** **(** :ref:`int<class_int>` bus_idx **)** const
  161. Returns the name of the bus that the bus at index ``bus_idx`` sends to.
  162. .. _class_AudioServer_method_get_bus_volume_db:
  163. - :ref:`float<class_float>` **get_bus_volume_db** **(** :ref:`int<class_int>` bus_idx **)** const
  164. Returns the volume of the bus at index ``bus_idx`` in dB.
  165. .. _class_AudioServer_method_get_device:
  166. - :ref:`String<class_String>` **get_device** **(** **)**
  167. .. _class_AudioServer_method_get_device_list:
  168. - :ref:`Array<class_Array>` **get_device_list** **(** **)**
  169. .. _class_AudioServer_method_get_mix_rate:
  170. - :ref:`float<class_float>` **get_mix_rate** **(** **)** const
  171. Returns the sample rate at the output of the audioserver.
  172. .. _class_AudioServer_method_get_speaker_mode:
  173. - :ref:`SpeakerMode<enum_AudioServer_SpeakerMode>` **get_speaker_mode** **(** **)** const
  174. Returns the speaker configuration.
  175. .. _class_AudioServer_method_is_bus_bypassing_effects:
  176. - :ref:`bool<class_bool>` **is_bus_bypassing_effects** **(** :ref:`int<class_int>` bus_idx **)** const
  177. If ``true``, the bus at index ``bus_idx`` is bypassing effects.
  178. .. _class_AudioServer_method_is_bus_effect_enabled:
  179. - :ref:`bool<class_bool>` **is_bus_effect_enabled** **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` effect_idx **)** const
  180. If ``true``, the effect at index ``effect_idx`` on the bus at index ``bus_idx`` is enabled.
  181. .. _class_AudioServer_method_is_bus_mute:
  182. - :ref:`bool<class_bool>` **is_bus_mute** **(** :ref:`int<class_int>` bus_idx **)** const
  183. If ``true``, the bus at index ``bus_idx`` is muted.
  184. .. _class_AudioServer_method_is_bus_solo:
  185. - :ref:`bool<class_bool>` **is_bus_solo** **(** :ref:`int<class_int>` bus_idx **)** const
  186. If ``true``, the bus at index ``bus_idx`` is in solo mode.
  187. .. _class_AudioServer_method_lock:
  188. - void **lock** **(** **)**
  189. Locks the audio drivers mainloop. Remember to unlock it afterwards.
  190. .. _class_AudioServer_method_move_bus:
  191. - void **move_bus** **(** :ref:`int<class_int>` index, :ref:`int<class_int>` to_index **)**
  192. Moves the bus from index ``index`` to index ``to_index``.
  193. .. _class_AudioServer_method_remove_bus:
  194. - void **remove_bus** **(** :ref:`int<class_int>` index **)**
  195. Removes the bus at index ``index``.
  196. .. _class_AudioServer_method_remove_bus_effect:
  197. - void **remove_bus_effect** **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` effect_idx **)**
  198. Removes the effect at index ``effect_idx`` from the bus at index ``bus_idx``.
  199. .. _class_AudioServer_method_set_bus_bypass_effects:
  200. - void **set_bus_bypass_effects** **(** :ref:`int<class_int>` bus_idx, :ref:`bool<class_bool>` enable **)**
  201. If ``true``, the bus at index ``bus_idx`` is bypassing effects.
  202. .. _class_AudioServer_method_set_bus_count:
  203. - void **set_bus_count** **(** :ref:`int<class_int>` amount **)**
  204. Adds and removes busses to make the number of busses match ``amount``.
  205. .. _class_AudioServer_method_set_bus_effect_enabled:
  206. - void **set_bus_effect_enabled** **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` effect_idx, :ref:`bool<class_bool>` enabled **)**
  207. If ``true``, the effect at index ``effect_idx`` on the bus at index ``bus_idx`` is enabled.
  208. .. _class_AudioServer_method_set_bus_layout:
  209. - void **set_bus_layout** **(** :ref:`AudioBusLayout<class_AudioBusLayout>` bus_layout **)**
  210. Overwrites the currently used :ref:`AudioBusLayout<class_AudioBusLayout>`.
  211. .. _class_AudioServer_method_set_bus_mute:
  212. - void **set_bus_mute** **(** :ref:`int<class_int>` bus_idx, :ref:`bool<class_bool>` enable **)**
  213. If ``true``, the bus at index ``bus_idx`` is muted.
  214. .. _class_AudioServer_method_set_bus_name:
  215. - void **set_bus_name** **(** :ref:`int<class_int>` bus_idx, :ref:`String<class_String>` name **)**
  216. Sets the name of the bus at index ``bus_idx`` to ``name``.
  217. .. _class_AudioServer_method_set_bus_send:
  218. - void **set_bus_send** **(** :ref:`int<class_int>` bus_idx, :ref:`String<class_String>` send **)**
  219. Connects the output of the bus at ``bus_idx`` to the bus named ``send``.
  220. .. _class_AudioServer_method_set_bus_solo:
  221. - void **set_bus_solo** **(** :ref:`int<class_int>` bus_idx, :ref:`bool<class_bool>` enable **)**
  222. If ``true``, the bus at index ``bus_idx`` is in solo mode.
  223. .. _class_AudioServer_method_set_bus_volume_db:
  224. - void **set_bus_volume_db** **(** :ref:`int<class_int>` bus_idx, :ref:`float<class_float>` volume_db **)**
  225. Sets the volume of the bus at index ``bus_idx`` to ``volume_db``.
  226. .. _class_AudioServer_method_set_device:
  227. - void **set_device** **(** :ref:`String<class_String>` device **)**
  228. .. _class_AudioServer_method_swap_bus_effects:
  229. - void **swap_bus_effects** **(** :ref:`int<class_int>` bus_idx, :ref:`int<class_int>` effect_idx, :ref:`int<class_int>` by_effect_idx **)**
  230. Swaps the position of two effects in bus ``bus_idx``.
  231. .. _class_AudioServer_method_unlock:
  232. - void **unlock** **(** **)**
  233. Unlocks the audiodriver's main loop. After locking it always unlock it.