qt插件python_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

0

好文不易,鼓励一下吧!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值