當前位置: 首頁>>代碼示例>>Python>>正文


Python QCoreApplication.instance方法代碼示例

本文整理匯總了Python中PyQt5.QtCore.QCoreApplication.instance方法的典型用法代碼示例。如果您正苦於以下問題:Python QCoreApplication.instance方法的具體用法?Python QCoreApplication.instance怎麽用?Python QCoreApplication.instance使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在PyQt5.QtCore.QCoreApplication的用法示例。


在下文中一共展示了QCoreApplication.instance方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: __init__

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def __init__(self, parent=None, button_func=None, params=None):
        super().__init__(parent, 'Error', params)

        if self.params.lang == 'en':
            text = ('Unexpected error occured.\n'
                    'Please exit the application and solve the problem.')
        else:
            text = ('予期せぬエラーが発生しました。\n'
                    'アプリケーションを終了し,問題を解決してください。')
        self.set_paragraph('Unexpected error', text=text)

        self.set_paragraph('Traceback log', text=self.params.error)

        self.vbox.addStretch(1)

        btn = QPushButton('Exit', self.inner)
        btn.setStyleSheet('QPushButton{font: bold; font-size: 15pt; background-color: white;};')
        btn.clicked.connect(QCoreApplication.instance().quit)

        self.vbox.addWidget(btn) 
開發者ID:canard0328,項目名稱:malss,代碼行數:22,代碼來源:error.py

示例2: closeEvent

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def closeEvent(self, event):
        if self.gui.main_window.gateways:
            event.accept()
        else:
            event.ignore()
            msgbox = QMessageBox(self)
            msgbox.setIcon(QMessageBox.Question)
            msgbox.setWindowTitle("Exit setup?")
            msgbox.setText("Are you sure you wish to exit?")
            msgbox.setInformativeText(
                "{} has not yet been configured.".format(APP_NAME)
            )
            msgbox.setStandardButtons(QMessageBox.Yes | QMessageBox.No)
            msgbox.setDefaultButton(QMessageBox.No)
            if msgbox.exec_() == QMessageBox.Yes:
                if sys.platform == "win32":
                    self.gui.systray.hide()
                QCoreApplication.instance().quit() 
開發者ID:gridsync,項目名稱:gridsync,代碼行數:20,代碼來源:welcome.py

示例3: callFunction

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def callFunction(self) -> None:
        self._function(*self._args, **self._kwargs)


#
#
# This is not a singleton class. The TaskManager is intended to make it easier for certain task-management-ish classes
# to handle tasks within the Qt event loop framework. It makes it easier to:
#
#  - Schedule a callback that will be picked up by the Qt event loop later.
#  - Schedule a callback with a delay (given in seconds).
#  - Remove all callbacks that has been scheduled but not yet invoked.
#
# This class uses QEvent, unique QEvent types, and QCoreApplication::postEvent() to achieve those functionality. A
# unique QEvent type is assigned for each TaskManager instance, so each instance can cancel the QEvent posted by itself.
# The unique QEvent type is retrieved via QEvent.registerEventType(), which will return a unique custom event type if
# available. If no more custom event type is available, it will return -1. A custom/user event type is a number between
# QEvent::User (1000) and QEvent::MaxUser (65535). See https://doc.qt.io/qt-5/qevent.html
#
# Here we use QCoreApplication.removePostedEvents() to remove posted but not yet dispatched events. Those are the events
# that have been posted but not yet processed. You can consider this as cancelling a task that you have scheduled
# earlier but it has not yet been executed. Because QCoreApplication.removePostedEvents() can use an eventType argument
# to specify the event type you want to remove, here we use that unique custom event type for each TaskManager to
# identify all events that are managed by the TaskManager itself. See https://doc.qt.io/qt-5/qcoreapplication.html
#
# According to my experience, QTimer doesn't seem to trigger events very accurately. I had for example, an expected
# delay of 5.0 seconds, but I got an actual delay of 4.7 seconds. That's around 6% off. So, here we add a little
# tolerance to all the specified delay.
# 
開發者ID:Ultimaker,項目名稱:Uranium,代碼行數:31,代碼來源:TaskManager.py

示例4: event_type

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def event_type(self) -> int:
        return self._event_type

    # Cleans up all the delayed events and remove all events that were posted by this TaskManager instance. 
開發者ID:Ultimaker,項目名稱:Uranium,代碼行數:6,代碼來源:TaskManager.py

示例5: cleanup

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def cleanup(self) -> None:
        for event in list(self._delayed_events.keys()):
            self._cleanupDelayedCallEvent(event)
        self._delayed_events.clear()

        # Removes all events that have been posted to the QApplication.
        QCoreApplication.instance().removePostedEvents(None, self._event_type)

    # Schedules a callback function to be called later. If delay is given, the callback will be scheduled to call after
    # the given amount of time. Otherwise, the callback will be scheduled to the QCoreApplication instance to be called
    # the next time the event gets picked up. 
開發者ID:Ultimaker,項目名稱:Uranium,代碼行數:13,代碼來源:TaskManager.py

示例6: callLater

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def callLater(self, delay: float, callback: Callable, *args, **kwargs) -> None:
        if delay < 0:
            raise ValueError("delay must be a non-negative value, but got [%s] instead." % delay)

        delay_to_use = None if delay <= 0 else delay
        event = _CallFunctionEvent(self, callback, args, kwargs,
                                   delay = delay_to_use)
        if delay_to_use is None:
            QCoreApplication.instance().postEvent(self, event)
        else:
            self._scheduleDelayedCallEvent(event) 
開發者ID:Ultimaker,項目名稱:Uranium,代碼行數:13,代碼來源:TaskManager.py

示例7: _onDelayReached

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def _onDelayReached(self, event: "_CallFunctionEvent") -> None:
        QCoreApplication.instance().postEvent(self, event)

    # Handle Qt events 
開發者ID:Ultimaker,項目名稱:Uranium,代碼行數:6,代碼來源:TaskManager.py

示例8: __init__

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def __init__(self, engine, parent = None) -> None:
        super().__init__(parent)

        self._engine = engine
        self._styles = None  # type: Optional[QObject]
        self._path = ""
        self._icons = {}  # type: Dict[str, QUrl]
        self._images = {}  # type: Dict[str, QUrl]

        # Workaround for incorrect default font on Windows
        if sys.platform == "win32":
            default_font = QFont()
            default_font.setPointSize(9)
            QCoreApplication.instance().setFont(default_font)

        self._em_height = int(QFontMetrics(QCoreApplication.instance().font()).ascent())
        self._em_width = self._em_height

        # Cache the initial language in the preferences. For fonts, a special font can be defined with, for example,
        # "medium" and "medium_nl_NL". If the special one exists, getFont() will return that, otherwise the default
        # will be returned. We cache the initial language here is because Cura can only change its language if it gets
        # restarted, so we need to keep the fonts consistent in a single Cura run.
        self._preferences = UM.Application.Application.getInstance().getPreferences()
        self._lang_code = self._preferences.getValue("general/language")

        self._initializeDefaults()

        self.reload() 
開發者ID:Ultimaker,項目名稱:Uranium,代碼行數:30,代碼來源:Theme.py

示例9: _initializeDefaults

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def _initializeDefaults(self) -> None:
        self._fonts = {
            "system": QCoreApplication.instance().font(),
            "fixed": QFontDatabase.systemFont(QFontDatabase.FixedFont)
        }

        palette = QCoreApplication.instance().palette()
        self._colors = {
            "system_window": palette.window(),
            "system_text": palette.text()
        }

        self._sizes = {
            "line": QSizeF(self._em_width, self._em_height)
        } 
開發者ID:Ultimaker,項目名稱:Uranium,代碼行數:17,代碼來源:Theme.py

示例10: getInstance

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def getInstance(cls, engine = None) -> "Theme":
        """Get the singleton instance for this class."""

        # Note: Explicit use of class name to prevent issues with inheritance.
        if Theme.__instance is None:
            Theme.__instance = cls(engine)
        return Theme.__instance 
開發者ID:Ultimaker,項目名稱:Uranium,代碼行數:9,代碼來源:Theme.py

示例11: createQmlComponent

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def createQmlComponent(self, qml_file_path: str, context_properties: Dict[str, "QObject"] = None) -> Optional["QObject"]:
        """Create a QML component from a qml file.
        :param qml_file_path:: The absolute file path to the root qml file.
        :param context_properties:: Optional dictionary containing the properties that will be set on the context of the
        qml instance before creation.
        :return: None in case the creation failed (qml error), else it returns the qml instance.
        :note If the creation fails, this function will ensure any errors are logged to the logging service.
        """

        if self._qml_engine is None: # Protect in case the engine was not initialized yet
            return None
        path = QUrl.fromLocalFile(qml_file_path)
        component = QQmlComponent(self._qml_engine, path)
        result_context = QQmlContext(self._qml_engine.rootContext()) #type: ignore #MyPy doens't realise that self._qml_engine can't be None here.
        if context_properties is not None:
            for name, value in context_properties.items():
                result_context.setContextProperty(name, value)
        result = component.create(result_context)
        for err in component.errors():
            Logger.log("e", str(err.toString()))
        if result is None:
            return None

        # We need to store the context with the qml object, else the context gets garbage collected and the qml objects
        # no longer function correctly/application crashes.
        result.attached_context = result_context
        return result 
開發者ID:Ultimaker,項目名稱:Uranium,代碼行數:29,代碼來源:QtApplication.py

示例12: getInstance

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def getInstance(cls, *args, **kwargs) -> "QtApplication":
        """Gets the instance of this application.

        This is just to further specify the type of Application.getInstance().
        :return: The instance of this application.
        """

        return cast(QtApplication, super().getInstance(**kwargs)) 
開發者ID:Ultimaker,項目名稱:Uranium,代碼行數:10,代碼來源:QtApplication.py

示例13: initUI

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def initUI(self):               
        
        qbtn = QPushButton('Quit', self)
        qbtn.clicked.connect(QCoreApplication.instance().quit) # 事件傳遞
        qbtn.resize(qbtn.sizeHint())
        qbtn.move(50, 50)       
        
        self.setGeometry(300, 300, 250, 150)
        self.setWindowTitle('Quit button')    
        self.show() 
開發者ID:Yeah-Kun,項目名稱:python,代碼行數:12,代碼來源:Closing_a_window.py

示例14: initUI

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def initUI(self):
        self.setGeometry(300, 300, 1280, 720)
        self.setWindowTitle('Face verification demo 1')

        self.l1_btn = QPushButton('Load 1...')
        self.l2_btn = QPushButton('Load 2...')

        self.match_btn = QPushButton('Match')
        self.exit_btn = QPushButton('Exit')

        self.i_lbl[0] = QLabel()
        self.i_lbl[1] = QLabel()

        self.exit_btn.clicked.connect(QCoreApplication.instance().quit)
        self.l1_btn.clicked.connect(self.l1_clicked)
        self.l2_btn.clicked.connect(self.l2_clicked)
        self.match_btn.clicked.connect(self.match_clicked)

        hbox = QHBoxLayout()
        hbox.addWidget(self.l1_btn)
        hbox.addWidget(self.l2_btn)
        hbox.addStretch(1)
        hbox.addWidget(self.match_btn)
        hbox.addStretch(1)
        hbox.addWidget(self.exit_btn)

        hbox2 = QHBoxLayout()
        hbox2.addWidget(self.i_lbl[0])
        hbox2.addStretch(1)
        hbox2.addWidget(self.i_lbl[1])

        vbox = QVBoxLayout()
        vbox.addStretch(1)
        vbox.addLayout(hbox2)
        vbox.addStretch(1)
        vbox.addLayout(hbox)

        self.setLayout(vbox)

        self.show() 
開發者ID:meownoid,項目名稱:face-identification-tpe,代碼行數:42,代碼來源:demo_app1.py

示例15: __init__

# 需要導入模塊: from PyQt5.QtCore import QCoreApplication [as 別名]
# 或者: from PyQt5.QtCore.QCoreApplication import instance [as 別名]
def __init__(self):
        threading.Thread.__init__(self)
        self.daemon = True  # OK for main to exit even if instance is still running
        self.paused = False  # start out non-paused
        self.state = threading.Condition() 
開發者ID:artisan-roaster-scope,項目名稱:artisan,代碼行數:7,代碼來源:queue.py


注:本文中的PyQt5.QtCore.QCoreApplication.instance方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。