QML使用Python的函數(shù)過程解析
有2種方法:
一、 QML中定義一個信號,連接Python里的函數(shù);
這里的函數(shù)不用特意指明為槽函數(shù),普通函數(shù)即可。
QML的信號連接Python的函數(shù)
QML:
首先在QML中定義一個信號,這里的信號傳遞一個字符串給函數(shù)(信號可帶參數(shù)也可不帶):
signal mySignal(string my_string)
然后在click中發(fā)射這個信號:
onClicked:{
root.mySignal("hello world")
}
Python:
使用QML里的信號連接Python里的函數(shù):
engine.rootObjects()[0].mySignal.connect(my_func) # 這里的mySignal是在QML里定義的
完整代碼:
QML:
import QtQuick 2.12
import QtQuick.Controls 2.12
ApplicationWindow {
id: root
width: 250
height: 500
visible: true
signal mySignal(string my_string)
MouseArea {
id: mouse_area
anchors.fill: parent
onClicked: {
root.mySignal("hello world")
}
}
}
Python:
from PyQt5.QtCore import QObject
from PyQt5.QtGui import QGuiApplication
from PyQt5.QtQml import QQmlApplicationEngine
import sys
class MyWindow(QObject):
def __init__(self):
super().__init__()
self.engine = QQmlApplicationEngine()
self.engine.load('qml-test.qml')
# root signal
my_obj = self.engine.rootObjects()[0]
my_obj.mySignal.connect(self.my_func)
def my_func(self, my_string):
print(my_string)
if __name__ == '__main__':
app = QGuiApplication(sys.argv)
window = MyWindow()
sys.exit(app.exec())
二、 Python中定義一個類及槽函數(shù),在QML中使用這個槽函數(shù)
在QML中調(diào)用Python中的槽函數(shù)
首先需要在Python里定義一個類,在類里寫一個槽函數(shù):
class Person(QObject):
def __init__(self):
super().__init__()
@pyqtSlot() # 注意是槽函數(shù)!
def begin(self):
print('begin')
然后通過setContextProperty將這個類設(shè)置為上下文的一個屬性值:
person = Person()
engine.rootContext().setContextProperty('person', person)
QML文件里不需特別設(shè)置,直接調(diào)用函數(shù)即可。
完整代碼:
Python:
from PyQt5.QtGui import QGuiApplication
from PyQt5.QtQml import QQmlApplicationEngine
from PyQt5.QtCore import QObject, pyqtSlot
import sys
class Person(QObject):
def __init__(self):
super().__init__()
@pyqtSlot() # 注意是槽函數(shù)!
def begin(self):
print('begin')
if __name__ == '__main__':
app = QGuiApplication(sys.argv)
engine = QQmlApplicationEngine()
person = Person()
engine.rootContext().setContextProperty('person', person)
engine.load('qml-test.qml')
sys.exit(app.exec())
QML:
import QtQuick 2.12
import QtQuick.Controls 2.12
ApplicationWindow {
id: root
width: 250
height: 500
visible: true
Button{
text:qsTr("begin")
onClicked: {
person.begin()
}
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
pandas 按日期范圍篩選數(shù)據(jù)的實現(xiàn)
這篇文章主要介紹了pandas 按日期范圍篩選數(shù)據(jù)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
Python實現(xiàn)解析路徑字符串并獲取每個文件夾名稱
在?Python?中,解析路徑字符串并獲取每個文件夾的名稱是一項常見的任務(wù),這篇文章主要為大家詳細(xì)介紹了Python解析路徑字符串的具體方法,希望對大家有所幫助2024-04-04
Qt通過QGraphicsview實現(xiàn)簡單縮放及還原效果
本文主要介紹通過QGraphicsview實現(xiàn)簡單的縮放以及縮放后還原原始大小,通過scale可以對view進(jìn)行放大或縮小,具體內(nèi)容詳情跟隨小編一起看看吧2021-09-09
詳解Python操作RabbitMQ服務(wù)器消息隊列的遠(yuǎn)程結(jié)果返回
RabbitMQ是一款基于MQ的服務(wù)器,Python可以通過Pika庫來進(jìn)行程序操控,這里我們將來詳解Python操作RabbitMQ服務(wù)器消息隊列的遠(yuǎn)程結(jié)果返回:2016-06-06
django的403/404/500錯誤自定義頁面的配置方式
這篇文章主要介紹了django的403/404/500錯誤自定義頁面的配置方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05
python使用OpenCV實現(xiàn)多目標(biāo)跟蹤
這篇文章主要介紹了python使用OpenCV實現(xiàn)多目標(biāo)跟蹤,如何在OpenCV中使用MultiTracker類實現(xiàn)多目標(biāo)跟蹤API。在深入了解詳細(xì)信息之前,請查看下面列出的關(guān)于目標(biāo)跟蹤的帖子,以了解在OpenCV中實現(xiàn)的單個目標(biāo)跟蹤器的基礎(chǔ)知識,需要的朋友可以參考一下2022-04-04

