A class encapsulating a group of AudioProcessorParameters and nested AudioProcessorParameterGroups. More...
Classes | |
class | AudioProcessorParameterNode |
A child of an AudioProcessorParameterGroup. More... | |
Public Member Functions | |
AudioProcessorParameterGroup () | |
Creates an empty AudioProcessorParameterGroup with no name or ID. | |
AudioProcessorParameterGroup (String groupID, String groupName, String subgroupSeparator) | |
Creates an empty AudioProcessorParameterGroup. | |
template<typename ParameterOrGroup> | |
AudioProcessorParameterGroup (String groupID, String groupName, String subgroupSeparator, std::unique_ptr< ParameterOrGroup > child) | |
Creates an AudioProcessorParameterGroup with a single child. | |
template<typename ParameterOrGroup, typename... Args> | |
AudioProcessorParameterGroup (String groupID, String groupName, String subgroupSeparator, std::unique_ptr< ParameterOrGroup > firstChild, Args &&... remainingChildren) | |
Creates an AudioProcessorParameterGroup with multiple children. | |
AudioProcessorParameterGroup (AudioProcessorParameterGroup &&) | |
Once a group has been added to an AudioProcessor don't try to mutate it by moving or swapping it - this will crash most hosts. | |
AudioProcessorParameterGroup & | operator= (AudioProcessorParameterGroup &&) |
Once a group has been added to an AudioProcessor don't try to mutate it by moving or swapping it - this will crash most hosts. | |
~AudioProcessorParameterGroup () | |
Destructor. | |
String | getID () const |
Returns the group's ID. | |
String | getName () const |
Returns the group's name. | |
String | getSeparator () const |
Returns the group's separator string. | |
const AudioProcessorParameterGroup * | getParent () const noexcept |
Returns the parent of the group, or nullptr if this is a top-level group. | |
void | setName (String newName) |
Changes the name of the group. | |
const AudioProcessorParameterNode *const * | begin () const noexcept |
const AudioProcessorParameterNode *const * | end () const noexcept |
Array< const AudioProcessorParameterGroup * > | getSubgroups (bool recursive) const |
Returns all subgroups of this group. | |
Array< AudioProcessorParameter * > | getParameters (bool recursive) const |
Returns all the parameters in this group. | |
Array< const AudioProcessorParameterGroup * > | getGroupsForParameter (AudioProcessorParameter *) const |
Searches this group recursively for a parameter and returns a depth ordered list of the groups it belongs to. | |
template<typename ParameterOrGroup> | |
void | addChild (std::unique_ptr< ParameterOrGroup > child) |
Adds a child to the group. | |
template<typename ParameterOrGroup, typename... Args> | |
void | addChild (std::unique_ptr< ParameterOrGroup > firstChild, Args &&... remainingChildren) |
Adds multiple parameters or sub-groups to this group. | |
A class encapsulating a group of AudioProcessorParameters and nested AudioProcessorParameterGroups.
This class is predominantly write-only; there are methods for adding group members but none for removing them. Ultimately you will probably want to add a fully constructed group to an AudioProcessor.
AudioProcessorParameterGroup::AudioProcessorParameterGroup | ( | ) |
Creates an empty AudioProcessorParameterGroup with no name or ID.
Referenced by AudioProcessorParameterGroup(), AudioProcessorParameterGroup(), AudioProcessorParameterGroup(), getGroupsForParameter(), getParent(), getSubgroups(), and operator=().
AudioProcessorParameterGroup::AudioProcessorParameterGroup | ( | String | groupID, |
String | groupName, | ||
String | subgroupSeparator ) |
Creates an empty AudioProcessorParameterGroup.
groupID | A unique identifier for the group. Keep it basic; don't use any special characters like "." and avoid pure integer strings which could collide with legacy parameter IDs. |
groupName | The group's name, which will be displayed in the host. |
subgroupSeparator | A separator string to use between the name of this group and the name of any subgroups if this group is flattened. AUv3 and VST3 plug-ins can have multiple layers of nested subgroups, but AU plug-ins cannot have any subgroups. |
AudioProcessorParameterGroup::AudioProcessorParameterGroup | ( | String | groupID, |
String | groupName, | ||
String | subgroupSeparator, | ||
std::unique_ptr< ParameterOrGroup > | child ) |
Creates an AudioProcessorParameterGroup with a single child.
groupID | A unique identifier for the group. Keep it basic; don't use any special characters like "." and avoid pure integer strings which could collide with legacy parameter IDs. |
groupName | The group's name, which will be displayed in the host. |
subgroupSeparator | A separator string to use between the name of this group and the name of any subgroups if this group is flattened. AUv3 and VST3 plug-ins can have multiple layers of nested subgroups, but AU plug-ins cannot have any subgroups. |
child | An AudioProcessorParameter or an AudioProcessorParameterGroup to add to the group. |
References addChild(), and AudioProcessorParameterGroup().
AudioProcessorParameterGroup::AudioProcessorParameterGroup | ( | String | groupID, |
String | groupName, | ||
String | subgroupSeparator, | ||
std::unique_ptr< ParameterOrGroup > | firstChild, | ||
Args &&... | remainingChildren ) |
Creates an AudioProcessorParameterGroup with multiple children.
groupID | A unique identifier for the group. Keep it basic; don't use any special characters like "." and avoid pure integer strings which could collide with legacy parameter IDs. |
groupName | The group's name, which will be displayed in the host. |
subgroupSeparator | A separator string to use between the name of this group and the name of any subgroups if this group is flattened. AUv3 and VST3 plug-ins can have multiple layers of nested subgroups, but AU plug-ins cannot have any subgroups. |
firstChild | An AudioProcessorParameter or an AudioProcessorParameterGroup to add to the group. |
remainingChildren | A list of more AudioProcessorParameters or AudioProcessorParameterGroups to add to the group. |
References addChild(), and AudioProcessorParameterGroup().
AudioProcessorParameterGroup::AudioProcessorParameterGroup | ( | AudioProcessorParameterGroup && | ) |
Once a group has been added to an AudioProcessor don't try to mutate it by moving or swapping it - this will crash most hosts.
References AudioProcessorParameterGroup().
AudioProcessorParameterGroup::~AudioProcessorParameterGroup | ( | ) |
Destructor.
AudioProcessorParameterGroup & AudioProcessorParameterGroup::operator= | ( | AudioProcessorParameterGroup && | ) |
Once a group has been added to an AudioProcessor don't try to mutate it by moving or swapping it - this will crash most hosts.
References AudioProcessorParameterGroup().
String AudioProcessorParameterGroup::getID | ( | ) | const |
Returns the group's ID.
String AudioProcessorParameterGroup::getName | ( | ) | const |
Returns the group's name.
String AudioProcessorParameterGroup::getSeparator | ( | ) | const |
Returns the group's separator string.
|
noexcept |
Returns the parent of the group, or nullptr if this is a top-level group.
References AudioProcessorParameterGroup().
void AudioProcessorParameterGroup::setName | ( | String | newName | ) |
Changes the name of the group.
If you do this after the group has been added to an AudioProcessor, call updateHostDisplay() to inform the host of the change. Not all hosts support dynamic group name changes.
References setName().
Referenced by setName().
|
noexcept |
|
noexcept |
Array< const AudioProcessorParameterGroup * > AudioProcessorParameterGroup::getSubgroups | ( | bool | recursive | ) | const |
Returns all subgroups of this group.
recursive | If this is true then this method will fetch all nested subgroups using a depth first search. |
References AudioProcessorParameterGroup(), and getSubgroups().
Referenced by getSubgroups().
Array< AudioProcessorParameter * > AudioProcessorParameterGroup::getParameters | ( | bool | recursive | ) | const |
Returns all the parameters in this group.
recursive | If this is true then this method will fetch all nested parameters using a depth first search. |
References getParameters().
Referenced by getParameters().
Array< const AudioProcessorParameterGroup * > AudioProcessorParameterGroup::getGroupsForParameter | ( | AudioProcessorParameter * | ) | const |
Searches this group recursively for a parameter and returns a depth ordered list of the groups it belongs to.
References AudioProcessorParameterGroup(), and getGroupsForParameter().
Referenced by getGroupsForParameter().
void AudioProcessorParameterGroup::addChild | ( | std::unique_ptr< ParameterOrGroup > | child | ) |
Adds a child to the group.
Do not add children to a group which has itself already been added to the AudioProcessor - the new elements will be ignored.
References addChild().
Referenced by addChild(), addChild(), AudioProcessorParameterGroup(), and AudioProcessorParameterGroup().
void AudioProcessorParameterGroup::addChild | ( | std::unique_ptr< ParameterOrGroup > | firstChild, |
Args &&... | remainingChildren ) |
Adds multiple parameters or sub-groups to this group.
Do not add children to a group which has itself already been added to the AudioProcessor - the new elements will be ignored.
References addChild().