class_audioeffectcapture.rst 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. :github_url: hide
  2. .. Generated automatically by doc/tools/make_rst.py in Godot's source tree.
  3. .. DO NOT EDIT THIS FILE, but the AudioEffectCapture.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_AudioEffectCapture:
  6. AudioEffectCapture
  7. ==================
  8. **Inherits:** :ref:`AudioEffect<class_AudioEffect>` **<** :ref:`Resource<class_Resource>` **<** :ref:`Reference<class_Reference>` **<** :ref:`Object<class_Object>`
  9. Captures audio from an audio bus in real-time.
  10. Description
  11. -----------
  12. AudioEffectCapture is an AudioEffect which copies all audio frames from the attached audio effect bus into its internal ring buffer.
  13. Application code should consume these audio frames from this ring buffer using :ref:`get_buffer<class_AudioEffectCapture_method_get_buffer>` and process it as needed, for example to capture data from a microphone, implement application defined effects, or to transmit audio over the network. When capturing audio data from a microphone, the format of the samples will be stereo 32-bit floating point PCM.
  14. Properties
  15. ----------
  16. +---------------------------+-----------------------------------------------------------------------+---------+
  17. | :ref:`float<class_float>` | :ref:`buffer_length<class_AudioEffectCapture_property_buffer_length>` | ``0.1`` |
  18. +---------------------------+-----------------------------------------------------------------------+---------+
  19. Methods
  20. -------
  21. +-------------------------------------------------+------------------------------------------------------------------------------------------------------------------------+
  22. | :ref:`bool<class_bool>` | :ref:`can_get_buffer<class_AudioEffectCapture_method_can_get_buffer>` **(** :ref:`int<class_int>` frames **)** |const| |
  23. +-------------------------------------------------+------------------------------------------------------------------------------------------------------------------------+
  24. | void | :ref:`clear_buffer<class_AudioEffectCapture_method_clear_buffer>` **(** **)** |
  25. +-------------------------------------------------+------------------------------------------------------------------------------------------------------------------------+
  26. | :ref:`PoolVector2Array<class_PoolVector2Array>` | :ref:`get_buffer<class_AudioEffectCapture_method_get_buffer>` **(** :ref:`int<class_int>` frames **)** |
  27. +-------------------------------------------------+------------------------------------------------------------------------------------------------------------------------+
  28. | :ref:`int<class_int>` | :ref:`get_buffer_length_frames<class_AudioEffectCapture_method_get_buffer_length_frames>` **(** **)** |const| |
  29. +-------------------------------------------------+------------------------------------------------------------------------------------------------------------------------+
  30. | :ref:`int<class_int>` | :ref:`get_discarded_frames<class_AudioEffectCapture_method_get_discarded_frames>` **(** **)** |const| |
  31. +-------------------------------------------------+------------------------------------------------------------------------------------------------------------------------+
  32. | :ref:`int<class_int>` | :ref:`get_frames_available<class_AudioEffectCapture_method_get_frames_available>` **(** **)** |const| |
  33. +-------------------------------------------------+------------------------------------------------------------------------------------------------------------------------+
  34. | :ref:`int<class_int>` | :ref:`get_pushed_frames<class_AudioEffectCapture_method_get_pushed_frames>` **(** **)** |const| |
  35. +-------------------------------------------------+------------------------------------------------------------------------------------------------------------------------+
  36. Property Descriptions
  37. ---------------------
  38. .. _class_AudioEffectCapture_property_buffer_length:
  39. - :ref:`float<class_float>` **buffer_length**
  40. +-----------+--------------------------+
  41. | *Default* | ``0.1`` |
  42. +-----------+--------------------------+
  43. | *Setter* | set_buffer_length(value) |
  44. +-----------+--------------------------+
  45. | *Getter* | get_buffer_length() |
  46. +-----------+--------------------------+
  47. Length of the internal ring buffer, in seconds. Setting the buffer length will have no effect if already initialized.
  48. Method Descriptions
  49. -------------------
  50. .. _class_AudioEffectCapture_method_can_get_buffer:
  51. - :ref:`bool<class_bool>` **can_get_buffer** **(** :ref:`int<class_int>` frames **)** |const|
  52. Returns ``true`` if at least ``frames`` audio frames are available to read in the internal ring buffer.
  53. ----
  54. .. _class_AudioEffectCapture_method_clear_buffer:
  55. - void **clear_buffer** **(** **)**
  56. Clears the internal ring buffer.
  57. ----
  58. .. _class_AudioEffectCapture_method_get_buffer:
  59. - :ref:`PoolVector2Array<class_PoolVector2Array>` **get_buffer** **(** :ref:`int<class_int>` frames **)**
  60. Gets the next ``frames`` audio samples from the internal ring buffer.
  61. Returns a :ref:`PoolVector2Array<class_PoolVector2Array>` containing exactly ``frames`` audio samples if available, or an empty :ref:`PoolVector2Array<class_PoolVector2Array>` if insufficient data was available.
  62. ----
  63. .. _class_AudioEffectCapture_method_get_buffer_length_frames:
  64. - :ref:`int<class_int>` **get_buffer_length_frames** **(** **)** |const|
  65. Returns the total size of the internal ring buffer in frames.
  66. ----
  67. .. _class_AudioEffectCapture_method_get_discarded_frames:
  68. - :ref:`int<class_int>` **get_discarded_frames** **(** **)** |const|
  69. Returns the number of audio frames discarded from the audio bus due to full buffer.
  70. ----
  71. .. _class_AudioEffectCapture_method_get_frames_available:
  72. - :ref:`int<class_int>` **get_frames_available** **(** **)** |const|
  73. Returns the number of frames available to read using :ref:`get_buffer<class_AudioEffectCapture_method_get_buffer>`.
  74. ----
  75. .. _class_AudioEffectCapture_method_get_pushed_frames:
  76. - :ref:`int<class_int>` **get_pushed_frames** **(** **)** |const|
  77. Returns the number of audio frames inserted from the audio bus.
  78. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  79. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  80. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`