andrewm@0
|
1 /*
|
andrewm@0
|
2 This code accompanies the textbook:
|
andrewm@0
|
3
|
andrewm@0
|
4 Digital Audio Effects: Theory, Implementation and Application
|
andrewm@0
|
5 Joshua D. Reiss and Andrew P. McPherson
|
andrewm@0
|
6
|
andrewm@0
|
7 ---
|
andrewm@0
|
8
|
andrewm@0
|
9 Empty: template for an effect; passes input to output unmodified
|
andrewm@0
|
10 See textbook Chapter 13: Building Audio Effect Plug-Ins
|
andrewm@0
|
11
|
andrewm@0
|
12 Code by Andrew McPherson, Brecht De Man and Joshua Reiss
|
andrewm@0
|
13
|
andrewm@0
|
14 ---
|
andrewm@0
|
15
|
andrewm@0
|
16 This program is free software: you can redistribute it and/or modify
|
andrewm@0
|
17 it under the terms of the GNU General Public License as published by
|
andrewm@0
|
18 the Free Software Foundation, either version 3 of the License, or
|
andrewm@0
|
19 (at your option) any later version.
|
andrewm@0
|
20
|
andrewm@0
|
21 This program is distributed in the hope that it will be useful,
|
andrewm@0
|
22 but WITHOUT ANY WARRANTY; without even the implied warranty of
|
andrewm@0
|
23 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
andrewm@0
|
24 GNU General Public License for more details.
|
andrewm@0
|
25
|
andrewm@0
|
26 You should have received a copy of the GNU General Public License
|
andrewm@0
|
27 along with this program. If not, see <http://www.gnu.org/licenses/>.
|
andrewm@0
|
28 */
|
andrewm@0
|
29
|
andrewm@0
|
30 #include "PluginProcessor.h"
|
andrewm@0
|
31 #include "PluginEditor.h"
|
andrewm@0
|
32
|
andrewm@0
|
33
|
andrewm@0
|
34 //==============================================================================
|
andrewm@0
|
35 EmptyAudioProcessorEditor::EmptyAudioProcessorEditor (EmptyAudioProcessor* ownerFilter)
|
andrewm@0
|
36 : AudioProcessorEditor (ownerFilter),
|
andrewm@0
|
37 volumeLabel_("", "Volume:"),
|
andrewm@0
|
38 volumeSlider_("volume")
|
andrewm@0
|
39 {
|
andrewm@0
|
40 // This is where our plugin's editor size is set.
|
andrewm@0
|
41 // setSize(170, 80);
|
andrewm@0
|
42
|
andrewm@0
|
43 // Set up the sliders
|
andrewm@0
|
44 addAndMakeVisible(&volumeSlider_);
|
andrewm@0
|
45 volumeSlider_.setSliderStyle(Slider::Rotary);
|
andrewm@0
|
46 volumeSlider_.addListener(this);
|
andrewm@0
|
47 volumeSlider_.setRange(0.0, 2.0, 0.01);
|
andrewm@0
|
48
|
andrewm@0
|
49 volumeLabel_.attachToComponent(&volumeSlider_, false);
|
andrewm@0
|
50 volumeLabel_.setFont(Font (11.0f));
|
andrewm@0
|
51
|
andrewm@0
|
52 // add the triangular resizer component for the bottom-right of the UI
|
andrewm@0
|
53 addAndMakeVisible(resizer_ = new ResizableCornerComponent (this, &resizeLimits_));
|
andrewm@0
|
54 resizeLimits_.setSizeLimits(170, 100, 400, 160);
|
andrewm@0
|
55
|
andrewm@0
|
56 // set our component's initial size to be the last one that was stored in the filter's settings
|
andrewm@0
|
57 setSize(ownerFilter->lastUIWidth_,
|
andrewm@0
|
58 ownerFilter->lastUIHeight_);
|
andrewm@0
|
59
|
andrewm@0
|
60 startTimer(50);
|
andrewm@0
|
61 }
|
andrewm@0
|
62
|
andrewm@0
|
63 EmptyAudioProcessorEditor::~EmptyAudioProcessorEditor()
|
andrewm@0
|
64 {
|
andrewm@0
|
65 }
|
andrewm@0
|
66
|
andrewm@0
|
67 //==============================================================================
|
andrewm@0
|
68 void EmptyAudioProcessorEditor::paint (Graphics& g)
|
andrewm@0
|
69 {
|
andrewm@0
|
70 g.fillAll (Colours::grey);
|
andrewm@0
|
71 }
|
andrewm@0
|
72
|
andrewm@0
|
73 void EmptyAudioProcessorEditor::resized()
|
andrewm@0
|
74 {
|
andrewm@0
|
75 volumeSlider_.setBounds(20, 20, 150, 40);
|
andrewm@0
|
76
|
andrewm@0
|
77 resizer_->setBounds(getWidth() - 16, getHeight() - 16, 16, 16);
|
andrewm@0
|
78
|
andrewm@0
|
79 getProcessor()->lastUIWidth_ = getWidth();
|
andrewm@0
|
80 getProcessor()->lastUIHeight_ = getHeight();
|
andrewm@0
|
81 }
|
andrewm@0
|
82
|
andrewm@0
|
83 //==============================================================================
|
andrewm@0
|
84 // This timer periodically checks whether any of the filter's parameters have changed...
|
andrewm@0
|
85 void EmptyAudioProcessorEditor::timerCallback()
|
andrewm@0
|
86 {
|
andrewm@0
|
87 EmptyAudioProcessor* ourProcessor = getProcessor();
|
andrewm@0
|
88
|
andrewm@0
|
89 volumeSlider_.setValue(ourProcessor->volume_, dontSendNotification);
|
andrewm@0
|
90 }
|
andrewm@0
|
91
|
andrewm@0
|
92 // This is our Slider::Listener callback, when the user drags a slider.
|
andrewm@0
|
93 void EmptyAudioProcessorEditor::sliderValueChanged (Slider* slider)
|
andrewm@0
|
94 {
|
andrewm@0
|
95 if (slider == &volumeSlider_)
|
andrewm@0
|
96 {
|
andrewm@0
|
97 // It's vital to use setParameterNotifyingHost to change any parameters that are automatable
|
andrewm@0
|
98 // by the host, rather than just modifying them directly, otherwise the host won't know
|
andrewm@0
|
99 // that they've changed.
|
andrewm@0
|
100 getProcessor()->setParameterNotifyingHost (EmptyAudioProcessor::kVolumeParam,
|
andrewm@0
|
101 (float)volumeSlider_.getValue());
|
andrewm@0
|
102 }
|
andrewm@0
|
103 } |