C++界面开发框架Qt:Qt for Python 6.0中进一步完善QML + Python的交互

Qt6为Python与QML的交互带来了重大改进,包括移除自定义类型注册限制、支持QML单例类型注册和不可创建类型注册。这些更新使得在QML中使用Python类更加灵活,如注册系统信息单例类和自定义枚举类型。此外,QtforPython现在也支持QmlElement装饰器模式,简化了类的注册过程。开发者可以期待更完善的QML和Python集成,以提升基于QML应用的开发体验。
摘要由CSDN通过智能技术生成

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的应用程序而言,这是一个非常好重要的部分。

如果这篇文章没能满足你的需求、点击获取更多文章教程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值