C#+AE读取Shapefile,raster,gdb,mdb,CAD图,自定义格式坐标数据

using System;
using System.Collections.Generic;
using System.Text;
using ESRI.ArcGIS.Carto;
using ESRI.ArcGIS.DataSourcesGDB;
using ESRI.ArcGIS.Display;
using ESRI.ArcGIS.esriSystem;
using ESRI.ArcGIS.Geodatabase;
using ESRI.ArcGIS.Geometry;
using ESRI.ArcGIS.Controls;
using ESRI.ArcGIS.DataSourcesFile;
using ESRI.ArcGIS.DataSourcesRaster;

namespace PLOS.ClassLibrary
{
public class ReadData
{
public static List<ILayer> ReadShapLayer(List<string> filePathList)
{
List<ILayer> layerList = new List<ILayer>();

if (filePathList.Count == 0) return null;
else
{
foreach (string path in filePathList)
{
IWorkspaceFactory pWorkspaceFactory = new ShapefileWorkspaceFactory();
IWorkspace pWorkspace = pWorkspaceFactory.OpenFromFile(System.IO.Path.GetDirectoryName(path), 0);
IFeatureWorkspace pFeatureWorkspace = pWorkspace as IFeatureWorkspace;

IFeatureClass pFeatureClass=pFeatureWorkspace.OpenFeatureClass(System.
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
读取shapefile中Polygon的原始数据,可以使用GDAL/OGR库中的OGRGeometry类。具体步骤如下: 1. 打开shapefile文件: ```c++ OGRRegisterAll(); OGRDataSource *poDS = OGRSFDriverRegistrar::Open("shapefile.shp", FALSE); if (poDS == NULL) { printf("Open failed.\n"); exit(1); } ``` 2. 获取第一个层: ```c++ OGRLayer *poLayer = poDS->GetLayer(0); if (poLayer == NULL) { printf("GetLayer failed.\n"); exit(1); } ``` 3. 遍历层中的所有要素: ```c++ OGRFeature *poFeature; poLayer->ResetReading(); while ((poFeature = poLayer->GetNextFeature()) != NULL) { OGRGeometry *poGeometry = poFeature->GetGeometryRef(); if (poGeometry != NULL && wkbFlatten(poGeometry->getGeometryType()) == wkbPolygon) { // 处理Polygon原始数据 // ... } OGRFeature::DestroyFeature(poFeature); } ``` 4. 处理Polygon原始数据: ```c++ OGRPolygon *poPolygon = (OGRPolygon *)poGeometry; OGRLinearRing *poExteriorRing = poPolygon->getExteriorRing(); int nExteriorPoints = poExteriorRing->getNumPoints(); OGRPoint *paExteriorPoints = new OGRPoint[nExteriorPoints]; poExteriorRing->getPoints(paExteriorPoints); // 处理外环原始数据 // ... for (int i = 0; i < poPolygon->getNumInteriorRings(); i++) { OGRLinearRing *poInteriorRing = poPolygon->getInteriorRing(i); int nInteriorPoints = poInteriorRing->getNumPoints(); OGRPoint *paInteriorPoints = new OGRPoint[nInteriorPoints]; poInteriorRing->getPoints(paInteriorPoints); // 处理内环原始数据 // ... delete[] paInteriorPoints; } delete[] paExteriorPoints; ``` 以上代码可以读取shapefile中所有的Polygon要素,并将其原始数据提取出来。需要注意的是,OGRGeometry类支持的几何类型很多,如果要处理其他类型的要素,则需要进行相应的判断和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值