2

我正在向 Qt 元对象系统注册枚举。我已经仔细检查了所有这些都具有元类型 ID,并且一切看起来都很完美。但是我对这些比较有一些未解决的问题。

让我们考虑这个用于填充组合框的代码:

WgtEnumItemEditor::WgtEnumItemEditor (QVariant::Type t, QWidget *p) : QComboBox(p) {
    QMetaObject const &mo = staticMetaObject;
    QString mtName = QMetaType::typeName(t);
    mtName = mtName.mid( mtName.lastIndexOf(':')+1 );
    qint32 const iEnum = mo.indexOfEnumerator( mtName.toLatin1() );
    QMetaEnum const &en = mo.enumerator( iEnum );
    quint32 const cEnum = en.keyCount();

    for (quint32 i=0; i<cEnum; i++){
        const char *key = en.key(i);
        uint const val = en.value(i);
        QVariant const var ( t, &val );
        addItem( classNameToNaturalString(key), var );
        qDebug() << var;
    }
}

效果很好,我的列表中填充了我的枚举的人类可读文本。

现在,我正在尝试使用包含枚举值的 QVariant 设置列表显示的初始值:

void WgtEnumItemEditor::setValue (const QVariant &v) {
    for (quint32 i=0; i<count(); i++) {
        if (itemData(i)==v.data) {
            setCurrentIndex(i);
            break;
        }
    }
}

这段代码不起作用。我必须通过以下方式替换测试:

*(uint*)itemData(i).data()==*(uint*)v.data()

这样就可以了。

谁能解释我如何在 QVariants 中比较我的自定义枚举?还是在创建用作列表的用户数据的 QVariant 时我做错了什么?

此外,如果我尝试 qDebug() 在循环中创建的 QVariants 以填充列表,我会得到空值输出。例如,在第一段代码中生成的输出如下所示:

QVariant(ReadingDirection, ) 
QVariant(ReadingDirection, )
QVariant(ReadingDirection, )
QVariant(ReadingDirection, )
QVariant(ReadingDirection, )
QVariant(BarcodeStandard, )
QVariant(BarcodeStandard, )
QVariant(BarcodeStandard, )

如您所见,该值未正确输出...您能帮我找出原因吗?

谢谢你,皮埃尔。

4

1 回答 1

0

我不确定这是否能解决您的问题,但要将自定义类型用作 QVariant,您需要使用 Q_DECLARE_METATYPE Makro。见这里:http ://doc.qt.digia.com/qt/qmetatype.html#Q_DECLARE_METATYPE

于 2012-10-23T15:02:36.950 回答