class_audiostreamgenerator.rst 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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 AudioStreamGenerator.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_AudioStreamGenerator:
  6. AudioStreamGenerator
  7. ====================
  8. **Inherits:** :ref:`AudioStream<class_AudioStream>` **<** :ref:`Resource<class_Resource>` **<** :ref:`Reference<class_Reference>` **<** :ref:`Object<class_Object>`
  9. Audio stream that generates sounds procedurally.
  10. Description
  11. -----------
  12. This audio stream does not play back sounds, but expects a script to generate audio data for it instead. See also :ref:`AudioStreamGeneratorPlayback<class_AudioStreamGeneratorPlayback>`.
  13. See also :ref:`AudioEffectSpectrumAnalyzer<class_AudioEffectSpectrumAnalyzer>` for performing real-time audio spectrum analysis.
  14. **Note:** Due to performance constraints, this class is best used from C# or from a compiled language via GDNative. If you still want to use this class from GDScript, consider using a lower :ref:`mix_rate<class_AudioStreamGenerator_property_mix_rate>` such as 11,025 Hz or 22,050 Hz.
  15. Tutorials
  16. ---------
  17. - `Audio Generator Demo <https://godotengine.org/asset-library/asset/526>`__
  18. - `Godot 3.2 will get new audio features <https://godotengine.org/article/godot-32-will-get-new-audio-features>`__
  19. Properties
  20. ----------
  21. +---------------------------+-------------------------------------------------------------------------+-------------+
  22. | :ref:`float<class_float>` | :ref:`buffer_length<class_AudioStreamGenerator_property_buffer_length>` | ``0.5`` |
  23. +---------------------------+-------------------------------------------------------------------------+-------------+
  24. | :ref:`float<class_float>` | :ref:`mix_rate<class_AudioStreamGenerator_property_mix_rate>` | ``44100.0`` |
  25. +---------------------------+-------------------------------------------------------------------------+-------------+
  26. Property Descriptions
  27. ---------------------
  28. .. _class_AudioStreamGenerator_property_buffer_length:
  29. - :ref:`float<class_float>` **buffer_length**
  30. +-----------+--------------------------+
  31. | *Default* | ``0.5`` |
  32. +-----------+--------------------------+
  33. | *Setter* | set_buffer_length(value) |
  34. +-----------+--------------------------+
  35. | *Getter* | get_buffer_length() |
  36. +-----------+--------------------------+
  37. The length of the buffer to generate (in seconds). Lower values result in less latency, but require the script to generate audio data faster, resulting in increased CPU usage and more risk for audio cracking if the CPU can't keep up.
  38. ----
  39. .. _class_AudioStreamGenerator_property_mix_rate:
  40. - :ref:`float<class_float>` **mix_rate**
  41. +-----------+---------------------+
  42. | *Default* | ``44100.0`` |
  43. +-----------+---------------------+
  44. | *Setter* | set_mix_rate(value) |
  45. +-----------+---------------------+
  46. | *Getter* | get_mix_rate() |
  47. +-----------+---------------------+
  48. The sample rate to use (in Hz). Higher values are more demanding for the CPU to generate, but result in better quality.
  49. In games, common sample rates in use are ``11025``, ``16000``, ``22050``, ``32000``, ``44100``, and ``48000``.
  50. According to the `Nyquist-Shannon sampling theorem <https://en.wikipedia.org/wiki/Nyquist%E2%80%93Shannon_sampling_theorem>`__, there is no quality difference to human hearing when going past 40,000 Hz (since most humans can only hear up to ~20,000 Hz, often less). If you are generating lower-pitched sounds such as voices, lower sample rates such as ``32000`` or ``22050`` may be usable with no loss in quality.
  51. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  52. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  53. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`