[英]Is there a way to use QMetaEnum with Q_ENUMS belonging to non Q_OBJECT or Q_GADGET class?
例如,我有以下课程:
namespace someName
{
class someClass
{
Q_ENUMS(ESomeEnum)
public:
enum ESomeEnum {ENUM_A, ENUM_B, ENUM_C};
// ... some other things ..
}
}
Q_DECLARE_METATYPE(someName::someClass)
有没有办法使用QMetaEnum :: valueToKey或QMetaEnum :: keyToValue?
尝试了这个答案中的方法,但得到以下错误:
error: static assertion failed: QMetaEnum::fromType only works with enums declared as Q_ENUM or Q_FLAG #define Q_STATIC_ASSERT_X(Condition, Message) static_assert(bool(Condition), Message)
我可以使用X-Macros来获得我想要的输出,但是在Qt中学习更多技巧也会很好。
不,没有,因为Q_ENUM
的功能是在moc生成的代码中实现的,而moc忽略了既不是Q_OBJECT
也不是Q_GADGET
。 没有理由不使用Q_GADGET
因为它对对象大小没有影响:不添加虚拟方法也不添加数据字段。
以下说明了这一点:
#include <QtCore>
namespace Ns {
class Class {
Q_GADGET
public:
enum ESomeEnum {ENUM_A, ENUM_B, ENUM_C};
Q_ENUM(ESomeEnum)
};
}
int main() {
auto metaEnum = QMetaEnum::fromType<Ns::Class::ESomeEnum>();
qDebug() << sizeof(Ns::Class) << metaEnum.valueToKey(Ns::Class::ENUM_A);
}
#include "main.moc"
输出:
1 ENUM_A
在这个特定的平台(以及许多其他平台)上,空类的大小为1。
Q_ENUM
就像旧的Q_ENUMS
但有以下差异:
enum
之后。 enum
可以放在宏中。 QMetaEnum::fromType<T>()
。 enum
自动声明为QMetaType
(不再需要在Q_DECLARE_METATYPE
添加它们)。 qDebug
enum
将打印值的名称而不是数字。 QVariant
, toString()
给出值名称。 值名称由QCOMPARE
打印(自Qt 5.6起) 取自关于该主题的WOBOQ博客文章 ,请阅读有关Q_ENUM
与Q_ENUMS
其他信息。
是的,自5.8以来你可以这样做:
namespace MyLibrary
{
Q_NAMESPACE
enum class MYLIBRARYSHARED_EXPORT MyEnumClass
{
...
};
Q_ENUM_NS(MyEnumClass)
...
} // namespace MyLibrary
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.