1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- # Copyright (c) 2016 Ultimaker B.V.
- # Cura is released under the terms of the LGPLv3 or higher.
- from PyQt5.QtCore import QObject, pyqtSlot, pyqtProperty, pyqtSignal
- from UM.PluginObject import PluginObject
- from UM.PluginRegistry import PluginRegistry
- from UM.Application import Application
- import os
- ## Machine actions are actions that are added to a specific machine type. Examples of such actions are
- # updating the firmware, connecting with remote devices or doing bed leveling. A machine action can also have a
- # qml, which should contain a "Cura.MachineAction" item. When activated, the item will be displayed in a dialog
- # and this object will be added as "manager" (so all pyqtSlot() functions can be called by calling manager.func())
- class MachineAction(QObject, PluginObject):
- ## Create a new Machine action.
- # \param key unique key of the machine action
- # \param label Human readable label used to identify the machine action.
- def __init__(self, key, label = ""):
- super().__init__()
- self._key = key
- self._label = label
- self._qml_url = ""
- self._view = None
- self._finished = False
- labelChanged = pyqtSignal()
- onFinished = pyqtSignal()
- def getKey(self):
- return self._key
- @pyqtProperty(str, notify = labelChanged)
- def label(self):
- return self._label
- def setLabel(self, label):
- if self._label != label:
- self._label = label
- self.labelChanged.emit()
- ## Reset the action to it's default state.
- # This should not be re-implemented by child classes, instead re-implement _reset.
- # /sa _reset
- @pyqtSlot()
- def reset(self):
- self._finished = False
- self._reset()
- ## Protected implementation of reset.
- # /sa reset()
- def _reset(self):
- pass
- @pyqtSlot()
- def setFinished(self):
- self._finished = True
- self._reset()
- self.onFinished.emit()
- @pyqtProperty(bool, notify = onFinished)
- def finished(self):
- return self._finished
- ## Protected helper to create a view object based on provided QML.
- def _createViewFromQML(self):
- path = os.path.join(PluginRegistry.getInstance().getPluginPath(self.getPluginId()), self._qml_url)
- self._view = Application.getInstance().createQmlComponent(path, {"manager": self})
- @pyqtProperty(QObject, constant = True)
- def displayItem(self):
- if not self._view:
- self._createViewFromQML()
- return self._view
|