在基类

时间:2018-07-24 08:30:44

标签: c++ qt enums qml

Q_ENUM在继承的枚举上使用时,无法按预期的方式工作。

例如,存在从A和A继承的基本结构B(旧类)和QObjectA有一个枚举,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也不起作用
  • qml中的值未定义
  • 正常枚举(不是来自基类)正在按预期方式运行

我尝试使用相同的结果来创建别名类型(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>

1 个答案:

答案 0 :(得分:1)

Q_ENUM这样的

Qt扩展由宏和moc处理,它们仅处理C ++的必需子集。它实际上并不能处理继承,仅适用于当前的类定义。

因此,您必须将Q_ENUMS放在基础enum的定义类中。