You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

200 lines
5.7KB

  1. /* WaveShaper Plugin Copyleft (C) 2001 Yves Usson
  2. * for SpiralSynthModular
  3. * Copyleft (C) 2000 David Griffiths <dave@pawfal.org>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to the Free Software
  17. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  18. */
  19. #include "WaveShaperPluginGUI.h"
  20. #include <FL/fl_draw.h>
  21. #include <FL/fl_draw.H>
  22. #include <FL/Fl_Box.H>
  23. using namespace std;
  24. FunctionPlot::FunctionPlot(int ox, int oy, int ww, int hh) :
  25. Fl_Widget (ox, oy, ww, hh),
  26. m_IndColour(FL_YELLOW),
  27. m_MrkColour(FL_BLUE),
  28. m_FGColour(FL_GREEN)
  29. {
  30. fval = new float[256];
  31. for (int i=0;i<256;i++) fval[i] = i / 128.0 - 1.0;
  32. }
  33. FunctionPlot::~FunctionPlot() {
  34. delete [] fval;
  35. }
  36. void FunctionPlot::draw() {
  37. int ox = x() + 3;
  38. int oy = y() +3;
  39. int ww = w() - 6;
  40. int hh = h() - 6;
  41. float coefx,coefy;
  42. draw_box();
  43. fl_clip(ox,oy,ww,hh);
  44. coefx = ww / 256.0;
  45. coefy = hh / 2.0;
  46. for (int i = -5; i <= 5; i++)
  47. {
  48. if (i==0) fl_color (m_IndColour);
  49. else fl_color (m_MrkColour);
  50. fl_line(ox,oy+hh/2+i*hh/10,ox+ww,oy+hh/2+i*hh/10);
  51. }
  52. for (int i = -5; i <= 5; i++)
  53. {
  54. if (i==0) fl_color (m_IndColour);
  55. else fl_color (m_MrkColour);
  56. fl_line(ox+i*ww/10+ww/2,oy,ox+i*ww/10+ww/2,oy+hh);
  57. }
  58. fl_color (m_FGColour);
  59. float y1 = oy+hh/2-coefy*fval[0];
  60. for (int i = 0; i < 255; i++)
  61. {
  62. float y2 = oy+hh/2-coefy*fval[i+1];
  63. fl_line((int)(ox+i*coefx),(int)y1,(int)(ox+(i+1)*coefx),(int)y2);
  64. y1 = y2;
  65. }
  66. fl_color (FL_BLACK);
  67. fl_pop_clip();
  68. }
  69. int FunctionPlot::handle(int event) {
  70. return 0;
  71. }
  72. void FunctionPlot::set(const int index, const float v) {
  73. if ((index < 0) || (index > 255)) return;
  74. fval[index] = v;
  75. if (fval[index] > 1.0f) fval[index] = 1.0f;
  76. if (fval[index] < -1.0f) fval[index] = -1.0f;
  77. }
  78. float FunctionPlot::get(const int index) const {
  79. if ((index < 0) || (index > 255)) return (-10.0f);
  80. return fval[index];
  81. }
  82. ////////////////////////////////////////////
  83. WaveShaperPluginGUI::WaveShaperPluginGUI (int w, int h, WaveShaperPlugin *o, ChannelHandler *ch, const HostInfo *Info) :
  84. SpiralPluginGUI(w, h, o, ch)
  85. {
  86. fplot = new FunctionPlot(3, 20, 268, 195);
  87. fplot->box (FL_UP_BOX);
  88. fplot->color (Info->SCOPE_BG_COLOUR);
  89. fplot->SetColours (Info->SCOPE_IND_COLOUR, Info->SCOPE_MRK_COLOUR, Info->SCOPE_FG_COLOUR);
  90. radio_polynomial = new Fl_LED_Button(3, 218, 30, 20, "S");
  91. radio_polynomial->down_box(FL_ROUND_DOWN_BOX);
  92. radio_polynomial->value(1);
  93. radio_polynomial->type(102);
  94. radio_polynomial->labelfont(12);
  95. radio_polynomial->labelsize(12);
  96. radio_polynomial->callback((Fl_Callback*)cb_radio);
  97. radio_sines = new Fl_LED_Button(3, 238, 30, 20, "S");
  98. radio_sines->down_box(FL_ROUND_DOWN_BOX);
  99. radio_sines->value(0);
  100. radio_sines->type(102);
  101. radio_sines->labelfont(12);
  102. radio_sines->labelsize(12);
  103. radio_sines->callback((Fl_Callback*)cb_radio);
  104. { Fl_Box* o = new Fl_Box(26, 218, 25, 20, "a .x");
  105. o->labelfont(2);
  106. o->labelsize(10);
  107. }
  108. { Fl_Box* o = new Fl_Box(33, 227, 10, 15, "i");
  109. o->labelfont(2);
  110. o->labelsize(10);
  111. }
  112. { Fl_Box* o = new Fl_Box(47, 217, 10, 15, "i");
  113. o->labelfont(2);
  114. o->labelsize(10);
  115. }
  116. { Fl_Box* o = new Fl_Box(31, 246, 10, 15, "i");
  117. o->labelfont(2);
  118. o->labelsize(10);
  119. }
  120. { Fl_Box* o = new Fl_Box(36, 237, 25, 20, "a .sin i x");
  121. o->labelfont(2);
  122. o->labelsize(10);
  123. }
  124. for (int i=0; i<6; i++) {
  125. knob[i] = new Fl_Knob (70+i*35, 220, 30, 30, "");
  126. knob[i]->color (Info->GUI_COLOUR);
  127. knob[i]->type (Fl_Knob::DOTLIN);
  128. knob[i]->labelsize (10);
  129. knob[i]->maximum (1);
  130. knob[i]->minimum (-1);
  131. knob[i]->step (0.01);
  132. knob[i]->value (0);
  133. knob[i]->callback ((Fl_Callback*)cb_knob);
  134. }
  135. knob[0]->value(1.0);
  136. end();
  137. }
  138. void WaveShaperPluginGUI::UpdateValues (SpiralPlugin *o) {
  139. WaveShaperPlugin* Plugin = (WaveShaperPlugin*) o;
  140. int wt = Plugin->GetWaveType ();
  141. radio_polynomial->value (wt);
  142. radio_sines->value (!wt);
  143. for (int j=0; j<6; j++) knob[j]->value (Plugin->GetCoef (j));
  144. Update ();
  145. }
  146. void WaveShaperPluginGUI::Update () {
  147. // Formerly KnobCB
  148. float WTData[256];
  149. m_GUICH->GetData ("WT", (void*)WTData);
  150. for (int i=0; i<256; i++) fplot->set (i, WTData[i]);
  151. fplot->redraw ();
  152. }
  153. inline void WaveShaperPluginGUI::cb_radio_i (Fl_LED_Button*, void*) {
  154. m_GUICH->Set ("WaveType", (int)radio_polynomial->value ());
  155. m_GUICH->SetCommand (WaveShaperPlugin::SETWAVETYPE);
  156. }
  157. void WaveShaperPluginGUI::cb_radio (Fl_LED_Button* o, void* v) {
  158. ((WaveShaperPluginGUI*)(o->parent()))->cb_radio_i (o, v);
  159. }
  160. inline void WaveShaperPluginGUI::cb_knob_i (Fl_Knob* o, void* v) {
  161. for (int j=0; j<6; j++) {
  162. if (o==knob[j]) {
  163. m_GUICH->Set ("CoefNum", j);
  164. m_GUICH->Set ("CoefVal", (float)knob[j]->value ());
  165. m_GUICH->SetCommand (WaveShaperPlugin::SETCOEF);
  166. break;
  167. }
  168. }
  169. }
  170. void WaveShaperPluginGUI::cb_knob (Fl_Knob* o, void* v) {
  171. ((WaveShaperPluginGUI*)(o->parent()))->cb_knob_i (o, v);
  172. }
  173. const string WaveShaperPluginGUI::GetHelpText(const string &loc){
  174. return string("")
  175. + "This plugin simulates wave shaping as found on analogue\n"
  176. + "synths, usable in two modes, linear or sine based.\n";
  177. }