我有一个代码,可以使用 Qt 5.5 ,而不是 Qt 5.2 。问题在于枚举:
#include <QtCore/QMetaType>
enum Area
{
Area_A,
Area_B,
Area_C
};
Q_DECLARE_METATYPE(Area)
然后我有一个对象,它暴露了这个区域属性:
class MyClass : public QObject
{
Q_OBJECT
Q_PROPERTY(Area area READ area WRITE setArea NOTIFY areaChanged)
public:
explicit MyClass(QObject *parent = 0)
: QObject(parent), m_area(Area_A){}
Area area() const { return m_area; }
void setArea(Area area) {
m_area = area;
emit areaChanged(area);
}
signals:
void areaChanged(Area area);
private:
Area m_area;
};
和main.cpp:
#include <QtGui/QGuiApplication>
#include <QtQml/QQmlApplicationEngine>
#include <QtQml/QQmlContext>
#include <QtQml/QtQml>
#include "MyClass.h"
int main(int argc, char *argv[])
{
QGuiApplication app(argc, argv);
qmlRegisterType<MyClass>("GLib", 1, 0, "MyClass");
MyClass controller;
QQmlApplicationEngine engine;
engine.rootContext()->setContextProperty("controller", &controller);
engine.load("./main.qml");
controller.setArea(Area_B);
return app.exec();
}
它编译,一切都好。但是当我尝试在 qml :
中使用区域属性时import QtQuick 2.0
import QtQuick.Window 2.0
import GLib 1.0
Window {
visible: true
id: root
property int area: controller.area
Text {
id: name
text: "Test"
x: area * 30
y: area * 30
}
}
如果使用Qt 5.2(Linux,x64),我有运行时错误:
QMetaProperty :: read:无法处理未注册的数据类型“Area” 物业'MyClass :: area' file:///home/yech844/devel/test_qml/main.qml:10:24:无法分配 [undefined] to int QMetaProperty :: read:无法处理未注册的 属性'MyClass :: area'的数据类型'Area' file:///home/yech844/devel/test_qml/main.qml:10:24:无法分配 [undefined]到int
这是Qt中的错误吗?为什么我不能使用Enum,它是在Class范围之外声明的?
答案 0 :(得分:4)
Qt 5.5引入了Q_ENUM宏,无需使用Q_DECLARE_METATYPE。在此处阅读更多相关信息:https://woboq.com/blog/q_enum.html
答案 1 :(得分:2)
我不知道为什么代码在Qt 5.5中有效,但我知道为什么它不在Qt 5.2中。
org.h2.tools.Console
仅在静态(已编译)上下文中提供该类型。例如,如果要使用Q_DECLARE_METATYPE(...)
中的类型。在这里,您可以在编译期间处理传递给函数的类型,为此,QVariant::fromValue(...)
就足够了。
但是,如果要在纯运行时上下文中使用类型,例如在QML文档中,Qt运行时不知道使用Q_DECLARE_METATYPE
声明的类型。为此,需要进行函数调用(在运行时评估),Q_DECLARE_METATYPE
是此工具:
qRegisterMetatype
我猜测Qt 5.5不需要该行,qRegisterMetaType<Area>("Area");
可能会检测到属性中元类型的使用,并自动为您调用上述函数。