ArcGIS二次开发基础教程(10):三维分析

ArcGIS二次开发基础教程(10):三维分析

坡度分析

请务必学会使用帮助文档!!!

//DEM数据的坡度分析 将分析结果添加到地图上
//首先获取DEM数据,方法有很多例如从个人地理数据库获取,也可直接获取文件数据,此处采用第二种方法
IWorkspaceFactory workspaceFactory = new ShapefileWorkspaceFactoryClass();
//从文件处打开工作空间
IRasterWorkspace rasterWorkspace = workspaceFactory.OpenFromFile(System.IO.Path.GetDirectoryName(path)) as IRasterWorkspace;
//打开数据集
IRasterDataset rasterDatset = rasterWorkspace.OpenRasterDataset(System.IO.Path.GetFileName(path));
//转换为坡度分析需要的地理数据集
IGeoDataset rasterGeoDataset = rasterDataset as IGeoDataset;
//表面分析接口 请查阅帮助文档
ISurfaceOp surfaceOp = new RasterSurfaceOpClass();
//坡度分析方法
IGeoDataset resultDataset = surfaceOp.Slope(rasterGeoDataset,esriGeoAnalysisSlopeEnum.esriGeoAnalysisSlopeDegrees,Type.Missing);
//将生成的数据集转换为栅格图层加到地图中
IRasterLayer rasterLayer = new RasterLayerClass();
//当栅格数据为单个数据栅格时
rasterLayer.CreateFromRaster(resultDataset as IRaster);
//当栅格数据为栅格数据集时
//rasterLayer.CreateFromDataset((IRasterDataset)reaultDataset);
rasterLayer.Name = "Slope";
axMapControl1.AddLayer(rasterLayer as ILayer);
axMapControl1.Refresh();
axTOCControl1.Update();

通视分析

//通视分析多需要一个要素数据集表示观察点
//首先获取DEM数据,方法有很多例如从个人地理数据库获取,也可直接获取文件数据,此处采用第二种方法
IWorkspaceFactory workspaceFactory = new ShapefileWorkspaceFactoryClass();
//从文件处打开工作空间  path1是DEM数据的路径
IRasterWorkspace rasterWorkspace = workspaceFactory.OpenFromFile(System.IO.Path.GetDirectoryName(path1)) as IRasterWorkspace;
//打开数据集
IRasterDataset rasterDatset = rasterWorkspace.OpenRasterDataset(System.IO.Path.GetFileName(path1));
//转换为坡度分析需要的地理数据集
IGeoDataset rasterGeoDataset = rasterDataset as IGeoDataset;
//获取要素数据集  path2是观察点要素数据集
IFeatrueWorkspace featureWorkspace = workspaceFactory.OpenFromFile(System.IO.Path.GetDirectoryName(path2)) as IFeatureWorkspace;
IFeatrueDataset featureDataset = featureWorkspace.OpenFeatureDataset(System.IO.Path.GetFileName(path2));
IGeoDataset featureGeoDataset = featureDataset as IGeoDataset;
//表面分析接口 请查阅帮助文档
ISurfaceOp surfaceOp = new RasterSurfaceOpClass();
//通视分析方法
IGeoDataset resultDataset = surfaceOp.Visibility(rasterGeoDataset,featureGeoDataset,esriGeoAnalysisVisibilityEnum.esriGeoAnalysisVisibilityFrequency,Type.Missing);
//将生成的数据集转换为栅格图层加到地图中
IRasterLayer rasterLayer = new RasterLayerClass();
rasterLayer.CreateFromRaster(resultDataset as IRaster);
rasterLayer.Name = "Visibility";
axMapControl1.AddLayer(rasterLayer as ILayer);
axMapControl1.Refresh();
axTOCControl1.Update();

历届GIS应用技能大赛开发题答案点这里,尚在不定期更新中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值