QGISポイントレイヤー内の各ポイントの座標情報を取得
10006 ワード
プロジェクトでポイントレイヤーのすべてのポイントの位置を取得する必要があるため、ソースコードを表示することで以下の方法を見つけ、テストした.
aaa
QgsMapCanvas*canvas = dynamic_cast<QgsMapCanvas*>(GlobalUseInst()->load2DMapCanvas());
QList<QgsMapLayer*> layerList = canvas->layers();
int numLayer = layerList.size();
for (size_t i = 0; i < numLayer; i++) {
QgsMapLayer* mapLayer = layerList.at(i);
QgsVectorLayer* vectorLayer = dynamic_cast<QgsVectorLayer*>(mapLayer);
if (vectorLayer->geometryType() == QGis::Point && vectorLayer->name() == QStringLiteral(" ")) {//
const QgsSingleSymbolRendererV2*rendererV2 = dynamic_cast<QgsSingleSymbolRendererV2*>(vectorLayer->rendererV2());
// QgsVectorDataProvider
QgsVectorDataProvider*dataProvider = vectorLayer->dataProvider();
//
QgsFeatureIterator it = dataProvider->getFeatures();
QgsFeature feature;
QgsMultiPoint airPortPoint;
int row = 0;
while (!it.isClosed()) {
//
it.nextFeature(feature);
AirPortItem airPortItem;
QgsGeometry* geo = feature.geometry();
QGis::GeometryType geoType = geo->type();
const QgsFields* fields = feature.fields();
int fieldCount = fields->count();
#if 1
airPortPoint = geo->asMultiPoint();//
#else
geo->asPoint();//
#endif
airPortItem.setAirPortLon(airPortPoint[0].x());
airPortItem.setAirPortLat(airPortPoint[0].y());
QString airPortName = feature.attribute(0).toString();
}
}
}
aaa