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.

338 lines
6.4KB

  1. /* SpiralSound
  2. * Copyleft (C) 2001 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 <stdio.h>
  19. #include "ControllerPlugin.h"
  20. #include "ControllerPluginGUI.h"
  21. #include <Fl/Fl_Button.H>
  22. #include "SpiralIcon.xpm"
  23. using namespace std;
  24. extern "C" {
  25. SpiralPlugin* SpiralPlugin_CreateInstance()
  26. {
  27. return new ControllerPlugin;
  28. }
  29. char** SpiralPlugin_GetIcon()
  30. {
  31. return SpiralIcon_xpm;
  32. }
  33. int SpiralPlugin_GetID()
  34. {
  35. return 0x0003;
  36. }
  37. string SpiralPlugin_GetGroupName()
  38. {
  39. return "Control";
  40. }
  41. }
  42. ///////////////////////////////////////////////////////
  43. ControllerPlugin::ControllerPlugin() :
  44. m_Num(4)
  45. {
  46. m_Version=5;
  47. m_PluginInfo.Name="CV";
  48. m_PluginInfo.Width=240;
  49. m_PluginInfo.Height=224;
  50. m_PluginInfo.NumInputs=0;
  51. m_PluginInfo.NumOutputs=4;
  52. m_PluginInfo.PortTips.push_back("CV 1");
  53. m_PluginInfo.PortTips.push_back("CV 2");
  54. m_PluginInfo.PortTips.push_back("CV 3");
  55. m_PluginInfo.PortTips.push_back("CV 4");
  56. for (int n=0; n<MAX_CHANNELS; n++)
  57. {
  58. m_ChannelVal[n]=0.0f;
  59. m_MinVal[n]=-1.0f;
  60. m_MaxVal[n]=1.0f;
  61. m_Names[n]="Name";
  62. }
  63. m_AudioCH->Register("Number",&m_GUIArgs.Number);
  64. m_AudioCH->Register("Value",&m_GUIArgs.Value);
  65. m_AudioCH->Register("Min",&m_GUIArgs.Min);
  66. m_AudioCH->Register("Max",&m_GUIArgs.Max);
  67. m_AudioCH->RegisterData("Name",ChannelHandler::INPUT,m_GUIArgs.Name,256);
  68. }
  69. ControllerPlugin::~ControllerPlugin()
  70. {
  71. }
  72. PluginInfo &ControllerPlugin::Initialise(const HostInfo *Host)
  73. {
  74. return SpiralPlugin::Initialise(Host);
  75. }
  76. SpiralGUIType *ControllerPlugin::CreateGUI()
  77. {
  78. return new ControllerPluginGUI(m_PluginInfo.Width,
  79. m_PluginInfo.Height,
  80. this,m_AudioCH,m_HostInfo);
  81. }
  82. void ControllerPlugin::Execute()
  83. {
  84. for(int c=0; c<m_Num; c++)
  85. {
  86. for (int n=0; n<m_HostInfo->BUFSIZE; n++)
  87. {
  88. SetOutput(c,n,m_ChannelVal[c]);
  89. }
  90. }
  91. }
  92. void ControllerPlugin::ExecuteCommands()
  93. {
  94. if (m_AudioCH->IsCommandWaiting())
  95. {
  96. switch (m_AudioCH->GetCommand())
  97. {
  98. case (SETNUM) :
  99. SetNum(m_GUIArgs.Number);
  100. break;
  101. case (SETALL) :
  102. SetAll(m_GUIArgs.Number, m_GUIArgs.Name, m_GUIArgs.Max, m_GUIArgs.Value, m_GUIArgs.Min);
  103. break;
  104. case (SETNAME) :
  105. SetName(m_GUIArgs.Number, m_GUIArgs.Name);
  106. break;
  107. case (SETMAX) :
  108. SetMax(m_GUIArgs.Number, m_GUIArgs.Max);
  109. break;
  110. case (SETCHANNEL) :
  111. SetChannel(m_GUIArgs.Number, m_GUIArgs.Value);
  112. break;
  113. case (SETMIN) :
  114. SetMin(m_GUIArgs.Number, m_GUIArgs.Min);
  115. break;
  116. }
  117. }
  118. }
  119. void ControllerPlugin::SetNum(int n)
  120. {
  121. // once to clear the connections with the current info
  122. UpdatePluginInfoWithHost();
  123. if (m_Num<n)
  124. {
  125. char t[256];
  126. sprintf(t,"CV %d",n);
  127. m_PluginInfo.PortTips.push_back(t);
  128. AddOutput();
  129. m_PluginInfo.NumOutputs++;
  130. }
  131. else
  132. {
  133. vector<string>::iterator i=m_PluginInfo.PortTips.end();
  134. m_PluginInfo.PortTips.erase(i--);
  135. RemoveOutput();
  136. m_PluginInfo.NumOutputs--;
  137. }
  138. m_Num=n;
  139. m_PluginInfo.NumOutputs=n;
  140. // do the actual update
  141. UpdatePluginInfoWithHost();
  142. }
  143. // use with caution
  144. void ControllerPlugin::Clear()
  145. {
  146. m_PluginInfo.PortTips.clear();
  147. RemoveAllOutputs();
  148. m_PluginInfo.NumOutputs=0;
  149. }
  150. void ControllerPlugin::StreamOut(ostream &s)
  151. {
  152. s<<m_Version<<" ";
  153. switch (m_Version)
  154. {
  155. case 5:
  156. {
  157. s<<m_Num<<endl;
  158. for (int n=0; n<m_Num; n++)
  159. {
  160. s<<m_Names[n].size()<<" ";
  161. s<<m_Names[n]<<" ";
  162. s<<m_MinVal[n]<<" ";
  163. s<<m_MaxVal[n]<<" ";
  164. s<<m_ChannelVal[n]<<endl;
  165. }
  166. } break;
  167. case 4:
  168. {
  169. s<<m_Num<<endl;
  170. for (int n=0; n<m_Num; n++)
  171. {
  172. s<<m_Names[n]<<" ";
  173. s<<m_MinVal[n]<<" ";
  174. s<<m_MaxVal[n]<<" ";
  175. s<<m_ChannelVal[n]<<endl;
  176. }
  177. } break;
  178. case 3:
  179. {
  180. s<<m_Num<<" ";
  181. for (int n=0; n<m_Num; n++)
  182. {
  183. s<<m_ChannelVal[n]<<" ";
  184. }
  185. s<<1<<endl;
  186. s<<m_Num<<" ";
  187. for (int n=0; n<m_Num; n++)
  188. {
  189. s<<m_Names[n].size()<<" ";
  190. s<<m_Names[n]<<" ";
  191. s<<m_MinVal[n]<<" ";
  192. s<<m_MaxVal[n]<<" ";
  193. s<<m_ChannelVal[n]<<endl;
  194. }
  195. } break;
  196. default :
  197. cerr<<"ControllerPlugin - I dont support this streaming version any more"<<endl;
  198. break;
  199. }
  200. }
  201. void ControllerPlugin::StreamIn(istream &s)
  202. {
  203. int version;
  204. s>>version;
  205. switch (version)
  206. {
  207. case 5:
  208. {
  209. Clear();
  210. s>>m_Num;
  211. string name;
  212. for (int n=0; n<m_Num; n++)
  213. {
  214. char Buf[4096];
  215. int size,dummy;
  216. s>>size;
  217. s.ignore(1);
  218. if (size > 0) {
  219. s.get(Buf,size+1);
  220. m_Names[n]=Buf;
  221. } else {
  222. m_Names[n] = "";
  223. }
  224. s>>m_MinVal[n];
  225. s>>m_MaxVal[n];
  226. s>>m_ChannelVal[n];
  227. }
  228. // add the channels one by one
  229. for (int n=0; n<m_Num; n++)
  230. {
  231. char t[256];
  232. sprintf(t,"CV %d",n);
  233. m_PluginInfo.PortTips.push_back(t);
  234. AddOutput();
  235. }
  236. m_PluginInfo.NumOutputs=m_Num;
  237. UpdatePluginInfoWithHost();
  238. } break;
  239. case 4:
  240. {
  241. Clear();
  242. s>>m_Num;
  243. string name;
  244. for (int n=0; n<m_Num; n++)
  245. {
  246. s>>m_Names[n];
  247. s>>m_MinVal[n];
  248. s>>m_MaxVal[n];
  249. s>>m_ChannelVal[n];
  250. }
  251. // add the channels one by one
  252. for (int n=0; n<m_Num; n++)
  253. {
  254. char t[256];
  255. sprintf(t,"CV %d",n);
  256. m_PluginInfo.PortTips.push_back(t);
  257. AddOutput();
  258. }
  259. m_PluginInfo.NumOutputs=m_Num;
  260. UpdatePluginInfoWithHost();
  261. } break;
  262. case 3:
  263. {
  264. Clear();
  265. s>>m_Num;
  266. for (int n=0; n<m_Num; n++)
  267. {
  268. s>>m_ChannelVal[n];
  269. }
  270. char Buf[4096];
  271. int size,dummy;
  272. s>>dummy;
  273. s>>m_Num;
  274. for (int n=0; n<m_Num; n++)
  275. {
  276. s>>size;
  277. s.ignore(1);
  278. s.get(Buf,size+1);
  279. m_Names[n]=Buf;
  280. s>>m_MinVal[n];
  281. s>>m_MaxVal[n];
  282. s>>m_ChannelVal[n];
  283. }
  284. // add the channels one by one
  285. for (int n=0; n<m_Num; n++)
  286. {
  287. char t[256];
  288. sprintf(t,"CV %d",n);
  289. m_PluginInfo.PortTips.push_back(t);
  290. AddOutput();
  291. }
  292. m_PluginInfo.NumOutputs=m_Num;
  293. UpdatePluginInfoWithHost();
  294. } break;
  295. default :
  296. cerr<<"ControllerPlugin - I dont support this streaming version any more"<<endl;
  297. break;
  298. }
  299. }