将枚举 class 添加到元对象 Qt 5.15 的正确方法
Proper way to add enum class to metaObject Qt 5.15
我正在修补 Qt 的元对象系统,我遇到了将 enum class
添加到元对象的问题。我有一个包含一些变量的结构,其中之一是 enum class
.
#ifndef EXAMPLE_H
#define EXAMPLE_H
#include <QObject>
enum class CarType {
NO_CAR = 0,
SLOW_CAR,
FAST_CAR,
HYPER_CAR
};
struct Player {
Q_GADGET
Q_PROPERTY(Player player READ getPlayer)
Q_PROPERTY(float m_speed READ getSpeed)
Q_PROPERTY(CarType m_carType READ getCarType)
Player getPlayer() { return *this;}
float getSpeed() {return m_speed;}
CarType getCarType() { return m_carType;}
public:
CarType m_carType;
float m_speed;
}; Q_DECLARE_METATYPE(Player)
#endif // EXAMPLE_H
我将此结构声明为 Q_META_TYPE
,以便使用元对象系统访问它。这允许我访问结构的属性。这是我的 main.cpp
:
#include <QCoreApplication>
#include <iostream>
#include <QMetaObject>
#include "example.h"
#include <QDebug>
#include <QMetaProperty>
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
qRegisterMetaType<Player>();
const QMetaObject* metaObject = &Player::staticMetaObject;
qInfo()<< "Number of enums is: " << metaObject->enumeratorCount();
return a.exec();
}
我希望 enumeratorCount()
为 1,但我得到的是 0。我已经搜索过这个问题,我能找到的大多数示例都在 class 中包含结构,并且 Q_ENUM
声明紧随其后,像这样:
enum class CarType {
NO_CAR = 0,
SLOW_CAR,
FAST_CAR,
HYPER_CAR
}; Q_ENUM(CarType)
但是,这会导致错误。在元对象系统中注册此枚举的正确方法是什么?
感谢您的宝贵时间。
编辑
我得到的相关错误是:
/home/raphael/SO_Example/example.h:10: error: ‘friend’ used outside of class
/home/raphael/SO_Example/example.h:10: error: ‘staticMetaObject’ was not declared in this scope; did you mean ‘qt_getQtMetaObject’?
如果您不想使用 Q_OBJECT
或 Q_GADGET
将您的枚举添加到 class,那么另一种方法是将您的枚举放入 Q_NAMESPACE
。您实际上不能将 Q_ENUM
与 Q_NAMESPACE
一起使用,但您可以改用 Q_ENUM_NS
。我自己还没有测试过,但它应该可以工作:
namespace MyNamespace
{
Q_NAMESPACE
enum class MyEnum {
Foo,
Bar
};
Q_ENUM_NS(MyEnum)
}
我正在修补 Qt 的元对象系统,我遇到了将 enum class
添加到元对象的问题。我有一个包含一些变量的结构,其中之一是 enum class
.
#ifndef EXAMPLE_H
#define EXAMPLE_H
#include <QObject>
enum class CarType {
NO_CAR = 0,
SLOW_CAR,
FAST_CAR,
HYPER_CAR
};
struct Player {
Q_GADGET
Q_PROPERTY(Player player READ getPlayer)
Q_PROPERTY(float m_speed READ getSpeed)
Q_PROPERTY(CarType m_carType READ getCarType)
Player getPlayer() { return *this;}
float getSpeed() {return m_speed;}
CarType getCarType() { return m_carType;}
public:
CarType m_carType;
float m_speed;
}; Q_DECLARE_METATYPE(Player)
#endif // EXAMPLE_H
我将此结构声明为 Q_META_TYPE
,以便使用元对象系统访问它。这允许我访问结构的属性。这是我的 main.cpp
:
#include <QCoreApplication>
#include <iostream>
#include <QMetaObject>
#include "example.h"
#include <QDebug>
#include <QMetaProperty>
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
qRegisterMetaType<Player>();
const QMetaObject* metaObject = &Player::staticMetaObject;
qInfo()<< "Number of enums is: " << metaObject->enumeratorCount();
return a.exec();
}
我希望 enumeratorCount()
为 1,但我得到的是 0。我已经搜索过这个问题,我能找到的大多数示例都在 class 中包含结构,并且 Q_ENUM
声明紧随其后,像这样:
enum class CarType {
NO_CAR = 0,
SLOW_CAR,
FAST_CAR,
HYPER_CAR
}; Q_ENUM(CarType)
但是,这会导致错误。在元对象系统中注册此枚举的正确方法是什么?
感谢您的宝贵时间。
编辑 我得到的相关错误是:
/home/raphael/SO_Example/example.h:10: error: ‘friend’ used outside of class
/home/raphael/SO_Example/example.h:10: error: ‘staticMetaObject’ was not declared in this scope; did you mean ‘qt_getQtMetaObject’?
如果您不想使用 Q_OBJECT
或 Q_GADGET
将您的枚举添加到 class,那么另一种方法是将您的枚举放入 Q_NAMESPACE
。您实际上不能将 Q_ENUM
与 Q_NAMESPACE
一起使用,但您可以改用 Q_ENUM_NS
。我自己还没有测试过,但它应该可以工作:
namespace MyNamespace
{
Q_NAMESPACE
enum class MyEnum {
Foo,
Bar
};
Q_ENUM_NS(MyEnum)
}