利用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;
複制