C++界面开发框架Qt:Qt for Python 6.0中改进对QML支持
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免费试用吧!更多Qt类开发工具QtitanRibbon、QtitanChart、QtitanNavigation、QtitanDocking、QtitanDataGrid在线订购现直降1000元,欢迎咨询慧都获取更多优惠>>