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.

263 lines
7.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 "LogicPluginGUI.h"
  19. #include <FL/fl_draw.h>
  20. #include <FL/fl_draw.H>
  21. #include <stdio.h>
  22. ////////////////////////////////////////////
  23. LogicPluginGUI::LogicPluginGUI(int w, int h,LogicPlugin *o,ChannelHandler *ch,const HostInfo *Info) :
  24. SpiralPluginGUI(w,h,o,ch)
  25. {
  26. int Width=38, Depth=20;
  27. m_AND = new Fl_Button (2, 15, Width, Depth, "AND");
  28. m_AND->type (FL_TOGGLE_BUTTON);
  29. m_AND->value (1);
  30. m_AND->labelsize (10);
  31. m_AND->box (FL_PLASTIC_UP_BOX);
  32. m_AND->color (Info->GUI_COLOUR);
  33. m_AND->selection_color (Info->GUI_COLOUR);
  34. m_AND->callback ((Fl_Callback*)cb_AND);
  35. m_OR = new Fl_Button(2, 36, Width, Depth, "OR");
  36. m_OR->type (FL_TOGGLE_BUTTON);
  37. m_OR->labelsize (10);
  38. m_OR->box (FL_PLASTIC_UP_BOX);
  39. m_OR->color (Info->GUI_COLOUR);
  40. m_OR->selection_color (Info->GUI_COLOUR);
  41. m_OR->callback ((Fl_Callback*)cb_OR);
  42. m_NOT = new Fl_Button (2, 57, Width, Depth, "NOT");
  43. m_NOT->type (FL_TOGGLE_BUTTON);
  44. m_NOT->labelsize (10);
  45. m_NOT->box (FL_PLASTIC_UP_BOX);
  46. m_NOT->color (Info->GUI_COLOUR);
  47. m_NOT->selection_color (Info->GUI_COLOUR);
  48. m_NOT->callback ((Fl_Callback*)cb_NOT);
  49. m_NAND = new Fl_Button(2, 78, Width, Depth, "NAND");
  50. m_NAND->type (FL_TOGGLE_BUTTON);
  51. m_NAND->labelsize (10);
  52. m_NAND->box (FL_PLASTIC_UP_BOX);
  53. m_NAND->color (Info->GUI_COLOUR);
  54. m_NAND->selection_color (Info->GUI_COLOUR);
  55. m_NAND->callback ((Fl_Callback*)cb_NAND);
  56. m_NOR = new Fl_Button (41, 15, Width, Depth, "NOR");
  57. m_NOR->type (FL_TOGGLE_BUTTON);
  58. m_NOR->labelsize (10);
  59. m_NOR->box (FL_PLASTIC_UP_BOX);
  60. m_NOR->color (Info->GUI_COLOUR);
  61. m_NOR->selection_color (Info->GUI_COLOUR);
  62. m_NOR->callback ((Fl_Callback*)cb_NOR);
  63. m_XOR = new Fl_Button (41, 36, Width, Depth, "XOR");
  64. m_XOR->type (FL_TOGGLE_BUTTON);
  65. m_XOR->labelsize (10);
  66. m_XOR->box (FL_PLASTIC_UP_BOX);
  67. m_XOR->color (Info->GUI_COLOUR);
  68. m_XOR->selection_color (Info->GUI_COLOUR);
  69. m_XOR->callback ((Fl_Callback*)cb_XOR);
  70. m_XNOR = new Fl_Button (41, 57, Width, Depth, "XNOR");
  71. m_XNOR->type (FL_TOGGLE_BUTTON);
  72. m_XNOR->labelsize (10);
  73. m_XNOR->box (FL_PLASTIC_UP_BOX);
  74. m_XNOR->color (Info->GUI_COLOUR);
  75. m_XNOR->selection_color (Info->GUI_COLOUR);
  76. m_XNOR->callback ((Fl_Callback*)cb_XNOR);
  77. m_Inputs = new Fl_Counter (10, 104, 60, 20, "Inputs");
  78. m_Inputs->labelsize (10);
  79. m_Inputs->type (FL_SIMPLE_COUNTER);
  80. m_Inputs->box (FL_PLASTIC_UP_BOX);
  81. m_Inputs->color (Info->GUI_COLOUR);
  82. m_Inputs->step (1);
  83. m_Inputs->value (2);
  84. m_Inputs->callback ((Fl_Callback*) cb_Inputs);
  85. end();
  86. }
  87. void LogicPluginGUI::ClearButtons()
  88. {
  89. m_AND->value(false);
  90. m_OR->value(false);
  91. m_NOT->value(false);
  92. m_NAND->value(false);
  93. m_NOR->value(false);
  94. m_XOR->value(false);
  95. m_XNOR->value(false);
  96. }
  97. void LogicPluginGUI::UpdateValues(SpiralPlugin *o)
  98. {
  99. LogicPlugin* Plugin = (LogicPlugin*)o;
  100. ClearButtons();
  101. switch (Plugin->GetOperator())
  102. {
  103. case LogicPlugin::AND : m_AND->value (true); break;
  104. case LogicPlugin::OR : m_OR->value (true); break;
  105. case LogicPlugin::NOT : m_NOT->value (true); break;
  106. case LogicPlugin::NAND : m_NAND->value (true); break;
  107. case LogicPlugin::NOR : m_NOR->value (true); break;
  108. case LogicPlugin::XOR : m_XOR->value (true); break;
  109. case LogicPlugin::XNOR : m_XNOR->value (true); break;
  110. default: break;
  111. }
  112. m_Inputs->value (Plugin->GetInputs());
  113. }
  114. //// Callbacks ////
  115. inline void LogicPluginGUI::cb_Inputs_i (Fl_Counter* o, void* v) {
  116. if (o->value() < 2) o->value(2);
  117. else {
  118. m_GUICH->Set ("Inputs", int (o->value ()));
  119. m_GUICH->SetCommand (LogicPlugin::SETINPUTS);
  120. }
  121. }
  122. void LogicPluginGUI::cb_Inputs (Fl_Counter* o, void* v) {
  123. ((LogicPluginGUI*) (o->parent ())) -> cb_Inputs_i (o, v);
  124. }
  125. inline void LogicPluginGUI::cb_AND_i(Fl_Button* o, void* v)
  126. {
  127. if (o->value())
  128. {
  129. ClearButtons();
  130. o->value(true);
  131. m_GUICH->Set("Operator",(int)LogicPlugin::AND);
  132. }
  133. else
  134. {
  135. o->value(true);
  136. }
  137. }
  138. void LogicPluginGUI::cb_AND(Fl_Button* o, void* v)
  139. { ((LogicPluginGUI*)(o->parent()))->cb_AND_i(o,v);}
  140. inline void LogicPluginGUI::cb_OR_i(Fl_Button* o, void* v)
  141. {
  142. if (o->value())
  143. {
  144. ClearButtons();
  145. o->value(true);
  146. m_GUICH->Set("Operator",(int)LogicPlugin::OR);
  147. }
  148. else
  149. {
  150. o->value(true);
  151. }
  152. }
  153. void LogicPluginGUI::cb_OR(Fl_Button* o, void* v)
  154. { ((LogicPluginGUI*)(o->parent()))->cb_OR_i(o,v);}
  155. inline void LogicPluginGUI::cb_NOT_i(Fl_Button* o, void* v)
  156. {
  157. if (o->value())
  158. {
  159. ClearButtons();
  160. o->value(true);
  161. m_GUICH->Set("Operator",(int)LogicPlugin::NOT);
  162. }
  163. else
  164. {
  165. o->value(true);
  166. }
  167. }
  168. void LogicPluginGUI::cb_NOT(Fl_Button* o, void* v)
  169. { ((LogicPluginGUI*)(o->parent()))->cb_NOT_i(o,v);}
  170. inline void LogicPluginGUI::cb_NAND_i(Fl_Button* o, void* v)
  171. {
  172. if (o->value())
  173. {
  174. ClearButtons();
  175. o->value(true);
  176. m_GUICH->Set("Operator",(int)LogicPlugin::NAND);
  177. }
  178. else
  179. {
  180. o->value(true);
  181. }
  182. }
  183. void LogicPluginGUI::cb_NAND(Fl_Button* o, void* v)
  184. { ((LogicPluginGUI*)(o->parent()))->cb_NAND_i(o,v);}
  185. inline void LogicPluginGUI::cb_NOR_i(Fl_Button* o, void* v)
  186. {
  187. if (o->value())
  188. {
  189. ClearButtons();
  190. o->value(true);
  191. m_GUICH->Set("Operator",(int)LogicPlugin::NOR);
  192. }
  193. else
  194. {
  195. o->value(true);
  196. }
  197. }
  198. void LogicPluginGUI::cb_NOR(Fl_Button* o, void* v)
  199. { ((LogicPluginGUI*)(o->parent()))->cb_NOR_i(o,v);}
  200. inline void LogicPluginGUI::cb_XOR_i(Fl_Button* o, void* v)
  201. {
  202. if (o->value())
  203. {
  204. ClearButtons();
  205. o->value(true);
  206. m_GUICH->Set("Operator",(int)LogicPlugin::XOR);
  207. }
  208. else
  209. {
  210. o->value(true);
  211. }
  212. }
  213. void LogicPluginGUI::cb_XOR(Fl_Button* o, void* v)
  214. { ((LogicPluginGUI*)(o->parent()))->cb_XOR_i(o,v);}
  215. inline void LogicPluginGUI::cb_XNOR_i(Fl_Button* o, void* v)
  216. {
  217. if (o->value())
  218. {
  219. ClearButtons();
  220. o->value(true);
  221. m_GUICH->Set("Operator",(int)LogicPlugin::XNOR);
  222. }
  223. else
  224. {
  225. o->value(true);
  226. }
  227. }
  228. void LogicPluginGUI::cb_XNOR(Fl_Button* o, void* v)
  229. { ((LogicPluginGUI*)(o->parent()))->cb_XNOR_i(o,v);}
  230. const string LogicPluginGUI::GetHelpText(const string &loc){
  231. return string("")
  232. + "Note that NOT only uses input 1,\nand XOR/XNOR only use inputs 1 and 2\n\n"
  233. + "1001010111010101101111101010100101010101010100010100100101\n"
  234. + "0010101010111010010010101010001010011110001010101000101010\n"
  235. + "1110111101101001000010101010111110101010101010101111010101\n"
  236. + "0011011111010101101000001010101010001010100001100111010111";
  237. }