利用Qt元对象特性来对枚举与字符串转换和遍历。
1. QMetaEnum类
- QMetaEnum类提供有关枚举器的元数据。
- 返回与模板参数中的类型相对应的QMetaEnum。
QMetaEnum QMetaEnum::fromType()
复制
注意: 枚举需要用Q_ENUM声明(如下例)。
class Object : public QObject
{
Q_OBJECT
public:
Object();
enum WeekDay {
Monday = 1,
Tuesday,
Wednesday,
Thursday,
Friday,
Saturday,
Sunday
};
Q_ENUM(WeekDay)
};
复制
2. 枚举转字符串
-
方法一:
通过枚举下标获取对应字符串。
const char *key(int index) const
复制
-
方法二:
通过枚举的值获取对应的字符串。
const char *valueToKey(int value) const
复制
- 例:
QMetaEnum metaEnum = QMetaEnum::fromType<Object::WeekDay>();
const char *weekDayStr = metaEnum.valueToKey(Object::Sunday);
qDebug() << weekDayStr;
复制
3. 字符串转枚举
- 可以通过
的值来判断是否正确转换。ok
int keyToValue(const char *key, bool *ok = nullptr) const
复制
- 例:
QMetaEnum metaEnum = QMetaEnum::fromType<Object::WeekDay>();
bool isOk = false;
Object::WeekDay weekDay = (Object::WeekDay)metaEnum.keyToValue("Sunday",
&isOk);
if (isOk) {
qDebug() << weekDay;
}
复制
4. 遍历
QStringList list;
QMetaEnum metaEnum = QMetaEnum::fromType<Object::WeekDay>();
for (int i = 0; i < metaEnum.keyCount(); i++) {
list += metaEnum.valueToKey(metaEnum.value(i));
// Or list += metaEnum.key(i);
}
qDebug() << list;
复制