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.

62 lines
1.9KB

  1. /* SpiralPlugin
  2. * Copyleft (C) 2000 David Griffiths <dave@pawfal.org>
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation; either version 2 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program; if not, write to the Free Software
  16. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  17. */
  18. #include <FL/Fl.H>
  19. #include "../Widgets/Fl_Knob.H"
  20. #include "MasherPlugin.h"
  21. #include "../SpiralPluginGUI.h"
  22. #ifndef MASHER_GUI_H
  23. #define MASHER_GUI_H
  24. class MasherPluginGUI : public SpiralPluginGUI
  25. {
  26. public:
  27. MasherPluginGUI(int w, int h, MasherPlugin *o,ChannelHandler *ch,const HostInfo *Info);
  28. virtual void UpdateValues(SpiralPlugin *o);
  29. virtual SpiralPlugin* GetPlugin() { return m_Plugin; }
  30. MasherPlugin *m_Plugin;
  31. protected:
  32. const string GetHelpText(const string &loc);
  33. private:
  34. Fl_Knob *m_Random;
  35. Fl_Knob *m_Pitch;
  36. Fl_Knob *m_GrainStoreSize;
  37. Fl_Knob *m_Density;
  38. //// Callbacks ////
  39. inline void cb_Random_i(Fl_Knob* o, void* v);
  40. static void cb_Random(Fl_Knob*, void*);
  41. inline void cb_Pitch_i(Fl_Knob* o, void* v);
  42. static void cb_Pitch(Fl_Knob*, void*);
  43. inline void cb_MinGrainSize_i(Fl_Knob* o, void* v);
  44. static void cb_MinGrainSize(Fl_Knob*, void*);
  45. inline void cb_GrainStoreSize_i(Fl_Knob* o, void* v);
  46. static void cb_GrainStoreSize(Fl_Knob*, void*);
  47. inline void cb_Density_i(Fl_Knob* o, void* v);
  48. static void cb_Density(Fl_Knob*, void*);
  49. };
  50. #endif