Audacity 3.2.0
Public Member Functions | Public Attributes | List of all members
EffectReverb::Editor Struct Reference
Inheritance diagram for EffectReverb::Editor:
[legend]
Collaboration diagram for EffectReverb::Editor:
[legend]

Public Member Functions

 Editor (const EffectUIServices &services, EffectSettingsAccess &access, const EffectReverbSettings &settings)
 
virtual ~Editor ()=default
 
bool ValidateUI () override
 Get settings data from the panel; may make error dialogs and return false. More...
 
bool UpdateUI () override
 Update appearance of the panel for changes in settings. More...
 
void PopulateOrExchange (ShuttleGui &S)
 
 SpinSlider (RoomSize) SpinSlider(PreDelay) SpinSlider(Reverberance) SpinSlider(HfDamping) SpinSlider(ToneLow) SpinSlider(ToneHigh) SpinSlider(WetGain) SpinSlider(DryGain) SpinSlider(StereoWidth) wxCheckBox *mWetOnlyC
 
 SpinSliderHandlers (RoomSize) SpinSliderHandlers(PreDelay) SpinSliderHandlers(Reverberance) SpinSliderHandlers(HfDamping) SpinSliderHandlers(ToneLow) SpinSliderHandlers(ToneHigh) SpinSliderHandlers(WetGain) SpinSliderHandlers(DryGain) SpinSliderHandlers(StereoWidth) void OnCheckbox(wxCommandEvent &evt)
 
- Public Member Functions inherited from EffectEditor
 EffectEditor (const EffectUIServices &services, EffectSettingsAccess &access)
 
virtual ~EffectEditor ()
 
virtual bool ValidateUI ()=0
 Get settings data from the panel; may make error dialogs and return false. More...
 
virtual bool UpdateUI ()
 Update appearance of the panel for changes in settings. More...
 
virtual bool IsGraphicalUI ()
 
virtual void Disconnect ()
 On the first call only, may disconnect from further event handling. More...
 
virtual void OnClose ()
 
- Public Member Functions inherited from Observer::Publisher< EffectSettingChanged >
 Publisher (ExceptionPolicy *pPolicy=nullptr, Alloc a={})
 Constructor supporting type-erased custom allocation/deletion. More...
 
 Publisher (Publisher &&)=default
 
Publisheroperator= (Publisher &&)=default
 
Subscription Subscribe (Callback callback)
 Connect a callback to the Publisher; later-connected are called earlier. More...
 
Subscription Subscribe (Object &obj, Return(Object::*callback)(Args...))
 Overload of Subscribe takes an object and pointer-to-member-function. More...
 

Public Attributes

EffectReverbSettings mSettings
 
bool mProcessingEvent = false
 

Additional Inherited Members

- Public Types inherited from Observer::Publisher< EffectSettingChanged >
using message_type = EffectSettingChanged
 
using CallbackReturn = std::conditional_t< true, void, bool >
 
using Callback = std::function< CallbackReturn(const EffectSettingChanged &) >
 Type of functions that can be connected to the Publisher. More...
 
- Static Public Member Functions inherited from EffectEditor
static bool EnableApply (wxWindow *parent, bool enable=true)
 Enable or disable the Apply button of the dialog that contains parent. More...
 
static bool EnablePreview (wxWindow *parent, bool enable=true)
 
- Static Public Attributes inherited from EffectEditor
static constexpr int kPlayID = 20102
 
- Static Public Attributes inherited from Observer::Publisher< EffectSettingChanged >
static constexpr bool notifies_all
 
- Protected Member Functions inherited from EffectEditor
template<typename EventTag , typename Class , typename Event >
void BindTo (wxEvtHandler &src, const EventTag &eventType, void(Class::*pmf)(Event &))
 
- Protected Member Functions inherited from Observer::Publisher< EffectSettingChanged >
CallbackReturn Publish (const EffectSettingChanged &message)
 Send a message to connected callbacks. More...
 
- Protected Attributes inherited from EffectEditor
const EffectUIServicesmUIServices
 
EffectSettingsAccessmAccess
 
bool mUIClosed { false }
 

Detailed Description

Definition at line 124 of file Reverb.cpp.

Constructor & Destructor Documentation

◆ Editor()

EffectReverb::Editor::Editor ( const EffectUIServices services,
EffectSettingsAccess access,
const EffectReverbSettings settings 
)
inline

Definition at line 127 of file Reverb.cpp.

129 : EffectEditor{ services, access }
131 {}
static Settings & settings()
Definition: TrackInfo.cpp:51
EffectReverbSettings mSettings
Definition: Reverb.cpp:139

◆ ~Editor()

virtual EffectReverb::Editor::~Editor ( )
virtualdefault

Member Function Documentation

◆ PopulateOrExchange()

void EffectReverb::Editor::PopulateOrExchange ( ShuttleGui S)

Definition at line 555 of file Reverb.cpp.

556{
557 S.AddSpace(0, 5);
558
559 S.StartMultiColumn(3, wxEXPAND);
560 {
561 S.SetStretchyCol(2);
562
563#define SpinSlider(n, p) \
564 m ## n ## T = S.AddSpinCtrl( p, n.def, n.max, n.min); \
565 BindTo(*m ## n ## T, wxEVT_SPINCTRL, &Editor::On ## n ## Text);\
566 \
567 m ## n ## S = S.Style(wxSL_HORIZONTAL).AddSlider( {}, n.def, n.max, n.min); \
568 BindTo(*m ## n ## S, wxEVT_SLIDER, &Editor::On ## n ## Slider);
569
570 SpinSlider(RoomSize, XXO("&Room Size (%):"))
571 SpinSlider(PreDelay, XXO("&Pre-delay (ms):"))
572 SpinSlider(Reverberance, XXO("Rever&berance (%):"))
573 SpinSlider(HfDamping, XXO("Da&mping (%):"))
574 SpinSlider(ToneLow, XXO("Tone &Low (%):"))
575 SpinSlider(ToneHigh, XXO("Tone &High (%):"))
576 SpinSlider(WetGain, XXO("Wet &Gain (dB):"))
577 SpinSlider(DryGain, XXO("Dr&y Gain (dB):"))
578 SpinSlider(StereoWidth, XXO("Stereo Wid&th (%):"))
579
580#undef SpinSlider
581
582 }
583 S.EndMultiColumn();
584
585 S.StartHorizontalLay(wxCENTER, false);
586 {
587 mWetOnlyC =
588 S.AddCheckBox(XXO("Wet O&nly"), WetOnly.def);
589 BindTo(*mWetOnlyC, wxEVT_CHECKBOX, &Editor::OnCheckbox);
590 }
591 S.EndHorizontalLay();
592
593}
XXO("&Cut/Copy/Paste Toolbar")
#define S(N)
Definition: ToChars.cpp:64
void BindTo(wxEvtHandler &src, const EventTag &eventType, void(Class::*pmf)(Event &))
Definition: EffectEditor.h:85
static constexpr EffectParameter ToneLow
Definition: Reverb.h:111
static constexpr EffectParameter PreDelay
Definition: Reverb.h:102
static constexpr EffectParameter RoomSize
Definition: Reverb.h:99
static constexpr EffectParameter StereoWidth
Definition: Reverb.h:123
static constexpr EffectParameter Reverberance
Definition: Reverb.h:105
static constexpr EffectParameter WetGain
Definition: Reverb.h:117
static constexpr EffectParameter HfDamping
Definition: Reverb.h:108
static constexpr EffectParameter ToneHigh
Definition: Reverb.h:114
static constexpr EffectParameter WetOnly
Definition: Reverb.h:126
static constexpr EffectParameter DryGain
Definition: Reverb.h:120
const Type def
Default value.
SpinSlider(RoomSize) SpinSlider(PreDelay) SpinSlider(Reverberance) SpinSlider(HfDamping) SpinSlider(ToneLow) SpinSlider(ToneHigh) SpinSlider(WetGain) SpinSlider(DryGain) SpinSlider(StereoWidth) wxCheckBox *mWetOnlyC

References EffectParameter< Structure, Member, Type, Value >::def, EffectReverb::DryGain, EffectReverb::HfDamping, EffectReverb::PreDelay, EffectReverb::Reverberance, EffectReverb::RoomSize, S, SpinSlider, EffectReverb::StereoWidth, EffectReverb::ToneHigh, EffectReverb::ToneLow, EffectReverb::WetGain, EffectReverb::WetOnly, and XXO().

Here is the call graph for this function:

◆ SpinSlider()

EffectReverb::Editor::SpinSlider ( RoomSize  )

◆ SpinSliderHandlers()

EffectReverb::Editor::SpinSliderHandlers ( RoomSize  ) &

◆ UpdateUI()

bool EffectReverb::Editor::UpdateUI ( )
overridevirtual

Update appearance of the panel for changes in settings.

Default implementation does nothing, returns true

Returns
true if successful

Reimplemented from EffectEditor.

Definition at line 595 of file Reverb.cpp.

596{
597 // get the settings from the MessageBuffer and write them to our local copy
599
600 auto& rs = mSettings;
601
602#define SetSpinSlider(n) \
603 m ## n ## S->SetValue((int) rs.m ## n); \
604 m ## n ## T->SetValue(wxString::Format(wxT("%d"), (int) rs.m ## n));
605
615
616#undef SetSpinSlider
617
618 mWetOnlyC->SetValue((int) rs.mWetOnly);
619
620 return true;
621}
#define SetSpinSlider(n)
EffectSettingsAccess & mAccess
Definition: EffectEditor.h:92
virtual const EffectSettings & Get()=0
static EffectReverbSettings & GetSettings(EffectSettings &settings)
Assume settings originated from MakeSettings() and copies thereof.
Definition: Effect.h:166

References EffectReverb::DryGain, EffectWithSettings< EffectReverbSettings, StatelessPerTrackEffect >::GetSettings(), EffectReverb::HfDamping, EffectReverb::PreDelay, EffectReverb::Reverberance, EffectReverb::RoomSize, SetSpinSlider, EffectReverb::StereoWidth, EffectReverb::ToneHigh, EffectReverb::ToneLow, and EffectReverb::WetGain.

Here is the call graph for this function:

◆ ValidateUI()

bool EffectReverb::Editor::ValidateUI ( )
overridevirtual

Get settings data from the panel; may make error dialogs and return false.

Returns
true only if panel settings are acceptable

Implements EffectEditor.

Definition at line 183 of file Reverb.cpp.

184{
185 auto& rs = mSettings;
186
187 rs.mRoomSize = mRoomSizeS->GetValue();
188 rs.mPreDelay = mPreDelayS->GetValue();
189 rs.mReverberance = mReverberanceS->GetValue();
190 rs.mHfDamping = mHfDampingS->GetValue();
191 rs.mToneLow = mToneLowS->GetValue();
192 rs.mToneHigh = mToneHighS->GetValue();
193 rs.mWetGain = mWetGainS->GetValue();
194 rs.mDryGain = mDryGainS->GetValue();
195 rs.mStereoWidth = mStereoWidthS->GetValue();
196 rs.mWetOnly = mWetOnlyC->GetValue();
197
199 (
200 [this](EffectSettings& settings)
201 {
202 // pass back the modified settings to the MessageBuffer
203
205 return nullptr;
206 }
207 );
208
209 return true;
210}
void ModifySettings(Function &&function)
Do a correct read-modify-write of settings.
double mRoomSize
Definition: Reverb.h:34
Externalized state of a plug-in.

References EffectWithSettings< EffectReverbSettings, StatelessPerTrackEffect >::GetSettings(), EffectEditor::mAccess, EffectSettingsAccess::ModifySettings(), EffectReverbSettings::mRoomSize, mSettings, and settings().

Here is the call graph for this function:

Member Data Documentation

◆ mProcessingEvent

bool EffectReverb::Editor::mProcessingEvent = false

Definition at line 141 of file Reverb.cpp.

◆ mSettings

EffectReverbSettings EffectReverb::Editor::mSettings

Definition at line 139 of file Reverb.cpp.

Referenced by ValidateUI().


The documentation for this struct was generated from the following file: