该类包含以下内容:
Q_PROPERTY(QList<double> switch1 READ switch1 WRITE setSwitch1 NOTIFY switch1Changed)
void setSwitch2(QList<double> arg)
{
if (m_switch2 != arg)
{
m_switch2 = arg;
emit switch2Changed(arg);
}
}
以下工作:
setSwitch2(QList<double>::fromVector(QVector<double>::fromStdVector(data->switch2)));
但现在我的数据类型是QVariantList
而不是QList<double>
.
我现在应该如何将QList替换为QVariant?
这不起作用:
setSwitch1(QVariantList::fromVector(QVector<QVariant>::fromStdVector(data->switch1)));
只需使用此构造函数:
QVariant::QVariant(const QList & val)
构造具有列表值 val 的新变型。
即,当将 QList 存储为 QVariant 时,QList 的模板类型必须是适合 QVariant 的类型。没有其他构造函数或转换方法。
你应该写这个:
QVariant variant(
QList<double>::fromVector(QVector<double>::fromStdVector(data->switch2))
);
setSwitchVariant(variant);
如果不需要构造函数:
QList<QUrl> params;
QVariant varParams;
varParams.setValue<QList<QUrl>>( params );
这与作者无关。但也许有人会派上用场。
qRegisterMetaTypeStreamOperators<QList<double>>("Stuff");
QList<double> lst;
// convert
QVariant varLst = QVariant::fromValue(lst);
// back
lst = varLst.value<QList<double>>();
列表有 QVariant 构造函数:QVariant(const QList &list)和 typedef QVariantList。两者都在一个漂亮的模板中切换:
template <class T> static QVariant toVariant(const QList<T> &list)
{
QVariantList variantList;
variantList.reserve(list.size());
for (const auto& v : list)
{
variantList.append(v);
}
return variantList;
}