栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

c++ GDAL读取shapefile文件

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

c++ GDAL读取shapefile文件

#include 
#include 
using namespace std;

int main()
{
	//支持中文路径
	CPLSetConfigOption("GDAL_FILENAME_IS_UTF8", "NO");
	//支持属相表中文字符
	CPLGetConfigOption("SHAPE_ENCODING", "UTF-8");
	const char * shpFile = "Supermarket.shp";
	GDALAllRegister();
	GDALDataset * ds;
	ds = (GDALDataset *)GDALOpenEx(shpFile, GDAL_OF_VECTOR and GDAL_OF_READONLY,NULL,NULL,NULL);
	if (ds == NULL)
	{
		cout << "打开数据失败!" << endl;
		return 0;
	}
	OGRLayer * lyr = ds->GetLayer(0);
	lyr->ResetReading();
	OGRFeatureDefn * lyrDefn = lyr->GetLayerDefn();
	int fieldCount = lyrDefn->GetFieldCount();
	while (true)
	{
		OGRFeature * feature;
		feature = lyr->GetNextFeature();
		if (feature == NULL)
		{
			cout << "数据读取结束" << endl;
			break;
		}
		for (int i = 0;i < fieldCount;i++)
		{
			OGRFieldDefn * fieldDefn=feature->GetFieldDefnRef(i);
			const char * fieldName= fieldDefn->GetNameRef();
			OGRFieldType fieldType = fieldDefn->GetType();
			switch (fieldType)
			{
			case OFTString:
				printf("%s:%sn", fieldName,feature->GetFieldAsString(i));
				break;
			case OFTReal:
				printf("%s:%0.5fn", fieldName, feature->GetFieldAsDouble(i));
				break;
			default:
				break;
			}
		}
		//输出坐标
		OGRPoint * point = (feature->GetGeometryRef())->toPoint();
		cout << point->getX() << endl;
		cout << point->getY() << endl;
	}
	return 0;
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/352984.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号