GDAL读取Shapefile


--------------------------------------------------------------------------------------

#include <gdal_priv.h>
#include <ogrsf_frmts.h>

GDALAllRegister();
OGRDataSource* poDS;
const char* pszDriverName = "ESRI Shapefile";
//
GDALDriverManager* pDriverManager = GetGDALDriverManager(); //new GDALDriverManager();
GDALDriver* pDriver = pDriverManager->GetDriverByName(pszDriverName);
if (pDriver == nullptr)
{
  qDebug() << pszDriverName << " driver not available.";            
  return;
}
//
const char* filePathChar1 = "D:\\data";
OGRSFDriver* pSFDriver = static_cast<OGRSFDriver*>(pDriver);
OGRDataSource* pDataSource = pSFDriver->Open(filePathChar, FALSE);

/*
OGRSFDriverRegistrar* pDriverRegistrar = OGRSFDriverRegistrar::GetRegistrar();
OGRSFDriver* pSFDriver = (OGRSFDriver*)pDriverRegistrar->GetDriverByName(pszDriverName);
OGRDataSource* pDataSource = pSFDriver->Open(filePathChar, FALSE);
*/

------------------------------------------------------------------------------------------------


OGRLayer* pLayer = pDataSource->GetLayerByName(baseNameChar);
/*const char* geometryColumnName = pLayer->GetGeometryColumn();
int fieldIndex = pLayer->FindFieldIndex(geometryColumnName, TRUE);*/
// pEnvelopeDisplay
if (pLayerList.size() == 0) {
  OGREnvelope* pEnvelope = new OGREnvelope();
  pLayer->GetExtent(pEnvelope, TRUE);
  double centerX = (pEnvelope->MinX + pEnvelope->MaxX) / 2;
  double centerY = (pEnvelope->MinY + pEnvelope->MaxY) / 2;
  double distanceX = pEnvelope->MaxX - pEnvelope->MinX;
  double distanceY = pEnvelope->MaxY - pEnvelope->MinY;
  //
}


--------------------------------------------------------------------------------------------------

转载于:https://www.cnblogs.com/gispathfinder/p/10890185.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值