Audacity 3.2.0
|
Base class for many of the effects in Audacity. More...
#include <Effect.h>
Public Member Functions | |
Effect () | |
virtual | ~Effect () |
PluginPath | GetPath () const override |
bool | VisitSettings (SettingsVisitor &visitor, EffectSettings &settings) override |
bool | VisitSettings (ConstSettingsVisitor &visitor, const EffectSettings &settings) const override |
ComponentInterfaceSymbol | GetSymbol () const override |
VendorSymbol | GetVendor () const override |
wxString | GetVersion () const override |
TranslatableString | GetDescription () const override |
EffectFamilySymbol | GetFamily () const override |
Report identifier and user-visible name of the effect protocol. More... | |
bool | IsInteractive () const override |
Whether the effect needs a dialog for entry of settings. More... | |
bool | IsDefault () const override |
Whether the effect sorts "above the line" in the menus. More... | |
RealtimeSince | RealtimeSupport () const override |
Since which version of Audacity has the effect supported realtime? More... | |
bool | SupportsAutomation () const override |
Whether the effect has any automatable controls. More... | |
bool | SaveSettings (const EffectSettings &settings, CommandParameters &parms) const override |
Store settings as keys and values. More... | |
bool | LoadSettings (const CommandParameters &parms, EffectSettings &settings) const override |
Restore settings from keys and values. More... | |
OptionalMessage | LoadUserPreset (const RegistryPath &name, EffectSettings &settings) const override |
bool | SaveUserPreset (const RegistryPath &name, const EffectSettings &settings) const override |
Save settings in the configuration file as a user-named preset. More... | |
RegistryPaths | GetFactoryPresets () const override |
Report names of factory presets. More... | |
OptionalMessage | LoadFactoryPreset (int id, EffectSettings &settings) const override |
OptionalMessage | LoadFactoryDefaults (EffectSettings &settings) const override |
virtual const EffectParameterMethods & | Parameters () const |
bool | CanExportPresets () const override |
Whether the effect supports export of presets to files, and importing too. More... | |
bool | HasOptions () const override |
const EffectSettingsManager & | GetDefinition () const override |
virtual NumericFormatID | GetSelectionFormat () |
bool | SaveSettingsAsString (const EffectSettings &settings, wxString &parms) const override |
OptionalMessage | LoadSettingsFromString (const wxString &parms, EffectSettings &settings) const override |
bool | IsBatchProcessing () const override |
void | SetBatchProcessing () override |
void | UnsetBatchProcessing () override |
unsigned | TestUIFlags (unsigned mask) |
bool | Delegate (Effect &delegate, EffectSettings &settings, InstanceFinder finder={}) |
Re-invoke DoEffect on another Effect object that implements the work. More... | |
Public Member Functions inherited from EffectBase | |
EffectBase () | |
~EffectBase () override | |
bool | IsLinearEffect () const |
bool | PreviewsFullSelection () const |
void | SetTracks (TrackList *pTracks) |
double | GetDefaultDuration () |
virtual std::any | BeginPreview (const EffectSettings &settings) |
Called when Preview() starts, to allow temporary effect state changes. More... | |
bool | DoEffect (EffectSettings &settings, const InstanceFinder &finder, double projectRate, TrackList *list, WaveTrackFactory *factory, NotifyingSelectedRegion &selectedRegion, unsigned flags, const EffectSettingsAccessPtr &pAccess) override |
virtual double | CalcPreviewInputLength (const EffectSettings &settings, double previewLength) const =0 |
void | CountWaveTracks () |
Public Member Functions inherited from EffectPlugin | |
EffectPlugin & | operator= (EffectPlugin &)=delete |
virtual | ~EffectPlugin () |
virtual bool | HasOptions () const =0 |
virtual bool | CanExportPresets () const =0 |
Whether the effect supports export of presets to files, and importing too. More... | |
virtual const EffectSettingsManager & | GetDefinition () const =0 |
virtual bool | SaveSettingsAsString (const EffectSettings &settings, wxString &parms) const =0 |
virtual OptionalMessage | LoadSettingsFromString (const wxString &parms, EffectSettings &settings) const =0 |
virtual bool | IsBatchProcessing () const =0 |
virtual void | SetBatchProcessing ()=0 |
virtual void | UnsetBatchProcessing ()=0 |
virtual bool | DoEffect (EffectSettings &settings, const InstanceFinder &finder, double projectRate, TrackList *list, WaveTrackFactory *factory, NotifyingSelectedRegion &selectedRegion, unsigned flags, const EffectSettingsAccessPtr &pAccess=nullptr)=0 |
Public Member Functions inherited from EffectInstanceFactory | |
virtual | ~EffectInstanceFactory () |
virtual std::shared_ptr< EffectInstance > | MakeInstance () const =0 |
Make an object maintaining short-term state of an Effect. More... | |
Public Member Functions inherited from EffectSettingsManager | |
virtual | ~EffectSettingsManager () |
virtual bool | VisitSettings (SettingsVisitor &visitor, EffectSettings &settings) |
virtual bool | VisitSettings (ConstSettingsVisitor &visitor, const EffectSettings &settings) const |
virtual EffectSettings | MakeSettings () const |
virtual bool | CopySettingsContents (const EffectSettings &src, EffectSettings &dst) const |
Update one settings object from another. More... | |
virtual std::unique_ptr< EffectOutputs > | MakeOutputs () const |
Produce an object to hold values to send to effect output meters. More... | |
Public Member Functions inherited from EffectDefinitionInterface | |
virtual | ~EffectDefinitionInterface () |
virtual EffectType | GetType () const =0 |
Type determines how it behaves. More... | |
virtual EffectType | GetClassification () const |
Determines which menu it appears in; default same as GetType(). More... | |
virtual EffectFamilySymbol | GetFamily () const =0 |
Report identifier and user-visible name of the effect protocol. More... | |
virtual bool | IsInteractive () const =0 |
Whether the effect needs a dialog for entry of settings. More... | |
virtual bool | IsDefault () const =0 |
Whether the effect sorts "above the line" in the menus. More... | |
virtual RealtimeSince | RealtimeSupport () const =0 |
Since which version of Audacity has the effect supported realtime? More... | |
bool | SupportsRealtime () const |
virtual bool | SupportsAutomation () const =0 |
Whether the effect has any automatable controls. More... | |
virtual bool | EnablesDebug () const |
Whether the effect dialog should have a Debug button; default, always false. More... | |
virtual ManualPageID | ManualPage () const |
Name of a page in the Audacity alpha manual, default is empty. More... | |
virtual FilePath | HelpPage () const |
Fully qualified local help file name, default is empty. More... | |
virtual bool | IsHiddenFromMenus () const |
Default is false. More... | |
Public Member Functions inherited from ComponentInterface | |
virtual | ~ComponentInterface () |
virtual PluginPath | GetPath () const =0 |
virtual ComponentInterfaceSymbol | GetSymbol () const =0 |
virtual VendorSymbol | GetVendor () const =0 |
virtual wxString | GetVersion () const =0 |
virtual TranslatableString | GetDescription () const =0 |
TranslatableString | GetName () const |
Static Public Member Functions | |
static Effect * | FetchParameters (Effect &e, EffectSettings &) |
Static Public Member Functions inherited from EffectBase | |
static std::optional< InstancePointer > | FindInstance (EffectPlugin &plugin) |
static InstanceFinder | DefaultInstanceFinder (EffectPlugin &plugin) |
Static Public Member Functions inherited from EffectDefinitionInterface | |
static Identifier | GetSquashedName (const Identifier &ident) |
A utility that strips spaces and CamelCases a name. More... | |
Protected Member Functions | |
bool | CheckWhetherSkipEffect (const EffectSettings &settings) const override |
Default implementation returns false. More... | |
double | CalcPreviewInputLength (const EffectSettings &settings, double previewLength) const override |
Default implementation returns previewLength More... | |
bool | TotalProgress (double frac, const TranslatableString &={}) const |
bool | TrackProgress (int whichTrack, double frac, const TranslatableString &={}) const |
bool | TrackGroupProgress (int whichGroup, double frac, const TranslatableString &={}) const |
int | GetNumWaveTracks () const |
int | GetNumWaveGroups () const |
void | GetBounds (const WaveTrack &track, sampleCount *start, sampleCount *len) |
Protected Member Functions inherited from EffectBase | |
virtual bool | CheckWhetherSkipEffect (const EffectSettings &settings) const =0 |
After Init(), tell whether Process() should be skipped. More... | |
void | SetLinearEffectFlag (bool linearEffectFlag) |
void | SetPreviewFullSelectionFlag (bool previewDurationFlag) |
bool | IsPreviewing () const |
const TrackList * | inputTracks () const |
const AudacityProject * | FindProject () const |
Private Member Functions | |
wxString | GetSavedStateGroup () |
Private Attributes | |
bool | mIsBatch { false } |
Additional Inherited Members | |
Public Types inherited from EffectPlugin | |
using | EffectSettingsAccessPtr = std::shared_ptr< EffectSettingsAccess > |
using | InstancePointer = std::shared_ptr< EffectInstanceEx > |
using | InstanceFinder = std::function< std::optional< InstancePointer >(EffectSettings &settings) > |
Public Types inherited from EffectDefinitionInterface | |
enum class | RealtimeSince : unsigned { Never , After_3_1 , Always } |
In which versions of Audacity was an effect realtime capable? More... | |
Public Attributes inherited from EffectBase | |
std::shared_ptr< TrackList > | mTracks {} |
int | mNumTracks {} |
BasicUI::ProgressDialog * | mProgress {} |
double | mProjectRate {} |
WaveTrackFactory * | mFactory {} |
double | mT0 {} |
double | mT1 {} |
bool | mIsPreview { false } |
Static Public Attributes inherited from EffectPlugin | |
static const wxString | kUserPresetIdent = wxT("User Preset:") |
static const wxString | kFactoryPresetIdent = wxT("Factory Preset:") |
static const wxString | kCurrentSettingsIdent = wxT("<Current Settings>") |
static const wxString | kFactoryDefaultsIdent = wxT("<Factory Defaults>") |
Protected Attributes inherited from EffectBase | |
double | mF0 {} |
double | mF1 {} |
wxArrayString | mPresetNames |
unsigned | mUIFlags { 0 } |
Effect::Effect | ( | ) |
Definition at line 34 of file Effect.cpp.
|
virtual |
Definition at line 38 of file Effect.cpp.
|
overrideprotectedvirtual |
Default implementation returns previewLength
Implements EffectBase.
Definition at line 384 of file Effect.cpp.
Referenced by PerTrackEffect::ProcessPass().
|
overridevirtual |
Whether the effect supports export of presets to files, and importing too.
Implements EffectPlugin.
Reimplemented in LadspaEffectBase, LV2EffectBase, VSTEffectBase, and VST3EffectBase.
Definition at line 170 of file Effect.cpp.
|
overrideprotectedvirtual |
Default implementation returns false.
Implements EffectBase.
Definition at line 379 of file Effect.cpp.
bool Effect::Delegate | ( | Effect & | delegate, |
EffectSettings & | settings, | ||
InstanceFinder | finder = {} |
||
) |
Re-invoke DoEffect on another Effect object that implements the work.
Definition at line 322 of file Effect.cpp.
References EffectBase::DefaultInstanceFinder(), EffectBase::DoEffect(), anonymous_namespace{Scrubbing.cpp}::finder, EffectBase::mFactory, EffectBase::mProjectRate, EffectBase::mT0, EffectBase::mT1, EffectBase::mTracks, EffectBase::mUIFlags, NotifyingSelectedRegion::setTimes(), and settings().
Referenced by NyquistBase::Process().
|
inlinestatic |
|
protected |
Definition at line 363 of file Effect.cpp.
References details::end(), WaveTrack::GetEndTime(), WaveTrack::GetStartTime(), min(), EffectBase::mT0, EffectBase::mT1, and WideSampleSequence::TimeToLongSamples().
Referenced by VampEffect::Process(), and PerTrackEffect::ProcessPass().
|
overridevirtual |
Implements EffectPlugin.
Definition at line 182 of file Effect.cpp.
Referenced by EffectChangeSpeed::OnChoice_Vinyl(), SaveUserPreset(), NoiseReductionBase::TrackProgress(), EffectChangeSpeed::TransferDataFromWindow(), and EffectChangeSpeed::Update_Vinyl().
|
overridevirtual |
Implements ComponentInterface.
Reimplemented in LadspaEffectBase, LV2EffectBase, NyquistBase, VSTEffectBase, and VST3EffectBase.
Definition at line 64 of file Effect.cpp.
|
overridevirtual |
Report names of factory presets.
Implements EffectSettingsManager.
Reimplemented in LadspaEffectBase, LV2EffectBase, VSTEffectBase, and VST3EffectBase.
Definition at line 155 of file Effect.cpp.
Referenced by LoadSettingsFromString().
|
overridevirtual |
Report identifier and user-visible name of the effect protocol.
Implements EffectDefinitionInterface.
Reimplemented in LadspaEffectBase, LV2EffectBase, NyquistBase, VSTEffectBase, and VST3EffectBase.
Definition at line 69 of file Effect.cpp.
|
inlineprotected |
Definition at line 140 of file Effect.h.
References EffectBase::mNumGroups.
Referenced by NyquistBase::Process(), and VampEffect::Process().
|
inlineprotected |
Definition at line 139 of file Effect.h.
References EffectBase::mNumTracks.
Referenced by TruncSilenceBase::Analyze(), AutoDuckBase::ApplyDuckFade(), AutoDuckBase::Process(), NormalizeBase::Process(), EffectTwoPassSimpleMono::ProcessOne(), NormalizeBase::ProcessOne(), and LoudnessBase::UpdateProgress().
|
overridevirtual |
Implements ComponentInterface.
Reimplemented in LadspaEffectBase, LV2EffectBase, NyquistBase, VSTEffectBase, and VST3EffectBase.
Definition at line 44 of file Effect.cpp.
References BUILTIN_EFFECT_PREFIX, GetSymbol(), and ComponentInterfaceSymbol::Internal().
|
private |
Definition at line 195 of file Effect.cpp.
References wxT().
Referenced by SetBatchProcessing(), and UnsetBatchProcessing().
|
virtual |
Definition at line 187 of file Effect.cpp.
References EffectBase::FindProject(), ProjectNumericFormats::Get(), ProjectNumericFormats::GetSelectionFormat(), NumericConverterFormats::HoursMinsSecondsFormat(), ComponentInterfaceSymbol::Internal(), and IsBatchProcessing().
Referenced by NyquistEffect::BuildEffectWindow(), and EffectRepeat::DisplayNewTime().
|
overridevirtual |
Implements ComponentInterface.
Reimplemented in LadspaEffectBase, LV2EffectBase, NyquistBase, VSTEffectBase, and VST3EffectBase.
Definition at line 49 of file Effect.cpp.
Referenced by GetPath().
|
overridevirtual |
Implements ComponentInterface.
Reimplemented in LadspaEffectBase, LV2EffectBase, NyquistBase, VSTEffectBase, and VST3EffectBase.
Definition at line 54 of file Effect.cpp.
References XO().
|
overridevirtual |
Implements ComponentInterface.
Reimplemented in LadspaEffectBase, LV2EffectBase, NyquistBase, VSTEffectBase, and VST3EffectBase.
Definition at line 59 of file Effect.cpp.
|
overridevirtual |
Whether there are preferences applying to the effect's family, for which a UI may be needed to change them
Implements EffectPlugin.
Reimplemented in LadspaEffectBase, LV2EffectBase, VSTEffectBase, and VST3EffectBase.
Definition at line 175 of file Effect.cpp.
|
overridevirtual |
Implements EffectPlugin.
Definition at line 295 of file Effect.cpp.
References mIsBatch.
Referenced by NyquistBase::DoLoadSettings(), GetSelectionFormat(), AmplifyBase::Parameters(), EffectAmplify::PopulateOrExchange(), NyquistBase::Process(), MacroCommands::PromptForParamsFor(), and EffectNoiseReduction::ShowHostInterface().
|
overridevirtual |
Whether the effect sorts "above the line" in the menus.
Implements EffectDefinitionInterface.
Reimplemented in LadspaEffectBase, LV2EffectBase, NyquistBase, VSTEffectBase, and VST3EffectBase.
Definition at line 81 of file Effect.cpp.
|
overridevirtual |
Whether the effect needs a dialog for entry of settings.
Implements EffectDefinitionInterface.
Reimplemented in LadspaEffectBase, LV2EffectBase, NyquistBase, VSTEffectBase, and VST3EffectBase.
Definition at line 76 of file Effect.cpp.
|
overridevirtual |
Change settings back to "factory default"
Implements EffectSettingsManager.
Definition at line 165 of file Effect.cpp.
References FactoryDefaultsGroup(), LoadUserPreset(), and settings().
Referenced by ChangeSpeedBase::DoLoadFactoryDefaults(), and EqualizationBase::DoLoadFactoryDefaults().
|
overridevirtual |
Change settings to the preset whose name is GetFactoryPresets()[id]
Implements EffectSettingsManager.
Reimplemented in LadspaEffectBase, LV2EffectBase, VSTEffectBase, and VST3EffectBase.
Definition at line 160 of file Effect.cpp.
Referenced by LoadSettingsFromString().
|
overridevirtual |
Restore settings from keys and values.
Implements EffectSettingsManager.
Reimplemented in LadspaEffectBase, LV2EffectBase, NyquistBase, VSTEffectBase, and VST3EffectBase.
Definition at line 122 of file Effect.cpp.
References Parameters(), EffectParameterMethods::Set(), and settings().
Referenced by TruncSilenceBase::LoadSettings(), and LoadSettingsFromString().
|
overridevirtual |
Implements EffectPlugin.
Definition at line 220 of file Effect.cpp.
References BasicUI::MessageBoxOptions::Caption(), CurrentSettingsGroup(), FactoryDefaultsGroup(), GetFactoryPresets(), ComponentInterface::GetName(), EffectPlugin::kCurrentSettingsIdent, EffectPlugin::kFactoryDefaultsIdent, EffectPlugin::kFactoryPresetIdent, EffectPlugin::kUserPresetIdent, LoadFactoryPreset(), LoadSettings(), LoadUserPreset(), make_iterator_range(), preset, S, settings(), BasicUI::ShowMessageBox(), UserPresetsGroup(), VisitSettings(), and XO().
Referenced by NoiseReductionBase::TrackProgress().
|
overridevirtual |
Change settings to a user-named preset
Implements EffectSettingsManager.
Reimplemented in LadspaEffectBase, LV2EffectBase, VSTEffectBase, and VST3EffectBase.
Definition at line 130 of file Effect.cpp.
Referenced by LoadFactoryDefaults(), LoadSettingsFromString(), and UnsetBatchProcessing().
|
virtual |
Reimplemented in AmplifyBase, AutoDuckBase, BassTrebleBase, ChangeSpeedBase, ClickRemovalBase, DistortionBase, DtmfBase, EchoBase, EqualizationBase, FindClippingBase, LegacyCompressorBase, LoudnessBase, NoiseBase, NormalizeBase, PaulstretchBase, PhaserBase, RepeatBase, ReverbBase, ScienFilterBase, TimeScaleBase, ToneGenBase, TruncSilenceBase, WahWahBase, EffectCompressor, and EffectLimiter.
Definition at line 96 of file Effect.cpp.
Referenced by LoadSettings(), SaveSettings(), and VisitSettings().
|
overridevirtual |
Since which version of Audacity has the effect supported realtime?
Implements EffectDefinitionInterface.
Reimplemented in LadspaEffectBase, LV2EffectBase, VSTEffectBase, and VST3EffectBase.
Definition at line 86 of file Effect.cpp.
References EffectDefinitionInterface::Never.
|
overridevirtual |
Store settings as keys and values.
The override may assume parms
is initially empty
Implements EffectSettingsManager.
Reimplemented in LadspaEffectBase, LV2EffectBase, NyquistBase, VSTEffectBase, and VST3EffectBase.
Definition at line 115 of file Effect.cpp.
References EffectParameterMethods::Get(), Parameters(), and settings().
Referenced by SaveSettingsAsString().
|
overridevirtual |
Implements EffectPlugin.
Definition at line 202 of file Effect.cpp.
References CommandParameters::GetParameters(), S, SaveSettings(), settings(), and VisitSettings().
Referenced by SaveUserPreset().
|
overridevirtual |
Save settings in the configuration file as a user-named preset.
Implements EffectSettingsManager.
Reimplemented in LadspaEffectBase, LV2EffectBase, VSTEffectBase, and VST3EffectBase.
Definition at line 143 of file Effect.cpp.
References GetDefinition(), name, PluginSettings::Private, SaveSettingsAsString(), PluginSettings::SetConfig(), settings(), and wxT().
Referenced by SetBatchProcessing().
|
overridevirtual |
Implements EffectPlugin.
Definition at line 300 of file Effect.cpp.
References GetSavedStateGroup(), EffectSettingsManager::MakeSettings(), mIsBatch, and SaveUserPreset().
Referenced by EVT_COMMAND_RANGE().
|
overridevirtual |
Whether the effect has any automatable controls.
Implements EffectDefinitionInterface.
Reimplemented in LadspaEffectBase, LV2EffectBase, VSTEffectBase, and VST3EffectBase.
Definition at line 91 of file Effect.cpp.
unsigned Effect::TestUIFlags | ( | unsigned | mask | ) |
Definition at line 291 of file Effect.cpp.
References EffectBase::mUIFlags.
Referenced by EVT_COMMAND_RANGE().
|
protected |
Definition at line 335 of file Effect.cpp.
References EffectBase::mProgress, BasicUI::ProgressDialog::Poll(), and BasicUI::Success.
Referenced by TruncSilenceBase::Analyze(), AutoDuckBase::ApplyDuckFade(), TruncSilenceBase::DoRemoval(), AutoDuckBase::Process(), NormalizeBase::Process(), NyquistBase::Process(), StereoToMono::ProcessOne(), EffectTwoPassSimpleMono::ProcessOne(), NormalizeBase::ProcessOne(), and LoudnessBase::UpdateProgress().
|
protected |
Definition at line 353 of file Effect.cpp.
References EffectBase::mNumGroups, EffectBase::mProgress, BasicUI::ProgressDialog::Poll(), and BasicUI::Success.
Referenced by VampEffect::Process(), NyquistBase::ProcessOne(), and PerTrackEffect::ProcessPass().
|
protected |
Definition at line 343 of file Effect.cpp.
References EffectBase::mNumTracks, EffectBase::mProgress, BasicUI::ProgressDialog::Poll(), and BasicUI::Success.
Referenced by RepeatBase::Process(), Reverse::Process(), SBSMSBase::Process(), VampEffect::Process(), PaulstretchBase::ProcessOne(), ChangeSpeedBase::ProcessOne(), ClickRemovalBase::ProcessOne(), Repair::ProcessOne(), FindClippingBase::ProcessOne(), NyquistBase::ProcessOne(), EqualizationBase::ProcessOne(), and PerTrackEffect::ProcessPass().
|
overridevirtual |
Implements EffectPlugin.
Definition at line 311 of file Effect.cpp.
References GetSavedStateGroup(), LoadUserPreset(), EffectSettingsManager::MakeSettings(), and mIsBatch.
|
overridevirtual |
Visit settings (read-only), if defined. false means no defined settings. Default implementation returns false
Reimplemented from EffectSettingsManager.
Reimplemented in NyquistBase.
Definition at line 108 of file Effect.cpp.
References Parameters(), settings(), and EffectParameterMethods::Visit().
|
overridevirtual |
Visit settings (and maybe change them), if defined. false means no defined settings. Default implementation returns false
Reimplemented from EffectSettingsManager.
Reimplemented in NyquistBase.
Definition at line 102 of file Effect.cpp.
References Parameters(), settings(), and EffectParameterMethods::Visit().
Referenced by LoadSettingsFromString(), SaveSettingsAsString(), and EqualizationBase::VisitSettings().
|
private |
Definition at line 148 of file Effect.h.
Referenced by IsBatchProcessing(), SetBatchProcessing(), and UnsetBatchProcessing().