来自 C++ 模型的 QML MapPolygon
QML MapPolygon from C++ model
我想在 QML 地图应用程序中动态 add/remove/edit MapPolygon
。我还有其他一些创建多边形的工作(文件 export/import 等)所以我认为我应该使用 MapItemView
和 C++ 模型 sotirng 多边形数据。
我尝试用我自己的基于 QObject 的对象创建我自己的模型:
对象:
class MODELSHARED_EXPORT Polygon : public QObject
{
Q_OBJECT
Q_PROPERTY(QList<QGeoCoordinate> coordinates READ coordinates WRITE setCoordinates NOTIFY coordinatesChanged)
public:
explicit Polygon(QObject *parent = nullptr);
QList<QGeoCoordinate> coordinates() const;
void setCoordinates(QList<QGeoCoordinate> coordinates);
signals:
void coordinatesChanged(QList<QGeoCoordinate> coordinates);
public slots:
void addCoordinate(const QGeoCoordinate & coordinate);
private:
QList<QGeoCoordinate> m_coordinates;
};
型号:
class MODELSHARED_EXPORT PolygonModel : public QAbstractListModel
{
...
QVariant data(const QModelIndex &index, int role) const override
{
if(index.row() >= 0 && index.row() < rowCount()) {
switch (role) {
case CoordinatesRole:
return QVariant::fromValue(m_data.at(index.row())->coordinates());
}
}
return QVariant();
}
public slots:
void addArea()
{
beginInsertRows(QModelIndex(), rowCount(), rowCount());
m_data.append(new Polygon(this));
endInsertRows();
}
void addPolygonCoordinate(const QGeoCoordinate &coordinate, int index)
{
if(index == -1) {
index = rowCount() - 1;
}
m_data.at(index)->addCoordinate(coordinate);
dataChanged(this->index(0), this->index(rowCount() - 1));
qDebug() << "Adding coordinate..." << coordinate;
}
private:
QList<Polygon*> m_data;
};
和 QML:
MapItemView {
id: AreaView
delegate: AreaPolygon {
path: coordinates
}
model: cppPolygonModel
}
AreaPolygon.qml
MapPolygon {
id: areaPolygon
border.width: 1
border.color: "red"
color: Qt.rgba(255, 0, 0, 0.1)
}
但不幸的是地图上没有出现多边形(当坐标成功添加到对象 QList 时 属性)。我认为 Object QList addidion 在 View 中不可见,因此 MapItemView 没有刷新。
有没有更好的选择?也许我应该使用 QGeoPolygon
个对象的模型? (如何?)
你必须 return QVariantList
而不是 QList<QGeoCoordinate>
:
if(index.row() >= 0 && index.row() < rowCount()) {
switch (role) {
case CoordinatesRole:
QVariantList coorvariant;
for(const QGeoCoordinate & coord: m_data.at(index.row())->coordinates()){
coorvariant.append(QVariant::fromValue(coord));
}
return coorvariant;
}
}
我想在 QML 地图应用程序中动态 add/remove/edit MapPolygon
。我还有其他一些创建多边形的工作(文件 export/import 等)所以我认为我应该使用 MapItemView
和 C++ 模型 sotirng 多边形数据。
我尝试用我自己的基于 QObject 的对象创建我自己的模型:
对象:
class MODELSHARED_EXPORT Polygon : public QObject
{
Q_OBJECT
Q_PROPERTY(QList<QGeoCoordinate> coordinates READ coordinates WRITE setCoordinates NOTIFY coordinatesChanged)
public:
explicit Polygon(QObject *parent = nullptr);
QList<QGeoCoordinate> coordinates() const;
void setCoordinates(QList<QGeoCoordinate> coordinates);
signals:
void coordinatesChanged(QList<QGeoCoordinate> coordinates);
public slots:
void addCoordinate(const QGeoCoordinate & coordinate);
private:
QList<QGeoCoordinate> m_coordinates;
};
型号:
class MODELSHARED_EXPORT PolygonModel : public QAbstractListModel
{
...
QVariant data(const QModelIndex &index, int role) const override
{
if(index.row() >= 0 && index.row() < rowCount()) {
switch (role) {
case CoordinatesRole:
return QVariant::fromValue(m_data.at(index.row())->coordinates());
}
}
return QVariant();
}
public slots:
void addArea()
{
beginInsertRows(QModelIndex(), rowCount(), rowCount());
m_data.append(new Polygon(this));
endInsertRows();
}
void addPolygonCoordinate(const QGeoCoordinate &coordinate, int index)
{
if(index == -1) {
index = rowCount() - 1;
}
m_data.at(index)->addCoordinate(coordinate);
dataChanged(this->index(0), this->index(rowCount() - 1));
qDebug() << "Adding coordinate..." << coordinate;
}
private:
QList<Polygon*> m_data;
};
和 QML:
MapItemView {
id: AreaView
delegate: AreaPolygon {
path: coordinates
}
model: cppPolygonModel
}
AreaPolygon.qml
MapPolygon {
id: areaPolygon
border.width: 1
border.color: "red"
color: Qt.rgba(255, 0, 0, 0.1)
}
但不幸的是地图上没有出现多边形(当坐标成功添加到对象 QList 时 属性)。我认为 Object QList addidion 在 View 中不可见,因此 MapItemView 没有刷新。
有没有更好的选择?也许我应该使用 QGeoPolygon
个对象的模型? (如何?)
你必须 return QVariantList
而不是 QList<QGeoCoordinate>
:
if(index.row() >= 0 && index.row() < rowCount()) {
switch (role) {
case CoordinatesRole:
QVariantList coorvariant;
for(const QGeoCoordinate & coord: m_data.at(index.row())->coordinates()){
coorvariant.append(QVariant::fromValue(coord));
}
return coorvariant;
}
}