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.

124 lines
4.1KB

  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 "MasherPluginGUI.h"
  19. #include <FL/fl_draw.H>
  20. #include <FL/fl_draw.H>
  21. using namespace std;
  22. ////////////////////////////////////////////
  23. MasherPluginGUI::MasherPluginGUI(int w, int h,MasherPlugin *o,ChannelHandler *ch,const HostInfo *Info) :
  24. SpiralPluginGUI(w,h,o,ch)
  25. {
  26. m_Plugin=o;
  27. m_Pitch = new Fl_Knob (5, 20, 40, 40, "GrainPitch");
  28. m_Pitch->type(Fl_Knob::DOTLIN);
  29. m_Pitch->color(Info->GUI_COLOUR);
  30. m_Pitch->labelsize(10);
  31. m_Pitch->maximum(5);
  32. m_Pitch->step(0.001);
  33. m_Pitch->value(1);
  34. m_Pitch->callback((Fl_Callback*)cb_Pitch);
  35. m_Random = new Fl_Knob (70, 20, 40, 40, "Randomness");
  36. m_Random->type(Fl_Knob::DOTLIN);
  37. m_Random->color(Info->GUI_COLOUR);
  38. m_Random->labelsize(10);
  39. m_Random->maximum(100);
  40. m_Random->step(1);
  41. m_Random->value(1);
  42. m_Random->callback((Fl_Callback*)cb_Random);
  43. m_GrainStoreSize = new Fl_Knob (5, 80, 40, 40, "Num Grains");
  44. m_GrainStoreSize->type(Fl_Knob::DOTLIN);
  45. m_GrainStoreSize->color(Info->GUI_COLOUR);
  46. m_GrainStoreSize->labelsize(10);
  47. m_GrainStoreSize->maximum(MAX_GRAINSTORE_SIZE-2);
  48. m_GrainStoreSize->step(1);
  49. m_GrainStoreSize->value(1);
  50. m_GrainStoreSize->callback((Fl_Callback*)cb_GrainStoreSize);
  51. m_Density = new Fl_Knob (70, 80, 40, 40, "Density");
  52. m_Density->type(Fl_Knob::DOTLIN);
  53. m_Density->color(Info->GUI_COLOUR);
  54. m_Density->labelsize(10);
  55. m_Density->maximum(MAX_GRAINSTORE_SIZE);
  56. m_Density->step(1);
  57. m_Density->value(1);
  58. m_Density->callback((Fl_Callback*)cb_Density);
  59. end();
  60. }
  61. extern "C" int sprintf(char *,const char *,...);
  62. void MasherPluginGUI::UpdateValues(SpiralPlugin *o)
  63. {
  64. MasherPlugin* Plugin = (MasherPlugin*)o;
  65. m_Pitch->value(Plugin->GetGrainPitch());
  66. m_Random->value(Plugin->GetRandomness());
  67. m_GrainStoreSize->value(Plugin->GetGrainStoreSize());
  68. m_Density->value(Plugin->GetDensity());
  69. }
  70. inline void MasherPluginGUI::cb_Random_i(Fl_Knob* o, void* v)
  71. {
  72. m_GUICH->Set("Randomness",(int)o->value());
  73. }
  74. void MasherPluginGUI::cb_Random(Fl_Knob* o, void* v)
  75. { ((MasherPluginGUI*)(o->parent()))->cb_Random_i(o,v); }
  76. inline void MasherPluginGUI::cb_Pitch_i(Fl_Knob* o, void* v)
  77. {
  78. m_GUICH->Set("GrainPitch",(float)o->value());
  79. }
  80. void MasherPluginGUI::cb_Pitch(Fl_Knob* o, void* v)
  81. { ((MasherPluginGUI*)(o->parent()))->cb_Pitch_i(o,v); }
  82. inline void MasherPluginGUI::cb_MinGrainSize_i(Fl_Knob* o, void* v)
  83. {
  84. m_GUICH->Set("Period",(int)o->value()+1);
  85. }
  86. void MasherPluginGUI::cb_MinGrainSize(Fl_Knob* o, void* v)
  87. { ((MasherPluginGUI*)(o->parent()))->cb_MinGrainSize_i(o,v); }
  88. inline void MasherPluginGUI::cb_GrainStoreSize_i(Fl_Knob* o, void* v)
  89. {
  90. m_GUICH->Set("GrainStoreSize",(int)o->value()+1);
  91. }
  92. void MasherPluginGUI::cb_GrainStoreSize(Fl_Knob* o, void* v)
  93. { ((MasherPluginGUI*)(o->parent()))->cb_GrainStoreSize_i(o,v); }
  94. inline void MasherPluginGUI::cb_Density_i(Fl_Knob* o, void* v)
  95. {
  96. m_GUICH->Set("Density",(int)o->value());
  97. }
  98. void MasherPluginGUI::cb_Density(Fl_Knob* o, void* v)
  99. { ((MasherPluginGUI*)(o->parent()))->cb_Density_i(o,v); }
  100. const string MasherPluginGUI::GetHelpText(const string &loc){
  101. return string("")
  102. + "Top secret sample masher plugin. Granulates the incoming stream and\n"
  103. + "carries out various patented algorithms on the result.\n\n"
  104. + "Truth is I don't really know how it works, but makes sounds like\n"
  105. + "tttttthhhIIiissssSSSSSSsssssSsSSsS.";
  106. }