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.

1912 lines
69KB

  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. # Carla plugin/slot skin code
  4. # Copyright (C) 2013-2014 Filipe Coelho <falktx@falktx.com>
  5. #
  6. # This program is free software; you can redistribute it and/or
  7. # modify it under the terms of the GNU General Public License as
  8. # published by the Free Software Foundation; either version 2 of
  9. # the License, or any later version.
  10. #
  11. # This program is distributed in the hope that it will be useful,
  12. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. # GNU General Public License for more details.
  15. #
  16. # For a full copy of the GNU General Public License see the doc/GPL.txt file.
  17. # ------------------------------------------------------------------------------------------------------------
  18. # Imports (Config)
  19. from carla_config import *
  20. # ------------------------------------------------------------------------------------------------------------
  21. # Imports (Global)
  22. if config_UseQt5:
  23. from PyQt5.QtCore import Qt, QRectF
  24. from PyQt5.QtGui import QFont, QFontDatabase, QPen, QPixmap
  25. from PyQt5.QtWidgets import QFrame, QPushButton
  26. else:
  27. from PyQt4.QtCore import Qt, QRectF
  28. from PyQt4.QtGui import QFont, QFontDatabase, QFrame, QPen, QPixmap, QPushButton
  29. # ------------------------------------------------------------------------------------------------------------
  30. # Imports (Custom)
  31. import ui_carla_plugin_default
  32. import ui_carla_plugin_basic_fx
  33. import ui_carla_plugin_calf
  34. import ui_carla_plugin_sf2
  35. import ui_carla_plugin_zynfx
  36. from carla_widgets import *
  37. from digitalpeakmeter import DigitalPeakMeter
  38. from pixmapdial import PixmapDial
  39. # ------------------------------------------------------------------------------------------------------------
  40. # Try to "shortify" a parameter name
  41. def getParameterShortName(paramName):
  42. paramName = paramName.split("/",1)[0].split(" (",1)[0].split(" [",1)[0].strip()
  43. paramLow = paramName.lower()
  44. # Cut useless prefix
  45. if paramLow.startswith("compressor "):
  46. paramName = paramName.replace("ompressor ", ".", 1)
  47. paramLow = paramName.lower()
  48. elif paramLow.startswith("room "):
  49. paramName = paramName.split(" ",1)[1]
  50. paramLow = paramName.lower()
  51. # Cut useless suffix
  52. if paramLow.endswith(" level"):
  53. paramName = paramName.rsplit(" ",1)[0]
  54. paramLow = paramName.lower()
  55. elif paramLow.endswith(" time"):
  56. paramName = paramName.rsplit(" ",1)[0]
  57. paramLow = paramName.lower()
  58. # Cut generic names
  59. if "attack" in paramLow:
  60. paramName = paramName.replace("ttack", "tk")
  61. elif "bandwidth" in paramLow:
  62. paramName = paramName.replace("andwidth", "w")
  63. elif "damping" in paramLow:
  64. paramName = paramName.replace("amping", "amp")
  65. elif "distortion" in paramLow:
  66. paramName = paramName.replace("istortion", "ist")
  67. elif "feedback" in paramLow:
  68. paramName = paramName.replace("eedback", "b")
  69. elif "frequency" in paramLow:
  70. paramName = paramName.replace("requency", "req")
  71. elif "input" in paramLow:
  72. paramName = paramName.replace("nput", "n")
  73. elif "makeup" in paramLow:
  74. paramName = paramName.replace("akeup", "kUp" if "Make" in paramName else "kup")
  75. elif "output" in paramLow:
  76. paramName = paramName.replace("utput", "ut")
  77. elif "random" in paramLow:
  78. paramName = paramName.replace("andom", "nd")
  79. elif "threshold" in paramLow:
  80. paramName = paramName.replace("hreshold", "hres")
  81. # remove space if 1st last word is lowercase and the 2nd first is uppercase, or if 2nd is number
  82. if " " in paramName:
  83. name1, name2 = paramName.split(" ", 1)
  84. if (name1[-1].islower() and name2[0].isupper()) or name2.isdigit():
  85. paramName = paramName.replace(" ", "", 1)
  86. # cut stuff if too big
  87. if len(paramName) > 7:
  88. paramName = paramName.replace("a","").replace("e","").replace("i","").replace("o","").replace("u","")
  89. if len(paramName) > 7:
  90. paramName = paramName[:7]
  91. return paramName.strip()
  92. # ------------------------------------------------------------------------------------------------------------
  93. # Abstract plugin slot
  94. class AbstractPluginSlot(QFrame, PluginEditParentMeta):
  95. #class AbstractPluginSlot(QFrame, PluginEditParentMeta, metaclass=PyQtMetaClass):
  96. def __init__(self, parent, host, pluginId):
  97. QFrame.__init__(self, parent)
  98. self.host = host
  99. if False:
  100. # kdevelop likes this :)
  101. host = CarlaHostMeta()
  102. self.host = host
  103. # -------------------------------------------------------------
  104. # Get plugin info
  105. self.fPluginId = pluginId
  106. self.fPluginInfo = host.get_plugin_info(self.fPluginId)
  107. #if not gCarla.isLocal:
  108. #self.fPluginInfo['hints'] &= ~PLUGIN_HAS_CUSTOM_UI
  109. # -------------------------------------------------------------
  110. # Internal stuff
  111. self.fIsActive = bool(host.get_internal_parameter_value(self.fPluginId, PARAMETER_ACTIVE) >= 0.5)
  112. self.fIsCollapsed = False
  113. self.fIsSelected = False
  114. self.fLastGreenLedState = False
  115. self.fLastBlueLedState = False
  116. self.fParameterIconTimer = ICON_STATE_NULL
  117. self.fParameterList = [] # index, widget
  118. audioCountInfo = host.get_audio_port_count_info(self.fPluginId)
  119. self.fPeaksInputCount = int(audioCountInfo['ins'])
  120. self.fPeaksOutputCount = int(audioCountInfo['outs'])
  121. if self.fPeaksInputCount > 2:
  122. self.fPeaksInputCount = 2
  123. if self.fPeaksOutputCount > 2:
  124. self.fPeaksOutputCount = 2
  125. # used during testing
  126. self.fIdleTimerId = 0
  127. # -------------------------------------------------------------
  128. # Set-up GUI
  129. self.fEditDialog = PluginEdit(self, host, self.fPluginId)
  130. # -------------------------------------------------------------
  131. # Set-up common widgets (as none)
  132. self.b_enable = None
  133. self.b_gui = None
  134. self.b_edit = None
  135. self.b_remove = None
  136. self.cb_presets = None
  137. self.label_name = None
  138. self.label_type = None
  139. self.led_control = None
  140. self.led_midi = None
  141. self.led_audio_in = None
  142. self.led_audio_out = None
  143. self.line = None
  144. self.peak_in = None
  145. self.peak_out = None
  146. # -------------------------------------------------------------
  147. # Set-up connections
  148. host.PluginRenamedCallback.connect(self.slot_handlePluginRenamedCallback)
  149. host.PluginUnavailableCallback.connect(self.slot_handlePluginUnavailableCallback)
  150. host.ParameterValueChangedCallback.connect(self.slot_handleParameterValueChangedCallback)
  151. host.ParameterDefaultChangedCallback.connect(self.slot_handleParameterDefaultChangedCallback)
  152. host.ParameterMidiChannelChangedCallback.connect(self.slot_handleParameterMidiChannelChangedCallback)
  153. host.ParameterMidiCcChangedCallback.connect(self.slot_handleParameterMidiCcChangedCallback)
  154. host.ProgramChangedCallback.connect(self.slot_handleProgramChangedCallback)
  155. host.MidiProgramChangedCallback.connect(self.slot_handleMidiProgramChangedCallback)
  156. host.OptionChangedCallback.connect(self.slot_handleOptionChangedCallback)
  157. host.UiStateChangedCallback.connect(self.slot_handleUiStateChangedCallback)
  158. # -----------------------------------------------------------------
  159. @pyqtSlot(int, str)
  160. def slot_handlePluginRenamedCallback(self, pluginId, newName):
  161. if self.fPluginId == pluginId:
  162. self.setName(newName)
  163. @pyqtSlot(int, str)
  164. def slot_handlePluginUnavailableCallback(self, pluginId, errorMsg):
  165. if self.fPluginId == pluginId:
  166. pass
  167. @pyqtSlot(int, int, float)
  168. def slot_handleParameterValueChangedCallback(self, pluginId, index, value):
  169. if self.fPluginId == pluginId:
  170. self.setParameterValue(index, value, True)
  171. @pyqtSlot(int, int, float)
  172. def slot_handleParameterDefaultChangedCallback(self, pluginId, index, value):
  173. if self.fPluginId == pluginId:
  174. self.setParameterDefault(index, value)
  175. @pyqtSlot(int, int, int)
  176. def slot_handleParameterMidiCcChangedCallback(self, pluginId, index, cc):
  177. if self.fPluginId == pluginId:
  178. self.setParameterMidiControl(index, cc)
  179. @pyqtSlot(int, int, int)
  180. def slot_handleParameterMidiChannelChangedCallback(self, pluginId, index, channel):
  181. if self.fPluginId == pluginId:
  182. self.setParameterMidiChannel(index, channel)
  183. @pyqtSlot(int, int)
  184. def slot_handleProgramChangedCallback(self, pluginId, index):
  185. if self.fPluginId == pluginId:
  186. self.setProgram(index, True)
  187. @pyqtSlot(int, int)
  188. def slot_handleMidiProgramChangedCallback(self, pluginId, index):
  189. if self.fPluginId == pluginId:
  190. self.setMidiProgram(index, True)
  191. @pyqtSlot(int, int, bool)
  192. def slot_handleOptionChangedCallback(self, pluginId, option, yesNo):
  193. if self.fPluginId == pluginId:
  194. self.setOption(option, yesNo)
  195. @pyqtSlot(int, int)
  196. def slot_handleUiStateChangedCallback(self, pluginId, state):
  197. if self.fPluginId == pluginId:
  198. self.customUiStateChanged(state)
  199. #------------------------------------------------------------------
  200. def ready(self):
  201. if self.b_enable is not None:
  202. self.b_enable.setChecked(self.fIsActive)
  203. self.b_enable.clicked.connect(self.slot_enableClicked)
  204. if self.b_gui is not None:
  205. self.b_gui.clicked.connect(self.slot_showCustomUi)
  206. self.b_gui.setEnabled(bool(self.fPluginInfo['hints'] & PLUGIN_HAS_CUSTOM_UI))
  207. if self.b_edit is None:
  208. # Edit dialog *must* be available
  209. self.b_edit = QPushButton(self)
  210. self.b_edit.setCheckable(True)
  211. self.b_edit.hide()
  212. self.b_edit.clicked.connect(self.slot_showEditDialog)
  213. if self.b_remove is not None:
  214. self.b_remove.clicked.connect(self.slot_removePlugin)
  215. if self.label_name is not None:
  216. self.label_name.setText(self.fPluginInfo['name'])
  217. if self.label_type is not None:
  218. self.label_type.setText(getPluginTypeAsString(self.fPluginInfo['type']))
  219. if self.led_control is not None:
  220. self.led_control.setColor(self.led_control.YELLOW)
  221. self.led_control.setEnabled(False)
  222. if self.led_midi is not None:
  223. self.led_midi.setColor(self.led_midi.RED)
  224. self.led_midi.setEnabled(False)
  225. if self.led_audio_in is not None:
  226. self.led_audio_in.setColor(self.led_audio_in.GREEN)
  227. self.led_audio_in.setEnabled(False)
  228. if self.led_audio_out is not None:
  229. self.led_audio_out.setColor(self.led_audio_out.BLUE)
  230. self.led_audio_out.setEnabled(False)
  231. if self.peak_in is not None:
  232. self.peak_in.setChannelCount(self.fPeaksInputCount)
  233. self.peak_in.setMeterColor(DigitalPeakMeter.COLOR_GREEN)
  234. self.peak_in.setMeterOrientation(DigitalPeakMeter.HORIZONTAL)
  235. if (self.fPeaksInputCount == 0 and not isinstance(self, PluginSlot_Default)) or self.fIsCollapsed:
  236. self.peak_in.hide()
  237. if self.peak_out is not None:
  238. self.peak_out.setChannelCount(self.fPeaksOutputCount)
  239. self.peak_out.setMeterColor(DigitalPeakMeter.COLOR_BLUE)
  240. self.peak_out.setMeterOrientation(DigitalPeakMeter.HORIZONTAL)
  241. if (self.fPeaksOutputCount == 0 and not isinstance(self, PluginSlot_Default)) or self.fIsCollapsed:
  242. self.peak_out.hide()
  243. if self.line is not None:
  244. if self.fIsCollapsed:
  245. self.line.hide()
  246. for paramIndex, paramWidget in self.fParameterList:
  247. paramWidget.setContextMenuPolicy(Qt.CustomContextMenu)
  248. paramWidget.customContextMenuRequested.connect(self.slot_knobCustomMenu)
  249. paramWidget.realValueChanged.connect(self.slot_parameterValueChanged)
  250. paramWidget.setValue(self.host.get_internal_parameter_value(self.fPluginId, paramIndex))
  251. if self.fIsCollapsed:
  252. paramWidget.hide()
  253. self.setWindowTitle(self.fPluginInfo['name'])
  254. #------------------------------------------------------------------
  255. def getFixedHeight(self):
  256. return 32
  257. def getHints(self):
  258. return self.fPluginInfo['hints']
  259. def getPluginId(self):
  260. return self.fPluginId
  261. #------------------------------------------------------------------
  262. def setPluginId(self, idx):
  263. self.fPluginId = idx
  264. self.fEditDialog.setPluginId(idx)
  265. def setName(self, name):
  266. self.fEditDialog.setName(name)
  267. if self.label_name is not None:
  268. self.label_name.setText(name)
  269. def setSelected(self, yesNo):
  270. if self.fIsSelected == yesNo:
  271. return
  272. self.fIsSelected = yesNo
  273. self.update()
  274. #------------------------------------------------------------------
  275. def setActive(self, active, sendCallback=False, sendHost=True):
  276. self.fIsActive = active
  277. if sendCallback:
  278. self.fParameterIconTimer = ICON_STATE_ON
  279. self.activeChanged(active)
  280. if sendHost:
  281. self.host.set_active(self.fPluginId, active)
  282. if active:
  283. self.fEditDialog.clearNotes()
  284. self.midiActivityChanged(False)
  285. # called from rack, checks if param is possible first
  286. def setInternalParameter(self, parameterId, value):
  287. if parameterId <= PARAMETER_MAX or parameterId >= PARAMETER_NULL:
  288. return
  289. elif parameterId == PARAMETER_ACTIVE:
  290. return self.setActive(bool(value), True, True)
  291. elif parameterId == PARAMETER_DRYWET:
  292. if (self.fPluginInfo['hints'] & PLUGIN_CAN_DRYWET) == 0: return
  293. self.host.set_drywet(self.fPluginId, value)
  294. elif parameterId == PARAMETER_VOLUME:
  295. if (self.fPluginInfo['hints'] & PLUGIN_CAN_VOLUME) == 0: return
  296. self.host.set_volume(self.fPluginId, value)
  297. elif parameterId == PARAMETER_BALANCE_LEFT:
  298. if (self.fPluginInfo['hints'] & PLUGIN_CAN_BALANCE) == 0: return
  299. self.host.set_balance_left(self.fPluginId, value)
  300. elif parameterId == PARAMETER_BALANCE_RIGHT:
  301. if (self.fPluginInfo['hints'] & PLUGIN_CAN_BALANCE) == 0: return
  302. self.host.set_balance_right(self.fPluginId, value)
  303. elif parameterId == PARAMETER_PANNING:
  304. if (self.fPluginInfo['hints'] & PLUGIN_CAN_PANNING) == 0: return
  305. self.host.set_panning(self.fPluginId, value)
  306. elif parameterId == PARAMETER_CTRL_CHANNEL:
  307. self.host.set_ctrl_channel(self.fPluginId, value)
  308. self.fEditDialog.setParameterValue(parameterId, value)
  309. #------------------------------------------------------------------
  310. def setParameterValue(self, parameterId, value, sendCallback):
  311. if parameterId == PARAMETER_ACTIVE:
  312. return self.setActive(bool(value), True, False)
  313. self.fEditDialog.setParameterValue(parameterId, value)
  314. if sendCallback:
  315. self.fParameterIconTimer = ICON_STATE_ON
  316. self.editDialogParameterValueChanged(self.fPluginId, parameterId, value)
  317. def setParameterDefault(self, parameterId, value):
  318. self.fEditDialog.setParameterDefault(parameterId, value)
  319. def setParameterMidiControl(self, parameterId, control):
  320. self.fEditDialog.setParameterMidiControl(parameterId, control)
  321. def setParameterMidiChannel(self, parameterId, channel):
  322. self.fEditDialog.setParameterMidiChannel(parameterId, channel)
  323. #------------------------------------------------------------------
  324. def setProgram(self, index, sendCallback):
  325. self.fEditDialog.setProgram(index)
  326. if sendCallback:
  327. self.fParameterIconTimer = ICON_STATE_ON
  328. self.editDialogProgramChanged(self.fPluginId, index)
  329. self.updateParameterValues()
  330. def setMidiProgram(self, index, sendCallback):
  331. self.fEditDialog.setMidiProgram(index)
  332. if sendCallback:
  333. self.fParameterIconTimer = ICON_STATE_ON
  334. self.editDialogMidiProgramChanged(self.fPluginId, index)
  335. self.updateParameterValues()
  336. #------------------------------------------------------------------
  337. def setOption(self, option, yesNo):
  338. self.fEditDialog.setOption(option, yesNo)
  339. #------------------------------------------------------------------
  340. def activeChanged(self, onOff):
  341. self.fIsActive = onOff
  342. if self.b_enable is None:
  343. return
  344. self.b_enable.blockSignals(True)
  345. self.b_enable.setChecked(onOff)
  346. self.b_enable.blockSignals(False)
  347. def customUiStateChanged(self, state):
  348. if self.b_gui is None:
  349. return
  350. self.b_gui.blockSignals(True)
  351. if state == 0:
  352. self.b_gui.setChecked(False)
  353. self.b_gui.setEnabled(True)
  354. elif state == 1:
  355. self.b_gui.setChecked(True)
  356. self.b_gui.setEnabled(True)
  357. elif state == -1:
  358. self.b_gui.setChecked(False)
  359. self.b_gui.setEnabled(False)
  360. self.b_gui.blockSignals(False)
  361. def parameterActivityChanged(self, onOff):
  362. if self.led_control is None:
  363. return
  364. self.led_control.setChecked(onOff)
  365. def midiActivityChanged(self, onOff):
  366. if self.led_midi is None:
  367. return
  368. self.led_midi.setChecked(onOff)
  369. def optionChanged(self, option, yesNo):
  370. pass
  371. # -----------------------------------------------------------------
  372. # PluginEdit callbacks
  373. def editDialogVisibilityChanged(self, pluginId, visible):
  374. if self.b_edit is None:
  375. return
  376. self.b_edit.blockSignals(True)
  377. self.b_edit.setChecked(visible)
  378. self.b_edit.blockSignals(False)
  379. def editDialogPluginHintsChanged(self, pluginId, hints):
  380. self.fPluginInfo['hints'] = hints
  381. for paramIndex, paramWidget in self.fParameterList:
  382. if paramIndex == PARAMETER_DRYWET:
  383. paramWidget.setVisible(hints & PLUGIN_CAN_DRYWET)
  384. elif paramIndex == PARAMETER_VOLUME:
  385. paramWidget.setVisible(hints & PLUGIN_CAN_VOLUME)
  386. if self.b_gui is not None:
  387. self.b_gui.setEnabled(bool(hints & PLUGIN_HAS_CUSTOM_UI))
  388. def editDialogParameterValueChanged(self, pluginId, parameterId, value):
  389. for paramIndex, paramWidget in self.fParameterList:
  390. if paramIndex != parameterId:
  391. continue
  392. paramWidget.blockSignals(True)
  393. paramWidget.setValue(value)
  394. paramWidget.blockSignals(False)
  395. break
  396. def editDialogProgramChanged(self, pluginId, index):
  397. if self.cb_presets is None:
  398. return
  399. self.cb_presets.blockSignals(True)
  400. self.cb_presets.setCurrentIndex(index)
  401. self.cb_presets.blockSignals(False)
  402. # FIXME
  403. self.updateParameterValues()
  404. def editDialogMidiProgramChanged(self, pluginId, index):
  405. if self.cb_presets is None:
  406. return
  407. self.cb_presets.blockSignals(True)
  408. self.cb_presets.setCurrentIndex(index)
  409. self.cb_presets.blockSignals(False)
  410. # FIXME
  411. self.updateParameterValues()
  412. def editDialogNotePressed(self, pluginId, note):
  413. pass
  414. def editDialogNoteReleased(self, pluginId, note):
  415. pass
  416. def editDialogMidiActivityChanged(self, pluginId, onOff):
  417. self.midiActivityChanged(onOff)
  418. #------------------------------------------------------------------
  419. def idleFast(self):
  420. # Input peaks
  421. if self.fPeaksInputCount > 0:
  422. if self.fPeaksInputCount > 1:
  423. peak1 = self.host.get_input_peak_value(self.fPluginId, True)
  424. peak2 = self.host.get_input_peak_value(self.fPluginId, False)
  425. ledState = bool(peak1 != 0.0 or peak2 != 0.0)
  426. if self.peak_in is not None:
  427. self.peak_in.displayMeter(1, peak1)
  428. self.peak_in.displayMeter(2, peak2)
  429. else:
  430. peak = self.host.get_input_peak_value(self.fPluginId, True)
  431. ledState = bool(peak != 0.0)
  432. if self.peak_in is not None:
  433. self.peak_in.displayMeter(1, peak)
  434. if self.fLastGreenLedState != ledState and self.led_audio_in is not None:
  435. self.fLastGreenLedState = ledState
  436. self.led_audio_in.setChecked(ledState)
  437. # Output peaks
  438. if self.fPeaksOutputCount > 0:
  439. if self.fPeaksOutputCount > 1:
  440. peak1 = self.host.get_output_peak_value(self.fPluginId, True)
  441. peak2 = self.host.get_output_peak_value(self.fPluginId, False)
  442. ledState = bool(peak1 != 0.0 or peak2 != 0.0)
  443. if self.peak_out is not None:
  444. self.peak_out.displayMeter(1, peak1)
  445. self.peak_out.displayMeter(2, peak2)
  446. else:
  447. peak = self.host.get_output_peak_value(self.fPluginId, True)
  448. ledState = bool(peak != 0.0)
  449. if self.peak_out is not None:
  450. self.peak_out.displayMeter(1, peak)
  451. if self.fLastBlueLedState != ledState and self.led_audio_out is not None:
  452. self.fLastBlueLedState = ledState
  453. self.led_audio_out.setChecked(ledState)
  454. def idleSlow(self):
  455. if self.fParameterIconTimer == ICON_STATE_ON:
  456. self.parameterActivityChanged(True)
  457. self.fParameterIconTimer = ICON_STATE_WAIT
  458. elif self.fParameterIconTimer == ICON_STATE_WAIT:
  459. self.fParameterIconTimer = ICON_STATE_OFF
  460. elif self.fParameterIconTimer == ICON_STATE_OFF:
  461. self.parameterActivityChanged(False)
  462. self.fParameterIconTimer = ICON_STATE_NULL
  463. self.fEditDialog.idleSlow()
  464. #------------------------------------------------------------------
  465. def drawOutline(self):
  466. painter = QPainter(self)
  467. if self.fIsSelected:
  468. painter.setPen(QPen(Qt.cyan, 4))
  469. painter.setBrush(Qt.transparent)
  470. painter.drawRect(0, 0, self.width(), self.height())
  471. else:
  472. painter.setPen(QPen(Qt.black, 1))
  473. painter.setBrush(Qt.black)
  474. painter.drawLine(0, self.height()-1, self.width(), self.height()-1)
  475. def showDefaultCustomMenu(self, isEnabled, bEdit = None, bGui = None):
  476. menu = QMenu(self)
  477. actActive = menu.addAction(self.tr("Disable") if isEnabled else self.tr("Enable"))
  478. menu.addSeparator()
  479. actReset = menu.addAction(self.tr("Reset parameters"))
  480. actRandom = menu.addAction(self.tr("Randomize parameters"))
  481. menu.addSeparator()
  482. if bEdit is not None:
  483. actEdit = menu.addAction(self.tr("Edit"))
  484. actEdit.setCheckable(True)
  485. actEdit.setChecked(bEdit.isChecked())
  486. else:
  487. actEdit = None
  488. if bGui is not None:
  489. actGui = menu.addAction(self.tr("Show Custom UI"))
  490. actGui.setCheckable(True)
  491. actGui.setChecked(bGui.isChecked())
  492. actGui.setEnabled(bGui.isEnabled())
  493. else:
  494. actGui = None
  495. menu.addSeparator()
  496. actClone = menu.addAction(self.tr("Clone"))
  497. actReplace = menu.addAction(self.tr("Replace..."))
  498. actRename = menu.addAction(self.tr("Rename..."))
  499. actRemove = menu.addAction(self.tr("Remove"))
  500. if self.fIdleTimerId != 0:
  501. actRemove.setVisible(False)
  502. actSel = menu.exec_(QCursor.pos())
  503. if not actSel:
  504. return
  505. if actSel == actActive:
  506. self.setActive(not isEnabled, True, True)
  507. elif actSel == actReset:
  508. self.host.reset_parameters(self.fPluginId)
  509. elif actSel == actRandom:
  510. self.host.randomize_parameters(self.fPluginId)
  511. elif actSel == actGui:
  512. bGui.click()
  513. elif actSel == actEdit:
  514. bEdit.click()
  515. elif actSel == actClone:
  516. if not self.host.clone_plugin(self.fPluginId):
  517. CustomMessageBox(self, QMessageBox.Warning, self.tr("Error"), self.tr("Operation failed"),
  518. self.host.get_last_error(), QMessageBox.Ok, QMessageBox.Ok)
  519. elif actSel == actRename:
  520. oldName = self.fPluginInfo['name']
  521. newNameTry = QInputDialog.getText(self, self.tr("Rename Plugin"), self.tr("New plugin name:"), QLineEdit.Normal, oldName)
  522. if not (newNameTry[1] and newNameTry[0] and oldName != newNameTry[0]):
  523. return
  524. newName = newNameTry[0]
  525. if self.host.rename_plugin(self.fPluginId, newName):
  526. self.setName(newName)
  527. else:
  528. CustomMessageBox(self, QMessageBox.Warning, self.tr("Error"), self.tr("Operation failed"),
  529. self.host.get_last_error(), QMessageBox.Ok, QMessageBox.Ok)
  530. elif actSel == actReplace:
  531. gCarla.gui.slot_pluginAdd(self.fPluginId)
  532. elif actSel == actRemove:
  533. if not self.host.remove_plugin(self.fPluginId):
  534. CustomMessageBox(self, QMessageBox.Warning, self.tr("Error"), self.tr("Operation failed"),
  535. self.host.get_last_error(), QMessageBox.Ok, QMessageBox.Ok)
  536. def updateParameterValues(self):
  537. for paramIndex, paramWidget in self.fParameterList:
  538. if paramIndex < 0:
  539. continue
  540. paramWidget.blockSignals(True)
  541. paramWidget.setValue(self.host.get_current_parameter_value(self.fPluginId, paramIndex))
  542. paramWidget.blockSignals(False)
  543. #------------------------------------------------------------------
  544. @pyqtSlot(bool)
  545. def slot_enableClicked(self, yesNo):
  546. self.setActive(yesNo, False, True)
  547. @pyqtSlot()
  548. def slot_showDefaultCustomMenu(self):
  549. self.showDefaultCustomMenu(self.fIsActive, self.b_edit, self.b_gui)
  550. @pyqtSlot()
  551. def slot_knobCustomMenu(self):
  552. sender = self.sender()
  553. index = sender.fIndex
  554. minimum = sender.fMinimum
  555. maximum = sender.fMaximum
  556. current = sender.fRealValue
  557. label = sender.fLabel
  558. if index in (PARAMETER_DRYWET, PARAMETER_VOLUME):
  559. default = 1.0
  560. resetText = self.tr("Reset (%i%%)" % int(default*100.0))
  561. minimText = self.tr("Set to Minimum (%i%%)" % int(minimum*100.0))
  562. maximText = self.tr("Set to Maximum (%i%%)" % int(maximum*100.0))
  563. else:
  564. default = self.host.get_default_parameter_value(self.fPluginId, index)
  565. resetText = self.tr("Reset (%f)" % default)
  566. minimText = self.tr("Set to Minimum (%f)" % minimum)
  567. maximText = self.tr("Set to Maximum (%f)" % maximum)
  568. menu = QMenu(self)
  569. actReset = menu.addAction(resetText)
  570. menu.addSeparator()
  571. actMinimum = menu.addAction(minimText)
  572. actMaximum = menu.addAction(maximText)
  573. menu.addSeparator()
  574. actSet = menu.addAction(self.tr("Set value..."))
  575. actSelected = menu.exec_(QCursor.pos())
  576. if actSelected == actSet:
  577. valueTry = QInputDialog.getDouble(self, self.tr("Set value"), label, current, minimum, maximum, 3) # FIXME - 3 decimals
  578. if valueTry[1]:
  579. value = valueTry[0] * 10
  580. else:
  581. return
  582. elif actSelected == actMinimum:
  583. value = minimum
  584. elif actSelected == actMaximum:
  585. value = maximum
  586. elif actSelected == actReset:
  587. value = default
  588. else:
  589. return
  590. self.sender().setValue(value)
  591. #------------------------------------------------------------------
  592. @pyqtSlot(bool)
  593. def slot_showCustomUi(self, show):
  594. self.host.show_custom_ui(self.fPluginId, show)
  595. @pyqtSlot(bool)
  596. def slot_showEditDialog(self, show):
  597. self.fEditDialog.setVisible(show)
  598. @pyqtSlot()
  599. def slot_removePlugin(self):
  600. if not self.host.remove_plugin(self.fPluginId):
  601. CustomMessageBox(self, QMessageBox.Warning, self.tr("Error"), self.tr("Operation failed"),
  602. self.host.get_last_error(), QMessageBox.Ok, QMessageBox.Ok)
  603. #------------------------------------------------------------------
  604. @pyqtSlot(int)
  605. def slot_parameterValueChanged(self, value):
  606. index = self.sender().getIndex()
  607. if index < 0:
  608. self.setInternalParameter(index, value)
  609. else:
  610. self.host.set_parameter_value(self.fPluginId, index, value)
  611. self.setParameterValue(index, value, False)
  612. @pyqtSlot(int)
  613. def slot_programChanged(self, index):
  614. self.host.set_program(self.fPluginId, index)
  615. self.setProgram(index, False)
  616. @pyqtSlot(int)
  617. def slot_midiProgramChanged(self, index):
  618. self.host.set_midi_program(self.fPluginId, index)
  619. self.setMidiProgram(index, False)
  620. #------------------------------------------------------------------
  621. def testTimer(self):
  622. self.fIdleTimerId = self.startTimer(25)
  623. #------------------------------------------------------------------
  624. def closeEvent(self, event):
  625. if self.fIdleTimerId != 0:
  626. self.killTimer(self.fIdleTimerId)
  627. self.fIdleTimerId = 0
  628. self.host.engine_close()
  629. QFrame.closeEvent(self, event)
  630. def timerEvent(self, event):
  631. if event.timerId() == self.fIdleTimerId:
  632. self.host.engine_idle()
  633. self.idleFast()
  634. self.idleSlow()
  635. QFrame.timerEvent(self, event)
  636. def paintEvent(self, event):
  637. self.drawOutline()
  638. QFrame.paintEvent(self, event)
  639. # ------------------------------------------------------------------------------------------------------------
  640. class PluginSlot_Default(AbstractPluginSlot):
  641. def __init__(self, parent, host, pluginId):
  642. AbstractPluginSlot.__init__(self, parent, host, pluginId)
  643. self.ui = ui_carla_plugin_default.Ui_PluginWidget()
  644. self.ui.setupUi(self)
  645. # -------------------------------------------------------------
  646. # Internal stuff
  647. self.fColorTop = QColor(60, 60, 60)
  648. self.fColorBottom = QColor(47, 47, 47)
  649. self.fColorSeprtr = QColor(70, 70, 70)
  650. # -------------------------------------------------------------
  651. # Set-up GUI
  652. self.setStyleSheet("""
  653. QLabel#label_name {
  654. color: #BBB;
  655. }
  656. """)
  657. self.ui.b_enable.setPixmaps(":/bitmaps/button_off.png", ":/bitmaps/button_on.png", ":/bitmaps/button_off.png")
  658. self.ui.b_edit.setPixmaps(":/bitmaps/button_edit.png", ":/bitmaps/button_edit_down.png", ":/bitmaps/button_edit_hover.png")
  659. if self.fPluginInfo['iconName'] == "distrho":
  660. self.ui.b_gui.setPixmaps(":/bitmaps/button_distrho.png", ":/bitmaps/button_distrho_down.png", ":/bitmaps/button_distrho_hover.png")
  661. elif self.fPluginInfo['iconName'] == "file":
  662. self.ui.b_gui.setPixmaps(":/bitmaps/button_file.png", ":/bitmaps/button_file_down.png", ":/bitmaps/button_file_hover.png")
  663. else:
  664. self.ui.b_gui.setPixmaps(":/bitmaps/button_gui.png", ":/bitmaps/button_gui_down.png", ":/bitmaps/button_gui_hover.png")
  665. # -------------------------------------------------------------
  666. self.b_enable = self.ui.b_enable
  667. self.b_gui = self.ui.b_gui
  668. self.b_edit = self.ui.b_edit
  669. self.label_name = self.ui.label_name
  670. self.led_control = self.ui.led_control
  671. self.led_midi = self.ui.led_midi
  672. self.led_audio_in = self.ui.led_audio_in
  673. self.led_audio_out = self.ui.led_audio_out
  674. self.peak_in = self.ui.peak_in
  675. self.peak_out = self.ui.peak_out
  676. self.ready()
  677. self.customContextMenuRequested.connect(self.slot_showDefaultCustomMenu)
  678. #------------------------------------------------------------------
  679. def getFixedHeight(self):
  680. return 36
  681. #------------------------------------------------------------------
  682. def paintEvent(self, event):
  683. painter = QPainter(self)
  684. painter.save()
  685. areaX = self.ui.area_right.x()+7
  686. width = self.width()
  687. height = self.height()
  688. painter.setPen(QPen(QColor(17, 17, 17), 1))
  689. painter.setBrush(QColor(17, 17, 17))
  690. painter.drawRect(0, 0, width, height)
  691. painter.setPen(self.fColorSeprtr.lighter(110))
  692. painter.setBrush(self.fColorBottom)
  693. painter.setRenderHint(QPainter.Antialiasing, True)
  694. # name -> leds arc
  695. path = QPainterPath()
  696. path.moveTo(areaX-20, height-4)
  697. path.cubicTo(areaX, height-5, areaX-20, 4.75, areaX, 4.75)
  698. path.lineTo(areaX, height-5)
  699. painter.drawPath(path)
  700. painter.setPen(self.fColorSeprtr)
  701. painter.setRenderHint(QPainter.Antialiasing, False)
  702. # separator lines
  703. painter.drawLine(0, height-5, areaX-20, height-5)
  704. painter.drawLine(areaX, 4, width, 4)
  705. painter.setPen(self.fColorBottom)
  706. painter.setBrush(self.fColorBottom)
  707. # top, bottom and left lines
  708. painter.drawLine(0, 0, width, 0)
  709. painter.drawRect(0, height-4, areaX, 4)
  710. painter.drawRoundedRect(areaX-20, height-5, areaX, 5, 22, 22)
  711. painter.drawLine(0, 0, 0, height)
  712. # fill the rest
  713. painter.drawRect(areaX-1, 5, width, height)
  714. # bottom 1px line
  715. painter.setPen(self.fColorSeprtr)
  716. painter.drawLine(0, height-1, width, height-1)
  717. painter.restore()
  718. AbstractPluginSlot.paintEvent(self, event)
  719. # ------------------------------------------------------------------------------------------------------------
  720. class PluginSlot_BasicFX(AbstractPluginSlot):
  721. def __init__(self, parent, host, pluginId):
  722. AbstractPluginSlot.__init__(self, parent, host, pluginId)
  723. self.ui = ui_carla_plugin_basic_fx.Ui_PluginWidget()
  724. self.ui.setupUi(self)
  725. # -------------------------------------------------------------
  726. # Set-up GUI
  727. labelFont = self.ui.label_name.font()
  728. labelFont.setBold(True)
  729. labelFont.setPointSize(9)
  730. self.ui.label_name.setFont(labelFont)
  731. r = 40
  732. g = 40
  733. b = 40
  734. if self.fPluginInfo['category'] == PLUGIN_CATEGORY_MODULATOR:
  735. r += 10
  736. elif self.fPluginInfo['category'] == PLUGIN_CATEGORY_EQ:
  737. g += 10
  738. elif self.fPluginInfo['category'] == PLUGIN_CATEGORY_FILTER:
  739. b += 10
  740. elif self.fPluginInfo['category'] == PLUGIN_CATEGORY_DELAY:
  741. r += 15
  742. b -= 15
  743. elif self.fPluginInfo['category'] == PLUGIN_CATEGORY_DISTORTION:
  744. g += 10
  745. b += 10
  746. elif self.fPluginInfo['category'] == PLUGIN_CATEGORY_DYNAMICS:
  747. r += 10
  748. b += 10
  749. elif self.fPluginInfo['category'] == PLUGIN_CATEGORY_UTILITY:
  750. r += 10
  751. g += 10
  752. bg = "noise1"
  753. if self.fPluginInfo['maker'] in ("falkTX, Michael Gruhn", "DISTRHO") and "3bandeq" in self.fPluginInfo['label'].lower():
  754. bg = "3bandeq"
  755. self.setStyleSheet("""
  756. PluginSlot_BasicFX#PluginWidget {
  757. background-color: rgb(%i, %i, %i);
  758. background-image: url(:/bitmaps/background_%s.png);
  759. background-repeat: repeat-xy;
  760. }
  761. QLabel#label_name {
  762. color: #BBB;
  763. }
  764. """ % (r, g, b, bg))
  765. self.ui.b_enable.setPixmaps(":/bitmaps/button_off.png", ":/bitmaps/button_on.png", ":/bitmaps/button_off.png")
  766. self.ui.b_edit.setPixmaps(":/bitmaps/button_edit.png", ":/bitmaps/button_edit_down.png", ":/bitmaps/button_edit_hover.png")
  767. if self.fPluginInfo['iconName'] == "distrho":
  768. self.ui.b_gui.setPixmaps(":/bitmaps/button_distrho.png", ":/bitmaps/button_distrho_down.png", ":/bitmaps/button_distrho_hover.png")
  769. elif self.fPluginInfo['iconName'] == "file":
  770. self.ui.b_gui.setPixmaps(":/bitmaps/button_file.png", ":/bitmaps/button_file_down.png", ":/bitmaps/button_file_hover.png")
  771. else:
  772. self.ui.b_gui.setPixmaps(":/bitmaps/button_gui.png", ":/bitmaps/button_gui_down.png", ":/bitmaps/button_gui_hover.png")
  773. #if self.fIsCollapsed:
  774. #self.ui.w_knobs.hide()
  775. #self.ui.horizontalLayout_2.setContentsMargins(0,0,0,0)
  776. #self.ui.horizontalLayout_2.setSpacing(0)
  777. #self.ui.horizontalLayout_2.SetMaximumSize(0,0)
  778. # -------------------------------------------------------------
  779. # Set-up parameters
  780. parameterCount = self.host.get_parameter_count(self.fPluginId) if not self.fIsCollapsed else 0
  781. index = 0
  782. for i in range(parameterCount):
  783. if index >= 8:
  784. break
  785. paramInfo = self.host.get_parameter_info(self.fPluginId, i)
  786. paramData = self.host.get_parameter_data(self.fPluginId, i)
  787. paramRanges = self.host.get_parameter_ranges(self.fPluginId, i)
  788. if paramData['type'] != PARAMETER_INPUT:
  789. continue
  790. if paramData['hints'] & PARAMETER_IS_BOOLEAN:
  791. continue
  792. if paramData['hints'] & PARAMETER_IS_INTEGER:
  793. continue
  794. if (paramData['hints'] & PARAMETER_IS_ENABLED) == 0:
  795. continue
  796. paramName = getParameterShortName(paramInfo['name'])
  797. #if self.fPluginInfo['category'] == PLUGIN_CATEGORY_FILTER:
  798. #_r = 55 + float(i)/8*200
  799. #_g = 255 - float(i)/8*200
  800. #_b = 127 - r*2
  801. #elif self.fPluginInfo['category'] == PLUGIN_CATEGORY_DELAY:
  802. #_r = 127
  803. #_g = 55 + float(i)/8*200
  804. #_b = 255 - float(i)/8*200
  805. #elif r < b < g:
  806. #_r = 55 + float(i)/8*200
  807. #_g = 127
  808. #_b = 255 - float(i)/8*200
  809. #else:
  810. _r = 255 - float(index)/8*200
  811. _g = 55 + float(index)/8*200
  812. _b = (r-40)*4
  813. #if _r < 140: _r = 140
  814. #if _g < 140: _g = 140
  815. #if _b < 140: _b = 140
  816. widget = PixmapDial(self, i)
  817. widget.setPixmap(3)
  818. widget.setLabel(paramName)
  819. widget.setCustomPaintColor(QColor(_r, _g, _b))
  820. widget.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_COLOR)
  821. widget.forceWhiteLabelGradientText()
  822. widget.setMinimum(paramRanges['min'])
  823. widget.setMaximum(paramRanges['max'])
  824. if (paramData['hints'] & PARAMETER_IS_ENABLED) == 0:
  825. widget.setEnabled(False)
  826. self.ui.w_knobs.layout().insertWidget(index, widget)
  827. index += 1
  828. self.fParameterList.append([i, widget])
  829. self.ui.dial_drywet.setIndex(PARAMETER_DRYWET)
  830. self.ui.dial_drywet.setPixmap(3)
  831. self.ui.dial_drywet.setLabel("Dry/Wet")
  832. self.ui.dial_drywet.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_CARLA_WET)
  833. self.ui.dial_drywet.setMinimum(0.0)
  834. self.ui.dial_drywet.setMaximum(1.0)
  835. self.ui.dial_drywet.forceWhiteLabelGradientText()
  836. self.ui.dial_drywet.setVisible(self.fPluginInfo['hints'] & PLUGIN_CAN_DRYWET)
  837. self.ui.dial_vol.setIndex(PARAMETER_VOLUME)
  838. self.ui.dial_vol.setPixmap(3)
  839. self.ui.dial_vol.setLabel("Volume")
  840. self.ui.dial_vol.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_CARLA_VOL)
  841. self.ui.dial_vol.setMinimum(0.0)
  842. self.ui.dial_vol.setMaximum(1.27)
  843. self.ui.dial_vol.forceWhiteLabelGradientText()
  844. self.ui.dial_vol.setVisible(self.fPluginInfo['hints'] & PLUGIN_CAN_VOLUME)
  845. self.fParameterList.append([PARAMETER_DRYWET, self.ui.dial_drywet])
  846. self.fParameterList.append([PARAMETER_VOLUME, self.ui.dial_vol])
  847. # -------------------------------------------------------------
  848. self.b_enable = self.ui.b_enable
  849. self.b_gui = self.ui.b_gui
  850. self.b_edit = self.ui.b_edit
  851. self.label_name = self.ui.label_name
  852. self.led_control = self.ui.led_control
  853. self.led_midi = self.ui.led_midi
  854. self.led_audio_in = self.ui.led_audio_in
  855. self.led_audio_out = self.ui.led_audio_out
  856. self.line = self.ui.line
  857. self.peak_in = self.ui.peak_in
  858. self.peak_out = self.ui.peak_out
  859. self.ready()
  860. self.customContextMenuRequested.connect(self.slot_showDefaultCustomMenu)
  861. #------------------------------------------------------------------
  862. def getFixedHeight(self):
  863. return 28 if self.fIsCollapsed else 79
  864. #------------------------------------------------------------------
  865. def paintEvent(self, event):
  866. painter = QPainter(self)
  867. painter.setBrush(Qt.transparent)
  868. painter.setPen(QPen(QColor(42, 42, 42), 1))
  869. painter.drawRect(0, 1, self.width()-1, 79-3)
  870. painter.setPen(QPen(QColor(60, 60, 60), 1))
  871. painter.drawLine(0, 0, self.width(), 0)
  872. AbstractPluginSlot.paintEvent(self, event)
  873. # ------------------------------------------------------------------------------------------------------------
  874. class PluginSlot_Calf(AbstractPluginSlot):
  875. def __init__(self, parent, host, pluginId):
  876. AbstractPluginSlot.__init__(self, parent, host, pluginId)
  877. self.ui = ui_carla_plugin_calf.Ui_PluginWidget()
  878. self.ui.setupUi(self)
  879. # FIXME
  880. self.fIsCollapsed = False
  881. audioCount = self.host.get_audio_port_count_info(self.fPluginId)
  882. midiCount = self.host.get_midi_port_count_info(self.fPluginId)
  883. # -------------------------------------------------------------
  884. # Internal stuff
  885. self.fButtonFont = self.ui.b_gui.font()
  886. self.fButtonFont.setBold(False)
  887. self.fButtonFont.setPointSize(8)
  888. # Use black for mono plugins
  889. self.fBackgroundBlack = audioCount['ins'] == 1
  890. self.fButtonColorOn = QColor( 18, 41, 87)
  891. self.fButtonColorOff = QColor(150, 150, 150)
  892. # -------------------------------------------------------------
  893. # Set-up GUI
  894. self.setStyleSheet("""
  895. QLabel#label_name, QLabel#label_audio_in, QLabel#label_audio_out, QLabel#label_midi {
  896. color: #BBB;
  897. }
  898. PluginSlot_Calf#PluginWidget {
  899. background-image: url(:/bitmaps/background_calf_%s.png);
  900. background-repeat: repeat-xy;
  901. border: 2px;
  902. }
  903. """ % ("black" if self.fBackgroundBlack else "blue"))
  904. self.ui.b_gui.setPixmaps(":/bitmaps/button_calf2.png", ":/bitmaps/button_calf2_down.png", ":/bitmaps/button_calf2_hover.png")
  905. self.ui.b_edit.setPixmaps(":/bitmaps/button_calf2.png", ":/bitmaps/button_calf2_down.png", ":/bitmaps/button_calf2_hover.png")
  906. self.ui.b_remove.setPixmaps(":/bitmaps/button_calf1.png", ":/bitmaps/button_calf1_down.png", ":/bitmaps/button_calf1_hover.png")
  907. self.ui.b_edit.setTopText(self.tr("Edit"), self.fButtonColorOn, self.fButtonFont)
  908. self.ui.b_remove.setTopText(self.tr("Remove"), self.fButtonColorOn, self.fButtonFont)
  909. if self.fPluginInfo['hints'] & PLUGIN_HAS_CUSTOM_UI:
  910. self.ui.b_gui.setTopText(self.tr("GUI"), self.fButtonColorOn, self.fButtonFont)
  911. else:
  912. self.ui.b_gui.setTopText(self.tr("GUI"), self.fButtonColorOff, self.fButtonFont)
  913. labelFont = self.ui.label_name.font()
  914. labelFont.setBold(True)
  915. labelFont.setPointSize(10)
  916. self.ui.label_name.setFont(labelFont)
  917. if audioCount['ins'] == 0:
  918. self.ui.label_audio_in.hide()
  919. self.ui.peak_in.hide()
  920. if audioCount['outs'] > 0:
  921. self.ui.peak_out.setMinimumWidth(200)
  922. if audioCount['outs'] == 0:
  923. self.ui.label_audio_out.hide()
  924. self.ui.peak_out.hide()
  925. if midiCount['ins'] == 0:
  926. self.ui.label_midi.hide()
  927. self.ui.led_midi.hide()
  928. if self.fIdleTimerId != 0:
  929. self.ui.b_remove.setEnabled(False)
  930. self.ui.b_remove.setVisible(False)
  931. # -------------------------------------------------------------
  932. # Set-up parameters
  933. parameterCount = self.host.get_parameter_count(self.fPluginId) if not self.fIsCollapsed else 0
  934. index = 0
  935. limit = 7 if midiCount['ins'] == 0 else 6
  936. for i in range(parameterCount):
  937. if index >= limit:
  938. break
  939. paramInfo = self.host.get_parameter_info(self.fPluginId, i)
  940. paramData = self.host.get_parameter_data(self.fPluginId, i)
  941. paramRanges = self.host.get_parameter_ranges(self.fPluginId, i)
  942. if paramData['type'] != PARAMETER_INPUT:
  943. continue
  944. if paramData['hints'] & PARAMETER_IS_BOOLEAN:
  945. continue
  946. if paramData['hints'] & PARAMETER_IS_INTEGER:
  947. continue
  948. if (paramData['hints'] & PARAMETER_IS_ENABLED) == 0:
  949. continue
  950. paramName = getParameterShortName(paramInfo['name'])
  951. widget = PixmapDial(self, i)
  952. widget.setPixmap(7)
  953. widget.setLabel(paramName)
  954. widget.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_NO_GRADIENT)
  955. widget.setMinimum(paramRanges['min'])
  956. widget.setMaximum(paramRanges['max'])
  957. if (paramData['hints'] & PARAMETER_IS_ENABLED) == 0:
  958. widget.setEnabled(False)
  959. self.ui.w_knobs.layout().insertWidget(index, widget)
  960. index += 1
  961. self.fParameterList.append([i, widget])
  962. # -------------------------------------------------------------
  963. self.b_gui = self.ui.b_gui
  964. self.b_edit = self.ui.b_edit
  965. self.b_remove = self.ui.b_remove
  966. self.label_name = self.ui.label_name
  967. self.led_midi = self.ui.led_midi
  968. self.peak_in = self.ui.peak_in
  969. self.peak_out = self.ui.peak_out
  970. self.ready()
  971. self.ui.led_midi.setColor(self.ui.led_midi.CALF)
  972. self.customContextMenuRequested.connect(self.slot_showDefaultCustomMenu)
  973. #------------------------------------------------------------------
  974. def getFixedHeight(self):
  975. return 88
  976. #------------------------------------------------------------------
  977. def editDialogPluginHintsChanged(self, pluginId, hints):
  978. if hints & PLUGIN_HAS_CUSTOM_UI:
  979. self.ui.b_gui.setTopText(self.tr("GUI"), self.fButtonColorOn, self.fButtonFont)
  980. else:
  981. self.ui.b_gui.setTopText(self.tr("GUI"), self.fButtonColorOff, self.fButtonFont)
  982. AbstractPluginSlot.editDialogPluginHintsChanged(self, pluginId, hints)
  983. #------------------------------------------------------------------
  984. def paintEvent(self, event):
  985. painter = QPainter(self)
  986. painter.setBrush(Qt.transparent)
  987. painter.setPen(QPen(QColor(20, 20, 20) if self.fBackgroundBlack else QColor(75, 86, 99), 1))
  988. painter.drawRect(0, 1, self.width()-1, 88-3)
  989. painter.setPen(QPen(QColor(45, 45, 45) if self.fBackgroundBlack else QColor(86, 99, 114), 1))
  990. painter.drawLine(0, 0, self.width(), 0)
  991. AbstractPluginSlot.paintEvent(self, event)
  992. # ------------------------------------------------------------------------------------------------------------
  993. class PluginSlot_OpenAV(AbstractPluginSlot):
  994. def __init__(self, parent, host, pluginId):
  995. AbstractPluginSlot.__init__(self, parent, host, pluginId)
  996. self.ui = ui_carla_plugin_basic_fx.Ui_PluginWidget()
  997. self.ui.setupUi(self)
  998. # -------------------------------------------------------------
  999. # Set-up GUI
  1000. QFontDatabase.addApplicationFont(":/fonts/uranium.ttf")
  1001. labelFont = QFont()
  1002. labelFont.setFamily("Uranium")
  1003. labelFont.setPointSize(13)
  1004. labelFont.setCapitalization(QFont.AllUppercase)
  1005. self.ui.label_name.setFont(labelFont)
  1006. self.setStyleSheet("""
  1007. PluginSlot_OpenAV#PluginWidget {
  1008. background-color: qlineargradient(x1: 0, y1: 0, x2: 0, y2: 1,
  1009. stop: 0 #303030, stop: 0.35 #111111, stop: 1.0 #111111);
  1010. }
  1011. """)
  1012. self.ui.label_name.setStyleSheet("* { color: #FF5100; }")
  1013. #self.ui.line.setStyleSheet("* { background-color: #FF5100; color: #FF5100; }")
  1014. self.ui.peak_in.setMeterStyle(DigitalPeakMeter.STYLE_OPENAV)
  1015. self.ui.peak_out.setMeterStyle(DigitalPeakMeter.STYLE_OPENAV)
  1016. self.ui.b_enable.setPixmaps(":/bitmaps/button_off.png", ":/bitmaps/button_on.png", ":/bitmaps/button_off.png")
  1017. self.ui.b_edit.setPixmaps(":/bitmaps/button_edit.png", ":/bitmaps/button_edit_down.png", ":/bitmaps/button_edit_hover.png")
  1018. self.ui.b_gui.setPixmaps(":/bitmaps/button_gui.png", ":/bitmaps/button_gui_down.png", ":/bitmaps/button_gui_hover.png")
  1019. # -------------------------------------------------------------
  1020. # Set-up parameters
  1021. parameterCount = self.host.get_parameter_count(self.fPluginId) if not self.fIsCollapsed else 0
  1022. index = 0
  1023. for i in range(parameterCount):
  1024. if index >= 8:
  1025. break
  1026. paramInfo = self.host.get_parameter_info(self.fPluginId, i)
  1027. paramData = self.host.get_parameter_data(self.fPluginId, i)
  1028. paramRanges = self.host.get_parameter_ranges(self.fPluginId, i)
  1029. if paramData['type'] != PARAMETER_INPUT:
  1030. continue
  1031. if paramData['hints'] & PARAMETER_IS_BOOLEAN:
  1032. continue
  1033. if paramData['hints'] & PARAMETER_IS_INTEGER:
  1034. continue
  1035. if (paramData['hints'] & PARAMETER_IS_ENABLED) == 0:
  1036. continue
  1037. paramName = getParameterShortName(paramInfo['name'])
  1038. widget = PixmapDial(self, i)
  1039. widget.setPixmap(11)
  1040. widget.setLabel(paramName)
  1041. widget.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_NO_GRADIENT)
  1042. widget.setMinimum(paramRanges['min'])
  1043. widget.setMaximum(paramRanges['max'])
  1044. if (paramData['hints'] & PARAMETER_IS_ENABLED) == 0:
  1045. widget.setEnabled(False)
  1046. self.ui.w_knobs.layout().insertWidget(index, widget)
  1047. index += 1
  1048. self.fParameterList.append([i, widget])
  1049. self.ui.dial_drywet.setIndex(PARAMETER_DRYWET)
  1050. self.ui.dial_drywet.setPixmap(13)
  1051. self.ui.dial_drywet.setLabel("Dry/Wet")
  1052. self.ui.dial_drywet.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_NO_GRADIENT)
  1053. self.ui.dial_drywet.setMinimum(0.0)
  1054. self.ui.dial_drywet.setMaximum(1.0)
  1055. self.ui.dial_drywet.setVisible(self.fPluginInfo['hints'] & PLUGIN_CAN_DRYWET)
  1056. self.ui.dial_vol.setIndex(PARAMETER_VOLUME)
  1057. self.ui.dial_vol.setPixmap(12)
  1058. self.ui.dial_vol.setLabel("Volume")
  1059. self.ui.dial_vol.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_NO_GRADIENT)
  1060. self.ui.dial_vol.setMinimum(0.0)
  1061. self.ui.dial_vol.setMaximum(1.27)
  1062. self.ui.dial_vol.setVisible(self.fPluginInfo['hints'] & PLUGIN_CAN_VOLUME)
  1063. self.fParameterList.append([PARAMETER_DRYWET, self.ui.dial_drywet])
  1064. self.fParameterList.append([PARAMETER_VOLUME, self.ui.dial_vol])
  1065. # -------------------------------------------------------------
  1066. self.b_enable = self.ui.b_enable
  1067. self.b_gui = self.ui.b_gui
  1068. self.b_edit = self.ui.b_edit
  1069. self.label_name = self.ui.label_name
  1070. self.led_control = self.ui.led_control
  1071. self.led_midi = self.ui.led_midi
  1072. self.led_audio_in = self.ui.led_audio_in
  1073. self.led_audio_out = self.ui.led_audio_out
  1074. self.line = self.ui.line
  1075. self.peak_in = self.ui.peak_in
  1076. self.peak_out = self.ui.peak_out
  1077. self.ready()
  1078. self.customContextMenuRequested.connect(self.slot_showDefaultCustomMenu)
  1079. #------------------------------------------------------------------
  1080. def getFixedHeight(self):
  1081. return 28 if self.fIsCollapsed else 79
  1082. #------------------------------------------------------------------
  1083. def paintEvent(self, event):
  1084. painter = QPainter(self)
  1085. painter.setBrush(Qt.transparent)
  1086. painter.setPen(QPen(QColor(42, 42, 42), 1))
  1087. painter.drawRect(0, 1, self.width()-1, 79-3)
  1088. painter.setPen(QPen(QColor(60, 60, 60), 1))
  1089. painter.drawLine(0, 0, self.width(), 0)
  1090. AbstractPluginSlot.paintEvent(self, event)
  1091. # ------------------------------------------------------------------------------------------------------------
  1092. class PluginSlot_Nekobi(AbstractPluginSlot):
  1093. def __init__(self, parent, host, pluginId):
  1094. AbstractPluginSlot.__init__(self, parent, host, pluginId)
  1095. #self.ui = ui_carla_plugin_basic_fx.Ui_PluginWidget()
  1096. #self.ui.setupUi(self)
  1097. # -------------------------------------------------------------
  1098. # Set-up GUI
  1099. self.fPixmapCenter = QPixmap(":/bitmaps/background_nekobi.png")
  1100. self.fPixmapLeft = QPixmap(":/bitmaps/background_nekobi_left.png")
  1101. self.fPixmapLeftRect = QRectF(0, 0, self.fPixmapLeft.width(), self.fPixmapLeft.height())
  1102. self.fPixmapRight = QPixmap(":/bitmaps/background_nekobi_right.png")
  1103. self.fPixmapRightRect = QRectF(0, 0, self.fPixmapRight.width(), self.fPixmapRight.height())
  1104. #self.setStyleSheet("""
  1105. #PluginSlot_Nekobi#PluginWidget {
  1106. #background-image: url(:/bitmaps/background_nekobi.png);
  1107. #background-repeat: repeat-xy;
  1108. #}
  1109. #QLabel#label_name {
  1110. #color: #BBB;
  1111. #}
  1112. #""")
  1113. #------------------------------------------------------------------
  1114. def getFixedHeight(self):
  1115. return 108
  1116. #------------------------------------------------------------------
  1117. def paintEvent(self, event):
  1118. painter = QPainter(self)
  1119. # main bg (center)
  1120. painter.drawTiledPixmap(0, 0, self.width(), self.height(), self.fPixmapCenter)
  1121. # left side
  1122. painter.drawPixmap(self.fPixmapLeftRect, self.fPixmapLeft, self.fPixmapLeftRect)
  1123. # right side
  1124. rightTarget = QRectF(self.fPixmapRightRect)
  1125. rightTarget.moveLeft(self.width()-rightTarget.width())
  1126. painter.drawPixmap(rightTarget, self.fPixmapRight, self.fPixmapRightRect)
  1127. AbstractPluginSlot.paintEvent(self, event)
  1128. # ------------------------------------------------------------------------------------------------------------
  1129. class PluginSlot_SF2(AbstractPluginSlot):
  1130. def __init__(self, parent, host, pluginId):
  1131. AbstractPluginSlot.__init__(self, parent, host, pluginId)
  1132. self.ui = ui_carla_plugin_sf2.Ui_PluginWidget()
  1133. self.ui.setupUi(self)
  1134. # -------------------------------------------------------------
  1135. # Set-up GUI
  1136. #labelFont = self.ui.label_name.font()
  1137. #labelFont.setBold(True)
  1138. #labelFont.setPointSize(9)
  1139. #self.ui.label_name.setFont(labelFont)
  1140. self.setStyleSheet("""
  1141. PluginSlot_SF2#PluginWidget {
  1142. background-image: url(:/bitmaps/background_3bandeq.png);
  1143. background-repeat: repeat-xy;
  1144. }
  1145. QLabel#label_name {
  1146. color: #BBB;
  1147. }
  1148. """)
  1149. self.ui.b_enable.setPixmaps(":/bitmaps/button_off.png", ":/bitmaps/button_on.png", ":/bitmaps/button_off.png")
  1150. self.ui.b_edit.setPixmaps(":/bitmaps/button_edit.png", ":/bitmaps/button_edit_down.png", ":/bitmaps/button_edit_hover.png")
  1151. # -------------------------------------------------------------
  1152. # Set-up parameters
  1153. parameterCount = self.host.get_parameter_count(self.fPluginId) if not self.fIsCollapsed else 0
  1154. index = 0
  1155. for i in range(parameterCount):
  1156. if index >= 8:
  1157. break
  1158. paramInfo = self.host.get_parameter_info(self.fPluginId, i)
  1159. paramData = self.host.get_parameter_data(self.fPluginId, i)
  1160. paramRanges = self.host.get_parameter_ranges(self.fPluginId, i)
  1161. if paramData['type'] != PARAMETER_INPUT:
  1162. continue
  1163. if paramData['hints'] & PARAMETER_IS_BOOLEAN:
  1164. continue
  1165. if paramData['hints'] & PARAMETER_IS_INTEGER:
  1166. continue
  1167. if (paramData['hints'] & PARAMETER_IS_ENABLED) == 0:
  1168. continue
  1169. paramName = getParameterShortName(paramInfo['name'])
  1170. widget = PixmapDial(self, i)
  1171. widget.setPixmap(3)
  1172. widget.setLabel(paramName)
  1173. widget.setMinimum(paramRanges['min'])
  1174. widget.setMaximum(paramRanges['max'])
  1175. if (paramData['hints'] & PARAMETER_IS_ENABLED) == 0:
  1176. widget.setEnabled(False)
  1177. self.ui.w_knobs.layout().insertWidget(index, widget)
  1178. index += 1
  1179. self.fParameterList.append([i, widget])
  1180. self.ui.dial_vol.setIndex(PARAMETER_VOLUME)
  1181. self.ui.dial_vol.setPixmap(3)
  1182. self.ui.dial_vol.setLabel("Volume")
  1183. self.ui.dial_vol.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_CARLA_VOL)
  1184. self.ui.dial_vol.setMinimum(0.0)
  1185. self.ui.dial_vol.setMaximum(1.27)
  1186. self.ui.dial_vol.forceWhiteLabelGradientText()
  1187. self.ui.dial_vol.setVisible(self.fPluginInfo['hints'] & PLUGIN_CAN_VOLUME)
  1188. self.fParameterList.append([PARAMETER_VOLUME, self.ui.dial_vol])
  1189. # -------------------------------------------------------------
  1190. self.b_enable = self.ui.b_enable
  1191. self.b_edit = self.ui.b_edit
  1192. self.label_name = self.ui.label_name
  1193. self.led_control = self.ui.led_control
  1194. self.led_midi = self.ui.led_midi
  1195. self.led_audio_out = self.ui.led_audio_out
  1196. self.line = self.ui.line
  1197. self.peak_out = self.ui.peak_out
  1198. self.ready()
  1199. self.customContextMenuRequested.connect(self.slot_showDefaultCustomMenu)
  1200. #------------------------------------------------------------------
  1201. def getFixedHeight(self):
  1202. return 79
  1203. #------------------------------------------------------------------
  1204. def paintEvent(self, event):
  1205. painter = QPainter(self)
  1206. painter.setBrush(Qt.transparent)
  1207. painter.setPen(QPen(QColor(42, 42, 42), 1))
  1208. painter.drawRect(0, 1, self.width()-1, 79-3)
  1209. painter.setPen(QPen(QColor(60, 60, 60), 1))
  1210. painter.drawLine(0, 0, self.width(), 0)
  1211. AbstractPluginSlot.paintEvent(self, event)
  1212. # ------------------------------------------------------------------------------------------------------------
  1213. class PluginSlot_ZynFX(AbstractPluginSlot):
  1214. def __init__(self, parent, host, pluginId):
  1215. AbstractPluginSlot.__init__(self, parent, host, pluginId)
  1216. self.ui = ui_carla_plugin_zynfx.Ui_PluginWidget()
  1217. self.ui.setupUi(self)
  1218. # -------------------------------------------------------------
  1219. # Set-up GUI
  1220. self.setStyleSheet("""
  1221. PluginSlot_ZynFX#PluginWidget {
  1222. background-image: url(:/bitmaps/background_zynfx.png);
  1223. background-repeat: repeat-xy;
  1224. border: 2px;
  1225. }
  1226. QLabel#label_name, QLabel#label_presets {
  1227. color: #BBB;
  1228. }
  1229. """)
  1230. self.ui.b_enable.setPixmaps(":/bitmaps/button_off.png", ":/bitmaps/button_on.png", ":/bitmaps/button_off.png")
  1231. self.ui.b_edit.setPixmaps(":/bitmaps/button_edit.png", ":/bitmaps/button_edit_down.png", ":/bitmaps/button_edit_hover.png")
  1232. labelFont = self.ui.label_name.font()
  1233. labelFont.setBold(True)
  1234. labelFont.setPointSize(9)
  1235. self.ui.label_name.setFont(labelFont)
  1236. presetFont = self.ui.label_presets.font()
  1237. presetFont.setBold(True)
  1238. presetFont.setPointSize(8)
  1239. self.ui.label_presets.setFont(presetFont)
  1240. self.ui.peak_in.setMeterStyle(DigitalPeakMeter.STYLE_OPENAV)
  1241. self.ui.peak_out.setMeterStyle(DigitalPeakMeter.STYLE_OPENAV)
  1242. # -------------------------------------------------------------
  1243. # Set-up parameters
  1244. parameterCount = self.host.get_parameter_count(self.fPluginId) if not self.fIsCollapsed else 0
  1245. index = 0
  1246. for i in range(parameterCount):
  1247. paramInfo = self.host.get_parameter_info(self.fPluginId, i)
  1248. paramData = self.host.get_parameter_data(self.fPluginId, i)
  1249. paramRanges = self.host.get_parameter_ranges(self.fPluginId, i)
  1250. if paramData['type'] != PARAMETER_INPUT:
  1251. continue
  1252. if paramData['hints'] & PARAMETER_IS_BOOLEAN:
  1253. continue
  1254. if paramData['hints'] & PARAMETER_IS_INTEGER:
  1255. continue
  1256. if (paramData['hints'] & PARAMETER_IS_ENABLED) == 0:
  1257. continue
  1258. paramName = paramInfo['name']
  1259. # real zyn fx plugins
  1260. if self.fPluginInfo['label'] == "zynalienwah":
  1261. if i == 0: paramName = "Freq"
  1262. elif i == 1: paramName = "Rnd"
  1263. elif i == 2: paramName = "L type" # combobox
  1264. elif i == 3: paramName = "St.df"
  1265. elif i == 5: paramName = "Fb"
  1266. elif i == 7: paramName = "L/R"
  1267. elif self.fPluginInfo['label'] == "zynchorus":
  1268. if i == 0: paramName = "Freq"
  1269. elif i == 1: paramName = "Rnd"
  1270. elif i == 2: paramName = "L type" # combobox
  1271. elif i == 3: paramName = "St.df"
  1272. elif i == 6: paramName = "Fb"
  1273. elif i == 7: paramName = "L/R"
  1274. elif i == 8: paramName = "Flngr" # button
  1275. elif i == 9: paramName = "Subst" # button
  1276. elif self.fPluginInfo['label'] == "zyndistortion":
  1277. if i == 0: paramName = "LRc."
  1278. elif i == 4: paramName = "Neg." # button
  1279. elif i == 5: paramName = "LPF"
  1280. elif i == 6: paramName = "HPF"
  1281. elif i == 7: paramName = "St." # button
  1282. elif i == 8: paramName = "PF" # button
  1283. elif self.fPluginInfo['label'] == "zyndynamicfilter":
  1284. if i == 0: paramName = "Freq"
  1285. elif i == 1: paramName = "Rnd"
  1286. elif i == 2: paramName = "L type" # combobox
  1287. elif i == 3: paramName = "St.df"
  1288. elif i == 4: paramName = "LfoD"
  1289. elif i == 5: paramName = "A.S."
  1290. elif i == 6: paramName = "A.Inv." # button
  1291. elif i == 7: paramName = "A.M."
  1292. elif self.fPluginInfo['label'] == "zynecho":
  1293. if i == 1: paramName = "LRdl."
  1294. elif i == 2: paramName = "LRc."
  1295. elif i == 3: paramName = "Fb."
  1296. elif i == 4: paramName = "Damp"
  1297. elif self.fPluginInfo['label'] == "zynphaser":
  1298. if i == 0: paramName = "Freq"
  1299. elif i == 1: paramName = "Rnd"
  1300. elif i == 2: paramName = "L type" # combobox
  1301. elif i == 3: paramName = "St.df"
  1302. elif i == 5: paramName = "Fb"
  1303. elif i == 7: paramName = "L/R"
  1304. elif i == 8: paramName = "Subst" # button
  1305. elif i == 9: paramName = "Phase"
  1306. elif i == 11: paramName = "Dist"
  1307. elif self.fPluginInfo['label'] == "zynreverb":
  1308. if i == 2: paramName = "I.delfb"
  1309. elif i == 5: paramName = "LPF"
  1310. elif i == 6: paramName = "HPF"
  1311. elif i == 9: paramName = "R.S."
  1312. elif i == 10: paramName = "I.del"
  1313. else:
  1314. paramName = getParameterShortName(paramInfo['name'])
  1315. widget = PixmapDial(self, i)
  1316. widget.setPixmap(5)
  1317. widget.setLabel(paramName)
  1318. widget.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_NO_GRADIENT)
  1319. widget.setMinimum(paramRanges['min'])
  1320. widget.setMaximum(paramRanges['max'])
  1321. if (paramData['hints'] & PARAMETER_IS_ENABLED) == 0:
  1322. widget.setEnabled(False)
  1323. self.ui.w_knobs.layout().insertWidget(index, widget)
  1324. index += 1
  1325. self.fParameterList.append([i, widget])
  1326. self.ui.dial_drywet.setIndex(PARAMETER_DRYWET)
  1327. self.ui.dial_drywet.setPixmap(5)
  1328. self.ui.dial_drywet.setLabel("Wet")
  1329. self.ui.dial_drywet.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_NO_GRADIENT)
  1330. self.ui.dial_drywet.setMinimum(0.0)
  1331. self.ui.dial_drywet.setMaximum(1.0)
  1332. self.ui.dial_drywet.setVisible(self.fPluginInfo['hints'] & PLUGIN_CAN_DRYWET)
  1333. self.ui.dial_vol.setIndex(PARAMETER_VOLUME)
  1334. self.ui.dial_vol.setPixmap(5)
  1335. self.ui.dial_vol.setLabel("Vol")
  1336. self.ui.dial_vol.setCustomPaintMode(PixmapDial.CUSTOM_PAINT_MODE_NO_GRADIENT)
  1337. self.ui.dial_vol.setMinimum(0.0)
  1338. self.ui.dial_vol.setMaximum(1.27)
  1339. self.ui.dial_vol.setVisible(self.fPluginInfo['hints'] & PLUGIN_CAN_VOLUME)
  1340. self.fParameterList.append([PARAMETER_DRYWET, self.ui.dial_drywet])
  1341. self.fParameterList.append([PARAMETER_VOLUME, self.ui.dial_vol])
  1342. # -------------------------------------------------------------
  1343. # Set-up MIDI programs
  1344. midiProgramCount = self.host.get_midi_program_count(self.fPluginId)
  1345. if midiProgramCount > 0:
  1346. self.ui.cb_presets.setEnabled(True)
  1347. self.ui.label_presets.setEnabled(True)
  1348. for i in range(midiProgramCount):
  1349. mpData = self.host.get_midi_program_data(self.fPluginId, i)
  1350. mpName = mpData['name']
  1351. self.ui.cb_presets.addItem(mpName)
  1352. self.fCurrentMidiProgram = self.host.get_current_midi_program_index(self.fPluginId)
  1353. self.ui.cb_presets.setCurrentIndex(self.fCurrentMidiProgram)
  1354. else:
  1355. self.fCurrentMidiProgram = -1
  1356. self.ui.cb_presets.setEnabled(False)
  1357. self.ui.cb_presets.setVisible(False)
  1358. self.ui.label_presets.setEnabled(False)
  1359. self.ui.label_presets.setVisible(False)
  1360. # -------------------------------------------------------------
  1361. self.b_enable = self.ui.b_enable
  1362. self.b_edit = self.ui.b_edit
  1363. self.cb_presets = self.ui.cb_presets
  1364. self.label_name = self.ui.label_name
  1365. self.led_control = self.ui.led_control
  1366. self.led_midi = self.ui.led_midi
  1367. self.led_audio_in = self.ui.led_audio_in
  1368. self.led_audio_out = self.ui.led_audio_out
  1369. self.line = self.ui.line
  1370. self.peak_in = self.ui.peak_in
  1371. self.peak_out = self.ui.peak_out
  1372. self.ready()
  1373. self.customContextMenuRequested.connect(self.slot_showDefaultCustomMenu)
  1374. self.ui.cb_presets.currentIndexChanged.connect(self.slot_midiProgramChanged)
  1375. #------------------------------------------------------------------
  1376. def getFixedHeight(self):
  1377. return 30 if self.fIsCollapsed else 79
  1378. #------------------------------------------------------------------
  1379. def paintEvent(self, event):
  1380. painter = QPainter(self)
  1381. painter.setBrush(Qt.transparent)
  1382. painter.setPen(QPen(QColor(60, 60, 60), 1))
  1383. painter.drawRect(0, 1, self.width()-1, self.height()-3)
  1384. painter.setPen(QPen(QColor(94, 94, 94), 1))
  1385. painter.drawLine(0, 0, self.width(), 0)
  1386. AbstractPluginSlot.paintEvent(self, event)
  1387. # ------------------------------------------------------------------------------------------------------------
  1388. def createPluginSlot(parent, host, pluginId, useSkins):
  1389. if not useSkins:
  1390. return PluginSlot_Default(parent, host, pluginId)
  1391. pluginInfo = host.get_plugin_info(pluginId)
  1392. pluginName = host.get_real_plugin_name(pluginId)
  1393. pluginLabel = pluginInfo['label']
  1394. pluginMaker = pluginInfo['maker']
  1395. uniqueId = pluginInfo['uniqueId']
  1396. #pluginIcon = pluginInfo['iconName']
  1397. if pluginInfo['type'] == PLUGIN_SF2:
  1398. return PluginSlot_SF2(parent, host, pluginId)
  1399. if pluginMaker == "OpenAV Productions":
  1400. return PluginSlot_OpenAV(parent, host, pluginId)
  1401. if pluginInfo['type'] == PLUGIN_INTERNAL:
  1402. if pluginLabel.startswith("zyn") and pluginInfo['category'] != PLUGIN_CATEGORY_SYNTH:
  1403. return PluginSlot_ZynFX(parent, host, pluginId)
  1404. elif pluginInfo['type'] == PLUGIN_LADSPA:
  1405. if pluginLabel.startswith("Zyn") and pluginMaker.startswith("Josep Andreu"):
  1406. return PluginSlot_ZynFX(parent, host, pluginId)
  1407. if pluginName.split(" ", 1)[0].lower() == "calf":
  1408. return PluginSlot_Calf(parent, host, pluginId)
  1409. #if pluginName.lower() == "nekobi":
  1410. #return PluginSlot_Nekobi(parent, pluginId)
  1411. return PluginSlot_BasicFX(parent, host, pluginId)
  1412. # ------------------------------------------------------------------------------------------------------------
  1413. # Main Testing
  1414. if __name__ == '__main__':
  1415. from carla_app import CarlaApplication
  1416. from carla_host import initHost, loadHostSettings
  1417. import resources_rc
  1418. app = CarlaApplication("Carla-Skins")
  1419. host = initHost("Skins", None, False, False, False)
  1420. loadHostSettings(host)
  1421. host.engine_init("JACK", "Carla-Widgets")
  1422. host.add_plugin(BINARY_NATIVE, PLUGIN_INTERNAL, "", "", "zynreverb", 0, None, 0x0)
  1423. #host.add_plugin(BINARY_NATIVE, PLUGIN_DSSI, "/usr/lib/dssi/karplong.so", "karplong", "karplong", 0, None, 0x0)
  1424. #host.add_plugin(BINARY_NATIVE, PLUGIN_LV2, "", "", "http://www.openavproductions.com/sorcer", 0, None, 0x0)
  1425. #host.add_plugin(BINARY_NATIVE, PLUGIN_LV2, "", "", "http://calf.sourceforge.net/plugins/Compressor", 0, None, 0x0)
  1426. host.set_active(0, True)
  1427. gui = createPluginSlot(None, host, 0, True)
  1428. gui.testTimer()
  1429. gui.show()
  1430. app.exec_()