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.

1888 lines
68KB

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