Audio plugin host https://kx.studio/carla
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.

848 lines
26KB

  1. /*
  2. * ZaMultiCompX2 Stereo multiband compressor
  3. * Copyright (C) 2014 Damien Zammit <damien@zamaudio.com>
  4. *
  5. * This program is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU General Public License as
  7. * published by the Free Software Foundation; either version 2 of
  8. * the License, or any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * For a full copy of the GNU General Public License see the doc/GPL.txt file.
  16. */
  17. #include "ZaMultiCompX2Plugin.hpp"
  18. #include "ZaMultiCompX2UI.hpp"
  19. using DGL::Point;
  20. START_NAMESPACE_DISTRHO
  21. // -----------------------------------------------------------------------
  22. ZaMultiCompX2UI::ZaMultiCompX2UI()
  23. : UI()
  24. {
  25. // background
  26. fImgBackground = Image(ZaMultiCompX2Artwork::zamulticompx2Data, ZaMultiCompX2Artwork::zamulticompx2Width, ZaMultiCompX2Artwork::zamulticompx2Height, GL_BGR);
  27. // led images
  28. fLedRedImg = Image(ZaMultiCompX2Artwork::ledredData, ZaMultiCompX2Artwork::ledredWidth, ZaMultiCompX2Artwork::ledredHeight);
  29. fLedYellowImg = Image(ZaMultiCompX2Artwork::ledyellowData, ZaMultiCompX2Artwork::ledyellowWidth, ZaMultiCompX2Artwork::ledyellowHeight);
  30. // led values
  31. fLedRedValue1 = 0.0f;
  32. fLedRedValue2 = 0.0f;
  33. fLedRedValue3 = 0.0f;
  34. fLedYellowValueL = 0.0f;
  35. fLedYellowValueR = 0.0f;
  36. // knob
  37. Image knobImage(ZaMultiCompX2Artwork::knobData, ZaMultiCompX2Artwork::knobWidth, ZaMultiCompX2Artwork::knobHeight);
  38. // knob
  39. fKnobAttack = new ImageKnob(this, knobImage);
  40. fKnobAttack->setAbsolutePos(24, 43);
  41. fKnobAttack->setRange(0.1f, 200.0f);
  42. fKnobAttack->setUsingLogScale(true);
  43. fKnobAttack->setDefault(10.0f);
  44. fKnobAttack->setStep(0.1f);
  45. fKnobAttack->setRotationAngle(240);
  46. fKnobAttack->setCallback(this);
  47. fKnobRelease = new ImageKnob(this, knobImage);
  48. fKnobRelease->setAbsolutePos(108, 43);
  49. fKnobRelease->setRange(50.0f, 500.0f);
  50. fKnobRelease->setDefault(80.0f);
  51. fKnobRelease->setRotationAngle(240);
  52. fKnobRelease->setCallback(this);
  53. fKnobThresh3 = new ImageKnob(this, knobImage);
  54. fKnobThresh3->setAbsolutePos(94.5, 99);
  55. fKnobThresh3->setRange(-60.0f, 0.0f);
  56. fKnobThresh3->setDefault(-16.0f);
  57. fKnobThresh3->setRotationAngle(240);
  58. fKnobThresh3->setCallback(this);
  59. fKnobThresh2 = new ImageKnob(this, knobImage);
  60. fKnobThresh2->setAbsolutePos(94.5, 150);
  61. fKnobThresh2->setRange(-60.0f, 0.0f);
  62. fKnobThresh2->setDefault(-18.0f);
  63. fKnobThresh2->setRotationAngle(240);
  64. fKnobThresh2->setCallback(this);
  65. fKnobThresh1 = new ImageKnob(this, knobImage);
  66. fKnobThresh1->setAbsolutePos(94.5, 201);
  67. fKnobThresh1->setRange(-60.0f, 0.0f);
  68. fKnobThresh1->setDefault(-20.0f);
  69. fKnobThresh1->setRotationAngle(240);
  70. fKnobThresh1->setCallback(this);
  71. fKnobRatio = new ImageKnob(this, knobImage);
  72. fKnobRatio->setAbsolutePos(191.5, 43);
  73. fKnobRatio->setRange(1.0f, 20.0f);
  74. fKnobRatio->setDefault(4.0f);
  75. fKnobRatio->setRotationAngle(240);
  76. fKnobRatio->setCallback(this);
  77. fKnobKnee = new ImageKnob(this, knobImage);
  78. fKnobKnee->setAbsolutePos(273, 43);
  79. fKnobKnee->setRange(0.0f, 8.0f);
  80. fKnobKnee->setDefault(0.0f);
  81. fKnobKnee->setRotationAngle(240);
  82. fKnobKnee->setCallback(this);
  83. fKnobGlobalGain = new ImageKnob(this, knobImage);
  84. fKnobGlobalGain->setAbsolutePos(427.3, 43);
  85. fKnobGlobalGain->setRange(-30.0f, 30.0f);
  86. fKnobGlobalGain->setDefault(0.0f);
  87. fKnobGlobalGain->setRotationAngle(240);
  88. fKnobGlobalGain->setCallback(this);
  89. fKnobXover2 = new ImageKnob(this, knobImage);
  90. fKnobXover2->setAbsolutePos(23, 121);
  91. fKnobXover2->setRange(1400.f, 14000.f);
  92. fKnobXover2->setUsingLogScale(true);
  93. fKnobXover2->setDefault(1400.f);
  94. fKnobXover2->setStep(5.f);
  95. fKnobXover2->setRotationAngle(240);
  96. fKnobXover2->setCallback(this);
  97. fKnobXover1 = new ImageKnob(this, knobImage);
  98. fKnobXover1->setAbsolutePos(23, 175.5);
  99. fKnobXover1->setRange(20.0f, 1400.0f);
  100. fKnobXover1->setUsingLogScale(true);
  101. fKnobXover1->setDefault(250.0f);
  102. fKnobXover1->setStep(1.f);
  103. fKnobXover1->setRotationAngle(240);
  104. fKnobXover1->setCallback(this);
  105. fKnobMakeup3 = new ImageKnob(this, knobImage);
  106. fKnobMakeup3->setAbsolutePos(167.75, 99.5);
  107. fKnobMakeup3->setRange(0.0f, 30.0f);
  108. fKnobMakeup3->setDefault(0.0f);
  109. fKnobMakeup3->setRotationAngle(240);
  110. fKnobMakeup3->setCallback(this);
  111. fKnobMakeup2 = new ImageKnob(this, knobImage);
  112. fKnobMakeup2->setAbsolutePos(167.75, 150.25);
  113. fKnobMakeup2->setRange(0.0f, 30.0f);
  114. fKnobMakeup2->setDefault(0.0f);
  115. fKnobMakeup2->setRotationAngle(240);
  116. fKnobMakeup2->setCallback(this);
  117. fKnobMakeup1 = new ImageKnob(this, knobImage);
  118. fKnobMakeup1->setAbsolutePos(167.75, 201.4);
  119. fKnobMakeup1->setRange(0.0f, 30.0f);
  120. fKnobMakeup1->setDefault(0.0f);
  121. fKnobMakeup1->setRotationAngle(240);
  122. fKnobMakeup1->setCallback(this);
  123. Image toggleonImage(ZaMultiCompX2Artwork::toggleonData, ZaMultiCompX2Artwork::toggleonWidth, ZaMultiCompX2Artwork::toggleonHeight);
  124. Image toggleoffImage(ZaMultiCompX2Artwork::toggleoffData, ZaMultiCompX2Artwork::toggleoffWidth, ZaMultiCompX2Artwork::toggleoffHeight);
  125. Image toggleonhImage(ZaMultiCompX2Artwork::toggleonhorizData, ZaMultiCompX2Artwork::toggleonhorizWidth, ZaMultiCompX2Artwork::toggleonhorizHeight);
  126. Image toggleoffhImage(ZaMultiCompX2Artwork::toggleoffhorizData, ZaMultiCompX2Artwork::toggleoffhorizWidth, ZaMultiCompX2Artwork::toggleoffhorizHeight);
  127. Point<int> togglePosStart(247,108);
  128. fToggleBypass3 = new ImageToggle(this, toggleoffImage, toggleonImage);
  129. fToggleBypass3->setAbsolutePos(togglePosStart);
  130. fToggleBypass3->setCallback(this);
  131. togglePosStart.setY(158);
  132. fToggleBypass2 = new ImageToggle(this, toggleoffImage, toggleonImage);
  133. fToggleBypass2->setAbsolutePos(togglePosStart);
  134. fToggleBypass2->setCallback(this);
  135. togglePosStart.setY(209);
  136. fToggleBypass1 = new ImageToggle(this, toggleoffImage, toggleonImage);
  137. fToggleBypass1->setAbsolutePos(togglePosStart);
  138. fToggleBypass1->setCallback(this);
  139. togglePosStart.setX(278);
  140. togglePosStart.setY(113);
  141. fToggleListen3 = new ImageToggle(this, toggleoffhImage, toggleonhImage);
  142. fToggleListen3->setAbsolutePos(togglePosStart);
  143. fToggleListen3->setCallback(this);
  144. togglePosStart.setY(164);
  145. fToggleListen2 = new ImageToggle(this, toggleoffhImage, toggleonhImage);
  146. fToggleListen2->setAbsolutePos(togglePosStart);
  147. fToggleListen2->setCallback(this);
  148. togglePosStart.setY(214);
  149. fToggleListen1 = new ImageToggle(this, toggleoffhImage, toggleonhImage);
  150. fToggleListen1->setAbsolutePos(togglePosStart);
  151. fToggleListen1->setCallback(this);
  152. togglePosStart.setX(285.5);
  153. togglePosStart.setY(254);
  154. fToggleStereo = new ImageToggle(this, toggleoffImage, toggleonImage);
  155. fToggleStereo->setAbsolutePos(togglePosStart);
  156. fToggleStereo->setCallback(this);
  157. fCanvasArea.setPos(540, 32);
  158. fCanvasArea.setSize(102, 102);
  159. fThresh[0] = -20.f;
  160. fThresh[1] = -18.f;
  161. fThresh[2] = -16.f;
  162. fRatio = 4.f;
  163. fKnee = 0.f;
  164. fMakeup[0] = 0.f;
  165. fMakeup[1] = 0.f;
  166. fMakeup[2] = 0.f;
  167. fBypass[0] = 0.f;
  168. fBypass[1] = 0.f;
  169. fBypass[2] = 0.f;
  170. fMaster = 0.f;
  171. int i,k;
  172. for (k = 0; k < MAX_COMP; ++k) {
  173. for (i = 0; i < COMPOINTS; ++i) {
  174. compx[k][i] = fCanvasArea.getX();
  175. compy[k][i] = fCanvasArea.getY() + fCanvasArea.getHeight();
  176. }
  177. }
  178. // set default values
  179. d_programChanged(0);
  180. }
  181. void ZaMultiCompX2UI::compcurve(float in, int k, float *outx, float* outy) {
  182. float knee = fKnee;
  183. float ratio = fRatio;
  184. float makeup = fMakeup[k] + fMaster;
  185. float thresdb = fThresh[k];
  186. float width=((knee+1.f)-0.99f)*6.f;
  187. float xg, yg;
  188. yg = 0.f;
  189. xg = (in==0.f) ? -160.f : to_dB(fabs(in));
  190. xg = sanitize_denormal(xg);
  191. if (2.f*(xg-thresdb)<-width) {
  192. yg = xg;
  193. } else if (2.f*fabs(xg-thresdb)<=width) {
  194. yg = xg + (1.f/ratio-1.f)*(xg-thresdb+width/2.f)*(xg-thresdb+width/2.f)/(2.f*width);
  195. } else if (2.f*(xg-thresdb)>width) {
  196. yg = thresdb + (xg-thresdb)/ratio;
  197. }
  198. yg = sanitize_denormal(yg);
  199. *outx = (to_dB(in) + 1.) / 55. + 1.;
  200. *outy = !fBypass[k] ? (to_dB(in) + fMaster + 1.) / 55. + 1. : (yg + makeup + 1.) / 55. + 1.;
  201. //printf("x = %f y = %f\n",*outx,*outy);
  202. }
  203. void ZaMultiCompX2UI::calc_compcurves() {
  204. float max_x = 1.f;
  205. float min_x = 0.f;
  206. float x2;
  207. for (int k = 0; k < MAX_COMP; ++k) {
  208. for (int i = 0; i < COMPOINTS; ++i) {
  209. x2 = (max_x - min_x) / COMPOINTS * i + min_x;
  210. compcurve(x2, k, &compx[k][i], &compy[k][i]);
  211. compx[k][i] = fCanvasArea.getX() + compx[k][i]*fCanvasArea.getWidth();
  212. compy[k][i] = fCanvasArea.getY() + (1.-compy[k][i])*fCanvasArea.getHeight();
  213. }
  214. //dot follows curve:
  215. //compcurve(from_dB(-ui->gainred), k, &dotx[0], &doty[0]);
  216. //dotx[0] = -(1-dotx[0])*280. + 280.;
  217. //doty[0] = (1.-doty[0])*280.;
  218. //dot follows centre:
  219. //dotx[0] = -(1.- from_dB(-gainred))*280. + 280.;
  220. //doty[0] = (1.- from_dB(-gainred))*280.;
  221. //printf("gainr=%.2f x=%.2f y=%.2f\n",ui->gainred, ui->dotx[0], ui->doty[0]);
  222. }
  223. }
  224. // -----------------------------------------------------------------------
  225. // DSP Callbacks
  226. void ZaMultiCompX2UI::d_parameterChanged(uint32_t index, float value)
  227. {
  228. switch (index)
  229. {
  230. case ZaMultiCompX2Plugin::paramAttack:
  231. fKnobAttack->setValue(value);
  232. break;
  233. case ZaMultiCompX2Plugin::paramRelease:
  234. fKnobRelease->setValue(value);
  235. break;
  236. case ZaMultiCompX2Plugin::paramThresh1:
  237. fKnobThresh1->setValue(value);
  238. fThresh[0] = value;
  239. break;
  240. case ZaMultiCompX2Plugin::paramThresh2:
  241. fKnobThresh2->setValue(value);
  242. fThresh[1] = value;
  243. break;
  244. case ZaMultiCompX2Plugin::paramThresh3:
  245. fKnobThresh3->setValue(value);
  246. fThresh[2] = value;
  247. break;
  248. case ZaMultiCompX2Plugin::paramRatio:
  249. fKnobRatio->setValue(value);
  250. fRatio = value;
  251. break;
  252. case ZaMultiCompX2Plugin::paramKnee:
  253. fKnobKnee->setValue(value);
  254. fKnee = value;
  255. break;
  256. case ZaMultiCompX2Plugin::paramGlobalGain:
  257. fKnobGlobalGain->setValue(value);
  258. fMaster = value;
  259. break;
  260. case ZaMultiCompX2Plugin::paramGainR1:
  261. if (fLedRedValue1 != value)
  262. {
  263. fLedRedValue1 = value;
  264. repaint();
  265. }
  266. break;
  267. case ZaMultiCompX2Plugin::paramGainR2:
  268. if (fLedRedValue2 != value)
  269. {
  270. fLedRedValue2 = value;
  271. repaint();
  272. }
  273. break;
  274. case ZaMultiCompX2Plugin::paramGainR3:
  275. if (fLedRedValue3 != value)
  276. {
  277. fLedRedValue3 = value;
  278. repaint();
  279. }
  280. break;
  281. case ZaMultiCompX2Plugin::paramOutputLevelL:
  282. if (fLedYellowValueL != value)
  283. {
  284. fLedYellowValueL = value;
  285. repaint();
  286. }
  287. break;
  288. case ZaMultiCompX2Plugin::paramOutputLevelR:
  289. if (fLedYellowValueR != value)
  290. {
  291. fLedYellowValueR = value;
  292. repaint();
  293. }
  294. break;
  295. case ZaMultiCompX2Plugin::paramMakeup1:
  296. fKnobMakeup1->setValue(value);
  297. if (fMakeup[0] != value)
  298. {
  299. fMakeup[0] = value;
  300. repaint();
  301. }
  302. break;
  303. case ZaMultiCompX2Plugin::paramMakeup2:
  304. fKnobMakeup2->setValue(value);
  305. if (fMakeup[1] != value)
  306. {
  307. fMakeup[1] = value;
  308. repaint();
  309. }
  310. break;
  311. case ZaMultiCompX2Plugin::paramMakeup3:
  312. fKnobMakeup3->setValue(value);
  313. if (fMakeup[2] != value)
  314. {
  315. fMakeup[2] = value;
  316. repaint();
  317. }
  318. break;
  319. case ZaMultiCompX2Plugin::paramToggle1:
  320. fToggleBypass1->setValue(value);
  321. if (fBypass[0] != value)
  322. {
  323. fBypass[0] = value;
  324. repaint();
  325. }
  326. break;
  327. case ZaMultiCompX2Plugin::paramToggle2:
  328. fToggleBypass2->setValue(value);
  329. if (fBypass[1] != value)
  330. {
  331. fBypass[1] = value;
  332. repaint();
  333. }
  334. break;
  335. case ZaMultiCompX2Plugin::paramToggle3:
  336. fToggleBypass3->setValue(value);
  337. if (fBypass[2] != value)
  338. {
  339. fBypass[2] = value;
  340. repaint();
  341. }
  342. break;
  343. case ZaMultiCompX2Plugin::paramListen1:
  344. fToggleListen1->setValue(value);
  345. break;
  346. case ZaMultiCompX2Plugin::paramListen2:
  347. fToggleListen2->setValue(value);
  348. break;
  349. case ZaMultiCompX2Plugin::paramListen3:
  350. fToggleListen3->setValue(value);
  351. break;
  352. }
  353. }
  354. void ZaMultiCompX2UI::d_programChanged(uint32_t index)
  355. {
  356. if (index != 0)
  357. return;
  358. // Default values
  359. fKnobAttack->setValue(10.0f);
  360. fKnobRelease->setValue(80.0f);
  361. /*
  362. * fKnobThresh->setValue(-6.0f);
  363. fKnobRatio->setValue(4.0f);
  364. fKnobKnee->setValue(0.0f);
  365. fKnobGlobalGain->setValue(0.0f);
  366. fKnobMakeup1->setValue(0.0f);
  367. fKnobMakeup2->setValue(0.0f);
  368. fKnobMakeup3->setValue(0.0f);
  369. fKnobXover1->setValue(250.0f);
  370. fKnobXover2->setValue(1400.0f);
  371. */
  372. fToggleBypass1->setValue(0.0f);
  373. fToggleBypass2->setValue(0.0f);
  374. fToggleBypass3->setValue(0.0f);
  375. fToggleListen1->setValue(0.0f);
  376. fToggleListen2->setValue(0.0f);
  377. fToggleListen3->setValue(0.0f);
  378. fToggleStereo->setValue(0.0f);
  379. }
  380. void ZaMultiCompX2UI::d_stateChanged(const char*, const char*)
  381. {
  382. }
  383. // -----------------------------------------------------------------------
  384. // Widget Callbacks
  385. void ZaMultiCompX2UI::imageKnobDragStarted(ImageKnob* knob)
  386. {
  387. if (knob == fKnobAttack)
  388. d_editParameter(ZaMultiCompX2Plugin::paramAttack, true);
  389. else if (knob == fKnobRelease)
  390. d_editParameter(ZaMultiCompX2Plugin::paramRelease, true);
  391. else if (knob == fKnobThresh1)
  392. d_editParameter(ZaMultiCompX2Plugin::paramThresh1, true);
  393. else if (knob == fKnobThresh2)
  394. d_editParameter(ZaMultiCompX2Plugin::paramThresh2, true);
  395. else if (knob == fKnobThresh3)
  396. d_editParameter(ZaMultiCompX2Plugin::paramThresh3, true);
  397. else if (knob == fKnobRatio)
  398. d_editParameter(ZaMultiCompX2Plugin::paramRatio, true);
  399. else if (knob == fKnobKnee)
  400. d_editParameter(ZaMultiCompX2Plugin::paramKnee, true);
  401. else if (knob == fKnobGlobalGain)
  402. d_editParameter(ZaMultiCompX2Plugin::paramGlobalGain, true);
  403. else if (knob == fKnobMakeup1)
  404. d_editParameter(ZaMultiCompX2Plugin::paramMakeup1, true);
  405. else if (knob == fKnobMakeup2)
  406. d_editParameter(ZaMultiCompX2Plugin::paramMakeup2, true);
  407. else if (knob == fKnobMakeup3)
  408. d_editParameter(ZaMultiCompX2Plugin::paramMakeup3, true);
  409. else if (knob == fKnobXover1)
  410. d_editParameter(ZaMultiCompX2Plugin::paramXover1, true);
  411. else if (knob == fKnobXover2)
  412. d_editParameter(ZaMultiCompX2Plugin::paramXover2, true);
  413. }
  414. void ZaMultiCompX2UI::imageKnobDragFinished(ImageKnob* knob)
  415. {
  416. if (knob == fKnobAttack)
  417. d_editParameter(ZaMultiCompX2Plugin::paramAttack, false);
  418. else if (knob == fKnobRelease)
  419. d_editParameter(ZaMultiCompX2Plugin::paramRelease, false);
  420. else if (knob == fKnobThresh1)
  421. d_editParameter(ZaMultiCompX2Plugin::paramThresh1, false);
  422. else if (knob == fKnobThresh2)
  423. d_editParameter(ZaMultiCompX2Plugin::paramThresh2, false);
  424. else if (knob == fKnobThresh3)
  425. d_editParameter(ZaMultiCompX2Plugin::paramThresh3, false);
  426. else if (knob == fKnobRatio)
  427. d_editParameter(ZaMultiCompX2Plugin::paramRatio, false);
  428. else if (knob == fKnobKnee)
  429. d_editParameter(ZaMultiCompX2Plugin::paramKnee, false);
  430. else if (knob == fKnobGlobalGain)
  431. d_editParameter(ZaMultiCompX2Plugin::paramGlobalGain, false);
  432. else if (knob == fKnobMakeup1)
  433. d_editParameter(ZaMultiCompX2Plugin::paramMakeup1, false);
  434. else if (knob == fKnobMakeup2)
  435. d_editParameter(ZaMultiCompX2Plugin::paramMakeup2, false);
  436. else if (knob == fKnobMakeup3)
  437. d_editParameter(ZaMultiCompX2Plugin::paramMakeup3, false);
  438. else if (knob == fKnobXover1)
  439. d_editParameter(ZaMultiCompX2Plugin::paramXover1, false);
  440. else if (knob == fKnobXover2)
  441. d_editParameter(ZaMultiCompX2Plugin::paramXover2, false);
  442. }
  443. void ZaMultiCompX2UI::imageKnobValueChanged(ImageKnob* knob, float value)
  444. {
  445. if (knob == fKnobAttack)
  446. d_setParameterValue(ZaMultiCompX2Plugin::paramAttack, value);
  447. else if (knob == fKnobRelease)
  448. d_setParameterValue(ZaMultiCompX2Plugin::paramRelease, value);
  449. else if (knob == fKnobThresh1) {
  450. d_setParameterValue(ZaMultiCompX2Plugin::paramThresh1, value);
  451. fThresh[0] = value;
  452. }
  453. else if (knob == fKnobThresh2) {
  454. d_setParameterValue(ZaMultiCompX2Plugin::paramThresh2, value);
  455. fThresh[1] = value;
  456. }
  457. else if (knob == fKnobThresh3) {
  458. d_setParameterValue(ZaMultiCompX2Plugin::paramThresh3, value);
  459. fThresh[2] = value;
  460. }
  461. else if (knob == fKnobRatio) {
  462. d_setParameterValue(ZaMultiCompX2Plugin::paramRatio, value);
  463. fRatio = value;
  464. }
  465. else if (knob == fKnobKnee) {
  466. d_setParameterValue(ZaMultiCompX2Plugin::paramKnee, value);
  467. fKnee = value;
  468. }
  469. else if (knob == fKnobGlobalGain) {
  470. d_setParameterValue(ZaMultiCompX2Plugin::paramGlobalGain, value);
  471. fMaster = value;
  472. }
  473. else if (knob == fKnobMakeup1) {
  474. d_setParameterValue(ZaMultiCompX2Plugin::paramMakeup1, value);
  475. fMakeup[0] = value;
  476. }
  477. else if (knob == fKnobMakeup2) {
  478. d_setParameterValue(ZaMultiCompX2Plugin::paramMakeup2, value);
  479. fMakeup[1] = value;
  480. }
  481. else if (knob == fKnobMakeup3) {
  482. d_setParameterValue(ZaMultiCompX2Plugin::paramMakeup3, value);
  483. fMakeup[2] = value;
  484. }
  485. else if (knob == fKnobXover1)
  486. d_setParameterValue(ZaMultiCompX2Plugin::paramXover1, value);
  487. else if (knob == fKnobXover2)
  488. d_setParameterValue(ZaMultiCompX2Plugin::paramXover2, value);
  489. }
  490. void ZaMultiCompX2UI::imageToggleClicked(ImageToggle* toggle, int)
  491. {
  492. float v = toggle->getValue();
  493. if (toggle == fToggleBypass1) {
  494. d_setParameterValue(ZaMultiCompX2Plugin::paramToggle1, v);
  495. fBypass[0] = v;
  496. }
  497. else if (toggle == fToggleBypass2) {
  498. d_setParameterValue(ZaMultiCompX2Plugin::paramToggle2, v);
  499. fBypass[1] = v;
  500. }
  501. else if (toggle == fToggleBypass3) {
  502. d_setParameterValue(ZaMultiCompX2Plugin::paramToggle3, v);
  503. fBypass[2] = v;
  504. }
  505. else if (toggle == fToggleListen1)
  506. d_setParameterValue(ZaMultiCompX2Plugin::paramListen1, v);
  507. else if (toggle == fToggleListen2)
  508. d_setParameterValue(ZaMultiCompX2Plugin::paramListen2, v);
  509. else if (toggle == fToggleListen3)
  510. d_setParameterValue(ZaMultiCompX2Plugin::paramListen3, v);
  511. else if (toggle == fToggleStereo)
  512. d_setParameterValue(ZaMultiCompX2Plugin::paramStereoDet, v);
  513. }
  514. void ZaMultiCompX2UI::onDisplay()
  515. {
  516. fImgBackground.draw();
  517. d_setState("stateMeterReset", "");
  518. // draw leds
  519. static const float sLedSpacing = 15.5f;
  520. static const int sLedInitialX = 343;
  521. static const int sYellowLedStaticYL = 254.5;
  522. static const int sYellowLedStaticYR = 269.5;
  523. static const int sRedLed1StaticY = 215;
  524. static const int sRedLed2StaticY = 164;
  525. static const int sRedLed3StaticY = 113;
  526. int numRedLeds1;
  527. int numRedLeds2;
  528. int numRedLeds3;
  529. int numYellowLedsL;
  530. int numYellowLedsR;
  531. if (fLedRedValue1 >= 40.f)
  532. numRedLeds1 = 12;
  533. else if (fLedRedValue1 >= 30.f)
  534. numRedLeds1 = 11;
  535. else if (fLedRedValue1 >= 20.f)
  536. numRedLeds1 = 10;
  537. else if (fLedRedValue1 >= 15.f)
  538. numRedLeds1 = 9;
  539. else if (fLedRedValue1 >= 10.f)
  540. numRedLeds1 = 8;
  541. else if (fLedRedValue1 >= 8.f)
  542. numRedLeds1 = 7;
  543. else if (fLedRedValue1 >= 6.f)
  544. numRedLeds1 = 6;
  545. else if (fLedRedValue1 >= 5.f)
  546. numRedLeds1 = 5;
  547. else if (fLedRedValue1 >= 4.f)
  548. numRedLeds1 = 4;
  549. else if (fLedRedValue1 >= 3.f)
  550. numRedLeds1 = 3;
  551. else if (fLedRedValue1 >= 2.f)
  552. numRedLeds1 = 2;
  553. else if (fLedRedValue1 >= 1.f)
  554. numRedLeds1 = 1;
  555. else numRedLeds1 = 0;
  556. if (fLedRedValue2 >= 40.f)
  557. numRedLeds2 = 12;
  558. else if (fLedRedValue2 >= 30.f)
  559. numRedLeds2 = 11;
  560. else if (fLedRedValue2 >= 20.f)
  561. numRedLeds2 = 10;
  562. else if (fLedRedValue2 >= 15.f)
  563. numRedLeds2 = 9;
  564. else if (fLedRedValue2 >= 10.f)
  565. numRedLeds2 = 8;
  566. else if (fLedRedValue2 >= 8.f)
  567. numRedLeds2 = 7;
  568. else if (fLedRedValue2 >= 6.f)
  569. numRedLeds2 = 6;
  570. else if (fLedRedValue2 >= 5.f)
  571. numRedLeds2 = 5;
  572. else if (fLedRedValue2 >= 4.f)
  573. numRedLeds2 = 4;
  574. else if (fLedRedValue2 >= 3.f)
  575. numRedLeds2 = 3;
  576. else if (fLedRedValue2 >= 2.f)
  577. numRedLeds2 = 2;
  578. else if (fLedRedValue2 >= 1.f)
  579. numRedLeds2 = 1;
  580. else numRedLeds2 = 0;
  581. if (fLedRedValue3 >= 40.f)
  582. numRedLeds3 = 12;
  583. else if (fLedRedValue3 >= 30.f)
  584. numRedLeds3 = 11;
  585. else if (fLedRedValue3 >= 20.f)
  586. numRedLeds3 = 10;
  587. else if (fLedRedValue3 >= 15.f)
  588. numRedLeds3 = 9;
  589. else if (fLedRedValue3 >= 10.f)
  590. numRedLeds3 = 8;
  591. else if (fLedRedValue3 >= 8.f)
  592. numRedLeds3 = 7;
  593. else if (fLedRedValue3 >= 6.f)
  594. numRedLeds3 = 6;
  595. else if (fLedRedValue3 >= 5.f)
  596. numRedLeds3 = 5;
  597. else if (fLedRedValue3 >= 4.f)
  598. numRedLeds3 = 4;
  599. else if (fLedRedValue3 >= 3.f)
  600. numRedLeds3 = 3;
  601. else if (fLedRedValue3 >= 2.f)
  602. numRedLeds3 = 2;
  603. else if (fLedRedValue3 >= 1.f)
  604. numRedLeds3 = 1;
  605. else numRedLeds3 = 0;
  606. for (int i=numRedLeds1; i>0; --i)
  607. fLedRedImg.drawAt(sLedInitialX + (12 - i)*sLedSpacing, sRedLed1StaticY);
  608. for (int i=numRedLeds2; i>0; --i)
  609. fLedRedImg.drawAt(sLedInitialX + (12 - i)*sLedSpacing, sRedLed2StaticY);
  610. for (int i=numRedLeds3; i>0; --i)
  611. fLedRedImg.drawAt(sLedInitialX + (12 - i)*sLedSpacing, sRedLed3StaticY);
  612. if (fLedYellowValueL >= 20.f)
  613. numYellowLedsL = 19;
  614. else if (fLedYellowValueL >= 10.f)
  615. numYellowLedsL = 18;
  616. else if (fLedYellowValueL >= 8.f)
  617. numYellowLedsL = 17;
  618. else if (fLedYellowValueL >= 4.f)
  619. numYellowLedsL = 16;
  620. else if (fLedYellowValueL >= 2.f)
  621. numYellowLedsL = 15;
  622. else if (fLedYellowValueL >= 1.f)
  623. numYellowLedsL = 14;
  624. else if (fLedYellowValueL >= 0.f)
  625. numYellowLedsL = 13;
  626. else if (fLedYellowValueL >= -1.f)
  627. numYellowLedsL = 12;
  628. else if (fLedYellowValueL >= -2.f)
  629. numYellowLedsL = 11;
  630. else if (fLedYellowValueL >= -3.f)
  631. numYellowLedsL = 10;
  632. else if (fLedYellowValueL >= -4.f)
  633. numYellowLedsL = 9;
  634. else if (fLedYellowValueL >= -5.f)
  635. numYellowLedsL = 8;
  636. else if (fLedYellowValueL >= -6.f)
  637. numYellowLedsL = 7;
  638. else if (fLedYellowValueL >= -8.f)
  639. numYellowLedsL = 6;
  640. else if (fLedYellowValueL >= -10.f)
  641. numYellowLedsL = 5;
  642. else if (fLedYellowValueL >= -15.f)
  643. numYellowLedsL = 4;
  644. else if (fLedYellowValueL >= -20.f)
  645. numYellowLedsL = 3;
  646. else if (fLedYellowValueL >= -30.f)
  647. numYellowLedsL = 2;
  648. else if (fLedYellowValueL >= -40.f)
  649. numYellowLedsL = 1;
  650. else numYellowLedsL = 0;
  651. if (numYellowLedsL > 12) {
  652. for (int i=12; i<numYellowLedsL; ++i)
  653. fLedRedImg.drawAt(sLedInitialX + i*sLedSpacing, sYellowLedStaticYL);
  654. for (int i=0; i<12; ++i)
  655. fLedYellowImg.drawAt(sLedInitialX + i*sLedSpacing, sYellowLedStaticYL);
  656. } else {
  657. for (int i=0; i<numYellowLedsL; ++i)
  658. fLedYellowImg.drawAt(sLedInitialX + i*sLedSpacing, sYellowLedStaticYL);
  659. }
  660. if (fLedYellowValueR >= 20.f)
  661. numYellowLedsR = 19;
  662. else if (fLedYellowValueR >= 10.f)
  663. numYellowLedsR = 18;
  664. else if (fLedYellowValueR >= 8.f)
  665. numYellowLedsR = 17;
  666. else if (fLedYellowValueR >= 4.f)
  667. numYellowLedsR = 16;
  668. else if (fLedYellowValueR >= 2.f)
  669. numYellowLedsR = 15;
  670. else if (fLedYellowValueR >= 1.f)
  671. numYellowLedsR = 14;
  672. else if (fLedYellowValueR >= 0.f)
  673. numYellowLedsR = 13;
  674. else if (fLedYellowValueR >= -1.f)
  675. numYellowLedsR = 12;
  676. else if (fLedYellowValueR >= -2.f)
  677. numYellowLedsR = 11;
  678. else if (fLedYellowValueR >= -3.f)
  679. numYellowLedsR = 10;
  680. else if (fLedYellowValueR >= -4.f)
  681. numYellowLedsR = 9;
  682. else if (fLedYellowValueR >= -5.f)
  683. numYellowLedsR = 8;
  684. else if (fLedYellowValueR >= -6.f)
  685. numYellowLedsR = 7;
  686. else if (fLedYellowValueR >= -8.f)
  687. numYellowLedsR = 6;
  688. else if (fLedYellowValueR >= -10.f)
  689. numYellowLedsR = 5;
  690. else if (fLedYellowValueR >= -15.f)
  691. numYellowLedsR = 4;
  692. else if (fLedYellowValueR >= -20.f)
  693. numYellowLedsR = 3;
  694. else if (fLedYellowValueR >= -30.f)
  695. numYellowLedsR = 2;
  696. else if (fLedYellowValueR >= -40.f)
  697. numYellowLedsR = 1;
  698. else numYellowLedsR = 0;
  699. if (numYellowLedsR > 12) {
  700. for (int i=12; i<numYellowLedsR; ++i)
  701. fLedRedImg.drawAt(sLedInitialX + i*sLedSpacing, sYellowLedStaticYR);
  702. for (int i=0; i<12; ++i)
  703. fLedYellowImg.drawAt(sLedInitialX + i*sLedSpacing, sYellowLedStaticYR);
  704. } else {
  705. for (int i=0; i<numYellowLedsR; ++i)
  706. fLedYellowImg.drawAt(sLedInitialX + i*sLedSpacing, sYellowLedStaticYR);
  707. }
  708. /*
  709. // TESTING - remove later
  710. // this paints the 'fCanvasArea' so we can clearly see its bounds
  711. {
  712. const int x = fCanvasArea.getX();
  713. const int y = fCanvasArea.getY();
  714. const int w = fCanvasArea.getWidth();
  715. const int h = fCanvasArea.getHeight();
  716. glColor4f(0.0f, 1.0f, 0.0f, 0.9f);
  717. glBegin(GL_QUADS);
  718. glTexCoord2f(0.0f, 0.0f);
  719. glVertex2i(x, y);
  720. glTexCoord2f(1.0f, 0.0f);
  721. glVertex2i(x+w, y);
  722. glTexCoord2f(1.0f, 1.0f);
  723. glVertex2i(x+w, y+h);
  724. glTexCoord2f(0.0f, 1.0f);
  725. glVertex2i(x, y+h);
  726. glEnd();
  727. // reset color
  728. glColor4f(1.0f, 1.0f, 1.0f, 1.0f);
  729. }
  730. */
  731. calc_compcurves();
  732. //draw comp curves
  733. glEnable(GL_BLEND);
  734. glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
  735. glEnable(GL_LINE_SMOOTH);
  736. glHint(GL_LINE_SMOOTH_HINT, GL_NICEST);
  737. glLineWidth(2);
  738. int i,k;
  739. for (k = 0; k < MAX_COMP; ++k) {
  740. glColor4f((k==0)?1.f:0.235f, (k==1)?1.f:0.235f, (k==2)?1.f:0.235f, 1.0f);
  741. for (i = 2; i < COMPOINTS; ++i) {
  742. glBegin(GL_LINES);
  743. if (compy[k][i-1] < fCanvasArea.getY() + fCanvasArea.getHeight()
  744. && compy[k][i-1] > fCanvasArea.getY()
  745. && compy[k][i] < fCanvasArea.getY() + fCanvasArea.getHeight()
  746. && compy[k][i] > fCanvasArea.getY()) {
  747. glVertex2i(compx[k][i-1], compy[k][i-1]);
  748. glVertex2i(compx[k][i], compy[k][i]);
  749. }
  750. glEnd();
  751. }
  752. }
  753. // reset color
  754. glColor4f(1.0f, 1.0f, 1.0f, 1.0f);
  755. }
  756. // -----------------------------------------------------------------------
  757. UI* createUI()
  758. {
  759. return new ZaMultiCompX2UI();
  760. }
  761. // -----------------------------------------------------------------------
  762. END_NAMESPACE_DISTRHO