标签:qtquick qml property qmlregistertype qt
本文的qml 运行环境为qt4,在qt5中同样支持。
在Qt SDK 提供的文档中提及property支持类型
qml中的property的作用是动态为对象添加属性,并且添加的属性可以进行跟踪(值被修改了就会发出信号)
添加的属性,官方文档只提及了添加基础类型属性的说明
诸如:int, double, bool, string, variant, color, real, vector3d, url, time, rect, size, enumeration, font, date, point, list, action等基础到不能再基础的数据类型
这里提一个qml的元素:QtObject
这个QtObject 元素是直接继承自c++类:QObject,相对于Item占用的内存就小点。一般用来封装一些特定的功能函数。
但这个QtObject元素不能直接内嵌qml的其他元素,甚至连自己都不能内嵌
比如下面的代码会报错:
Cannot assign to non-existent default property QtObject{ ^test.qml:
import QtQuick 1.1 QtObject{ QtObject{ } }
如果我想要在QtObject嵌套一个可用的qml元素,可以像下面这种写法
import QtQuick 1.1 QtObject{ property list<QtObject> __listObject: [ QtObject{ id:a; property int _num: 100 } ] property variant __varObject: QtObject{ id:b; property int _num: 1000 } property QtObject __object: QtObject{ id:c; property int _num: 10000 } Component.onCompleted: { console.debug("a:"+a._num); console.debug("b:"+b._num); console.debug("c:"+c._num); console.debug("__listObject:"+__listObject[0]._num); console.debug("__varObject:"+__varObject._num); console.debug("__object:"+__object._num); } }
Qml debugging is enabled. Only use this in a safe environment!
a:100
b:1000
c:10000
__listObject:100
__varObject:1000
__object:10000
QDeclarativeView only supports loading of root objects that derive from QGraphicsObject
<QDeclarativeView only supports loading of root objects that derive from QGraphicsObject >这句就忽略不看
如果想要在QtObject中内嵌一个或者多个qml元素作为属性,有如下三种写法:
第一种比较常用:
property variant object: QtObject { // some property // some function }直接使用variant 对应的是js中var,很好用的一个东西。
第二使用一个list存储一个或多个qml元素实例
property list<QtObject> // QtObject 可以替换为任何已经注册的或者自定义的元素类型 __listObject: [ QtObject{ id:a; property int _num: 100 } ]第三种就是我今天看一位大神的代码才猛然醒悟的:
property QtObject __object: QtObject{ id:c; property int _num: 10000 }直接说明property是一个QtObject对象的实例。
第三种声明的属性其属性名指向的是一个实例化对象,并非是一个基本数据类型的值。所以对这样的属性进行赋值操作后,再打印其属性值是undefined。
=====================================================================
还有一个,以上三种声明的属性的写法和qml的标准属性名是不一样的,qml的标准属性名写法是开头必须是小写字母开头。而以下划线开头的写法是告诉大家,这个属性是const private,不要随意变动他。
在新的Qt5(QtQuick2)中还有更多的特性,比如支持了在qml中定义枚举
还有上诉的写法Qt 文档没有给出太多实例,只是在文档中说了一些(Qt4)
====================================================================
Any C++ data that is used from QML - whether as custom properties, or parameters for signals or functions -must
be of a type that is recognizable by QML.
By default, QML recognizes the following data types:
bool
unsigned int, int
float, double, qreal
QString
QUrl
QColor
QDate, QTime, QDateTime
QPoint, QPointF
QSize, QSizeF
QRect, QRectF
QVariant
QVariantList, QVariantMap
QObject*
Enumerations declared with Q_ENUMS()
To allow a custom C++ type to be created or used in QML, the C++ class must be registered as a QML type using qmlRegisterType(), as shown in the Defining new QML elements section above.
最后这句话就说明了,只要通过qml的 注册函数 qmlRegisterType() 就能像第三种声明属性的方法那样将一个对象实例声明为属性。
=============================================================================================================
就这么多了~~~~~~~~
标签:qtquick qml property qmlregistertype qt
原文地址:http://blog.csdn.net/qyvlik/article/details/42344451