Q_ENUM
在继承的枚举上使用时,无法按预期的方式工作。
例如,存在从A和A
继承的基本结构B
(旧类)和QObject
。 A
有一个枚举,B
有这个枚举的Q_ENUM
。
b.h
#pragma once
#include <QObject>
#include <QDebug>
struct A
{
A() = default;
virtual ~A() = default;
enum E_FOO{
FOO = 1000,
FOOO,
FOOOO
};
};
class B
: public QObject
, public A
{
Q_OBJECT
Q_ENUMS(E_FOO) // OPTION 1 doesn't work
public:
B() {
qDebug() << "enums from A" << B::FOO << B::FOOO<<B::FOOOO;
qDebug() << "enums from B" << B::BAR << B::BARR << B::BARRR;
}
// Q_ENUM(E_FOO) // OPTION 2 doesn't work
// using E_FOO_FORWARDED = A::E_FOO; // OPTION 3 doesn't work
// Q_ENUM(E_FOO_FORWARDED)
// additional enum (for testing a "normal" case)
enum E_BAR {
BAR = 1111,
BARR,
BARRR
};
Q_ENUM(E_BAR)
};
这是要加载的qml文件,它在创建时仅显示枚举的值。
MainWindow.qml
import QtQuick 2.7
import QtQuick.Layouts 1.0
import QtQuick.Controls 2.3
import mmm 1.0
ApplicationWindow {
Component.onCompleted:{
console.log("checking if values are correct:")
console.log("B.FOO should be = 1000", B.FOO)
console.log("B.BAR should be = 1111", B.BAR)
}
}
这是运行所有文件的主文件:
main.cpp
#include <QGuiApplication>
#include <QtQml/QQmlApplicationEngine>
#include <QtQuick/QQuickWindow>
#include <QObject>
#include <QDebug>
#include "b.h"
int main(int argc, char *argv[])
{
qmlRegisterUncreatableType<B>("mmm",1, 0, "B", "err");
// (check qDebug capabilities that are coded inside the
B b; consturctor)
// checking enum inside qml
QGuiApplication a(argc, argv);
QQmlApplicationEngine eng(QUrl("qrc:/qml/MainWindow.qml"));
QQuickWindow* window = qobject_cast<QQuickWindow*>(eng.rootObjects().first());
window->show();
return a.exec();
}
结果是
enums from A 1000 1001 1002
enums from B B::E_BAR(BAR) B::E_BAR(BARR) B::E_BAR(BARRR)
qml: checking if values are correct:
qml: B.FOO should be = 1000 undefined
qml: B.BAR should be = 1111 1111
所以:
Q_ENUM
的新功能(qDebug中的名称打印)不起作用Q_ENUMS
也不起作用我尝试使用相同的结果来创建别名类型(using E_FOO_FORWARDED = A::E_FOO
)。有解决这个问题的方法吗?
项目的其他文件
inherited_enum.pro
QT += gui core qml quick
TEMPLATE = app
CONFIG += c++14 console qml
SOURCES += main.cpp
RESOURCES += qml.qrc
qml.qrc
<RCC>
<qresource prefix="/qml">
<file>MainWindow.qml</file>
</qresource>
</RCC>
答案 0 :(得分:1)
Q_ENUM
这样的Qt扩展由宏和moc处理,它们仅处理C ++的必需子集。它实际上并不能处理继承,仅适用于当前的类定义。
因此,您必须将Q_ENUMS
放在基础enum
的定义类中。