在文档中明确指出,具有列表的C ++类必须从QObject继承,但是如果列表中的对象必须是QObject,则不清楚。 我尝试使用QQmlListProperty和QQmlListProperty进行this方法,但在这两种情况下我都遇到以下错误:
QMetaProperty :: read:无法处理未注册的数据类型&#39; QQmlListProperty <QString>
&#39;对于属性&ns; ns :: Status :: values&#39;
编辑:我的代码:
.HPP:
namespace ns{
class Status : public QObject
{
Q_OBJECT
Q_PROPERTY(QQmlListProperty<QString> values READ values NOTIFY valuesChanged)
public:
Status(QObject* parent = Q_NULLPTR);
virtual ~Status();
bool updateValues(const std::vector<std::string>& values);
QQmlListProperty<QString> values();
int valueCount() const;
QString* value(int) const;
signals:
void valuesChanged();
private:
QVector<QString*> m_values_;
std::vector<QString> m_valueStorage_;
static int valueCount(QQmlListProperty<QString>*);
static QString* value(QQmlListProperty<QString>*, int);
};
}
的.cpp:
using namespace ns;
Status::Status(QObject* parent) :
QObject(parent),
m_values_(2),
m_valueStorage_(2)
{}
Status::~Status(){}
bool Status::updateValues(const std::vector<std::string>& values)
{
//Do Stuff
emit valuesChanged();
return true;
}
QQmlListProperty<QString> Status::values()
{
return QQmlListProperty<QString>(this, nullptr, &Status::valueCount, &Status::value);
}
int Status::valueCount() const
{
return m_values_.count();
}
QString* Status::value(int index) const
{
return m_values_.at(index);
}
int Status::valueCount(QQmlListProperty<QString>* list){
return reinterpret_cast<Status*>(list->data)->valueCount();
}
QString* Status::value(QQmlListProperty<QString>* list, int i){
return reinterpret_cast<Status*>(list->data)->value(i);
}
QML:
import Foo 1.0
Rectangle {
Status {
id: status
objectName: "Status"
}
Component {
id: value
Rectangle { Text: {text: modelData } }
}
ColumnLayout {
Repeater { model: status.values; delegate: value }
}
}
此外,在我的 main 中,在我将qml文件加载到QQmlApplicationEngine之前:
qmlRegisterType<ns::Status>("Foo", 1,0, "Status");
答案 0 :(得分:6)
QQmlListProperty
确实意味着与QObject
一起使用。
虽然类中没有任何内容强制执行此限制,因为它全部是模板化的,但QML引擎期望元素类型是QObject的子类。
Qt文档中的一个指示可以在QQmlListReference
(从c ++中操作QQmlListProperty
的类)的文档中找到。
本段提到QObject
:
QML列表属性是类型安全的。只有从正确的基类派生的QObject才能分配给列表。 listElementType()方法可用于查询支持的QObject类型的QMetaObject。尝试将不正确类型的对象添加到列表属性将失败。
QObject *QQmlListReference::at(int index) const
方法也是另一条线索。