123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- :github_url: hide
- .. DO NOT EDIT THIS FILE!!!
- .. Generated automatically from Godot engine sources.
- .. Generator: https://github.com/godotengine/godot/tree/master/doc/tools/make_rst.py.
- .. XML source: https://github.com/godotengine/godot/tree/master/doc/classes/AudioEffectCompressor.xml.
- .. _class_AudioEffectCompressor:
- AudioEffectCompressor
- =====================
- **Inherits:** :ref:`AudioEffect<class_AudioEffect>` **<** :ref:`Resource<class_Resource>` **<** :ref:`RefCounted<class_RefCounted>` **<** :ref:`Object<class_Object>`
- Adds a compressor audio effect to an audio bus.
- Reduces sounds that exceed a certain threshold level, smooths out the dynamics and increases the overall volume.
- .. rst-class:: classref-introduction-group
- Description
- -----------
- Dynamic range compressor reduces the level of the sound when the amplitude goes over a certain threshold in Decibels. One of the main uses of a compressor is to increase the dynamic range by clipping as little as possible (when sound goes over 0dB).
- Compressor has many uses in the mix:
- - In the Master bus to compress the whole output (although an :ref:`AudioEffectLimiter<class_AudioEffectLimiter>` is probably better).
- - In voice channels to ensure they sound as balanced as possible.
- - Sidechained. This can reduce the sound level sidechained with another audio bus for threshold detection. This technique is common in video game mixing to the level of music and SFX while voices are being heard.
- - Accentuates transients by using a wider attack, making effects sound more punchy.
- .. rst-class:: classref-introduction-group
- Tutorials
- ---------
- - :doc:`Audio buses <../tutorials/audio/audio_buses>`
- .. rst-class:: classref-reftable-group
- Properties
- ----------
- .. table::
- :widths: auto
- +-------------------------------------+--------------------------------------------------------------------+-----------+
- | :ref:`float<class_float>` | :ref:`attack_us<class_AudioEffectCompressor_property_attack_us>` | ``20.0`` |
- +-------------------------------------+--------------------------------------------------------------------+-----------+
- | :ref:`float<class_float>` | :ref:`gain<class_AudioEffectCompressor_property_gain>` | ``0.0`` |
- +-------------------------------------+--------------------------------------------------------------------+-----------+
- | :ref:`float<class_float>` | :ref:`mix<class_AudioEffectCompressor_property_mix>` | ``1.0`` |
- +-------------------------------------+--------------------------------------------------------------------+-----------+
- | :ref:`float<class_float>` | :ref:`ratio<class_AudioEffectCompressor_property_ratio>` | ``4.0`` |
- +-------------------------------------+--------------------------------------------------------------------+-----------+
- | :ref:`float<class_float>` | :ref:`release_ms<class_AudioEffectCompressor_property_release_ms>` | ``250.0`` |
- +-------------------------------------+--------------------------------------------------------------------+-----------+
- | :ref:`StringName<class_StringName>` | :ref:`sidechain<class_AudioEffectCompressor_property_sidechain>` | ``&""`` |
- +-------------------------------------+--------------------------------------------------------------------+-----------+
- | :ref:`float<class_float>` | :ref:`threshold<class_AudioEffectCompressor_property_threshold>` | ``0.0`` |
- +-------------------------------------+--------------------------------------------------------------------+-----------+
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Property Descriptions
- ---------------------
- .. _class_AudioEffectCompressor_property_attack_us:
- .. rst-class:: classref-property
- :ref:`float<class_float>` **attack_us** = ``20.0`` :ref:`🔗<class_AudioEffectCompressor_property_attack_us>`
- .. rst-class:: classref-property-setget
- - |void| **set_attack_us**\ (\ value\: :ref:`float<class_float>`\ )
- - :ref:`float<class_float>` **get_attack_us**\ (\ )
- Compressor's reaction time when the signal exceeds the threshold, in microseconds. Value can range from 20 to 2000.
- .. rst-class:: classref-item-separator
- ----
- .. _class_AudioEffectCompressor_property_gain:
- .. rst-class:: classref-property
- :ref:`float<class_float>` **gain** = ``0.0`` :ref:`🔗<class_AudioEffectCompressor_property_gain>`
- .. rst-class:: classref-property-setget
- - |void| **set_gain**\ (\ value\: :ref:`float<class_float>`\ )
- - :ref:`float<class_float>` **get_gain**\ (\ )
- Gain applied to the output signal.
- .. rst-class:: classref-item-separator
- ----
- .. _class_AudioEffectCompressor_property_mix:
- .. rst-class:: classref-property
- :ref:`float<class_float>` **mix** = ``1.0`` :ref:`🔗<class_AudioEffectCompressor_property_mix>`
- .. rst-class:: classref-property-setget
- - |void| **set_mix**\ (\ value\: :ref:`float<class_float>`\ )
- - :ref:`float<class_float>` **get_mix**\ (\ )
- Balance between original signal and effect signal. Value can range from 0 (totally dry) to 1 (totally wet).
- .. rst-class:: classref-item-separator
- ----
- .. _class_AudioEffectCompressor_property_ratio:
- .. rst-class:: classref-property
- :ref:`float<class_float>` **ratio** = ``4.0`` :ref:`🔗<class_AudioEffectCompressor_property_ratio>`
- .. rst-class:: classref-property-setget
- - |void| **set_ratio**\ (\ value\: :ref:`float<class_float>`\ )
- - :ref:`float<class_float>` **get_ratio**\ (\ )
- Amount of compression applied to the audio once it passes the threshold level. The higher the ratio, the more the loud parts of the audio will be compressed. Value can range from 1 to 48.
- .. rst-class:: classref-item-separator
- ----
- .. _class_AudioEffectCompressor_property_release_ms:
- .. rst-class:: classref-property
- :ref:`float<class_float>` **release_ms** = ``250.0`` :ref:`🔗<class_AudioEffectCompressor_property_release_ms>`
- .. rst-class:: classref-property-setget
- - |void| **set_release_ms**\ (\ value\: :ref:`float<class_float>`\ )
- - :ref:`float<class_float>` **get_release_ms**\ (\ )
- Compressor's delay time to stop reducing the signal after the signal level falls below the threshold, in milliseconds. Value can range from 20 to 2000.
- .. rst-class:: classref-item-separator
- ----
- .. _class_AudioEffectCompressor_property_sidechain:
- .. rst-class:: classref-property
- :ref:`StringName<class_StringName>` **sidechain** = ``&""`` :ref:`🔗<class_AudioEffectCompressor_property_sidechain>`
- .. rst-class:: classref-property-setget
- - |void| **set_sidechain**\ (\ value\: :ref:`StringName<class_StringName>`\ )
- - :ref:`StringName<class_StringName>` **get_sidechain**\ (\ )
- Reduce the sound level using another audio bus for threshold detection.
- .. rst-class:: classref-item-separator
- ----
- .. _class_AudioEffectCompressor_property_threshold:
- .. rst-class:: classref-property
- :ref:`float<class_float>` **threshold** = ``0.0`` :ref:`🔗<class_AudioEffectCompressor_property_threshold>`
- .. rst-class:: classref-property-setget
- - |void| **set_threshold**\ (\ value\: :ref:`float<class_float>`\ )
- - :ref:`float<class_float>` **get_threshold**\ (\ )
- The level above which compression is applied to the audio. Value can range from -60 to 0.
- .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
- .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
- .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`
- .. |constructor| replace:: :abbr:`constructor (This method is used to construct a type.)`
- .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`
- .. |operator| replace:: :abbr:`operator (This method describes a valid operator to use with this type as left-hand operand.)`
- .. |bitfield| replace:: :abbr:`BitField (This value is an integer composed as a bitmask of the following flags.)`
- .. |void| replace:: :abbr:`void (No return value.)`
|