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.

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