Qt是一个跨平台框架,通常用作图形工具包,它不仅创建CLI应用程序中非常有用。而且它也可以在三种主要的台式机操作系统以及移动操作系统(如Symbian,Nokia Belle,Meego Harmattan,MeeGo或BB10)以及嵌入式设备,Android(Necessitas)和iOS的端口上运行。现在我们为你提供了免费的试用版。赶快点击下载Qt最新试用版吧>>
自从PySide植到Qt5(又名PySide2)的初始端口以来,由于QML的普及,我们希望在绑定集中完全支持QML的交互。
在第一个正式发行版5.12中,涵盖了QML和Python交互的许多用例,但还是忽略了社区真正需要的几个用例。现在我们正在开发Qt6的新功能和改进,我们希望解决其中的大多数问题。
在这里,您可以找到我们到目前为止计划在Python 6.0 Qt中所要完成的功能的摘要。
无限制类型
以前最多可以注册50个自定义类型的限制在6.0中消失了,现在您可以根据需要注册任意多个类型。
单例类型
从6.0开始,您可以使用qmlRegisterSingletonType注册用于QML的自定义单例。
例如,如果您想向QML公开有关操作系统的信息,则可以创建以下类:
class SystemInfo(QObject):
def __init__(self):
QObject.__init__(self)
def getOSName(self):
return platform.system()
def getOSRelease(self):
return platform.release()
osName = Property(str, getOSName)
osRelease = Property(str, getOSRelease)
然后在CustomType1.0 下注册:
qmlRegisterSingletonType(SystemInfo, "CustomType", 1, 0, "SystemInfo")
现在,您SystemInfo只需导入CustomTypeQML代码即可访问:
import CustomType 1.0
Text {
text: "OS Name: " + SystemInfo.osName
}
不可创建的类型
另一个缺少的功能是将自定义QML类型注册为不可创建的选项,这可以通过qmlRegisterUncreatableType来实现。
您可以使用它,例如在QML中注册自定义enum类
class Theme(QObject):
@QEnum
class Variant(Enum):
Default, Dark, HighContrast = range(3)
# ... qmlRegisterUncreatableType(Theme, "CustomType", 1, 0, "Theme", "Theme can't be created")
注册后,您可以这样使用enum:
import QtQuick 2.0
import CustomType 1.0
Item {
property int theme: Theme.Default
}
适应新的类注册方式
Qt for Python现在还支持QmlElement decorator模式,该decorator的工作方式与QML_ELEMENTC ++ 类似。
QML_IMPORT_NAME = "com.library.name"
QML_IMPORT_MAJOR_VERSION = 1
QML_IMPORT_MINOR_VERSION = 0 # Optional
@QmlElement
class ClassForQml(QObject):
# ...
例如,此代码段将公开ClassForQml给QML,并且可以通过全局变量中指定的导入名称和版本来导入。如果您要注册许多类型,这对您可能特别有用。
结论
我们了解到QML + Python交互的其他方面可能是您的应用程序当前需要的,你或者会从中受益。因此,我希望您的一些意见建议,甚至是有关如何实现Qt forPython的创新,对于基于QML的应用程序而言,这是一个非常好重要的部分。
标签:
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,尊重他人劳动成果
文章转载自:Qt
0
好文不易,鼓励一下吧!