ArcGISEngine实现栅格数据裁剪

转自:http://www.gisall.com/html/72/124272-8236.html

ArcGIS空间分析扩展模块提供了对栅格数据进行裁剪抽取操作的功能,在ArcGISEngine中可以调用相关的GP工具来对栅格数据操作。

  •  调用空间分析ArcToolbox中Extract By Polygon工具

private void ExtractByPolygon()

        {

            IVariantArray parameters = new VarArrayClass();

            string sDocPath = @"C:\filerastergdb.gdb\raster";      //地图文档路径

            string sDocPath1 = @"C:\filerasteroutput.gdb\outraster";

            parameters.Add(sDocPath);

           

            string ss1 = "'545160.944 4639276.889';'545216.242 4639266.57';'545227.355 4639308.375'";;

            parameters.Add(ss1);

            parameters.Add(sDocPath1);

            parameters.Add("INSIDE");

            IGeoProcessor2 gp = new GeoProcessorClass();

            gp.OverwriteOutput = true;

            IGeoProcessorResult pResult = null;

            try

            {

                pResult = gp.Execute("ExtractByPolygon", parameters, null);

                IWorkspaceFactory pFWSF = new ESRI.ArcGIS.DataSourcesGDB.FileGDBWorkspaceFactoryClass();

                ESRI.ArcGIS.Geodatabase.IWorkspace pWS = pFWSF.OpenFromFile(@"C:\filerasteroutput.gdb", 0) ;

                ESRI.ArcGIS.Geodatabase.IRasterWorkspaceEx pRasterWs = pWS as ESRI.ArcGIS.Geodatabase.IRasterWorkspaceEx;

                IRasterDataset pRasterDataset = pRasterWs.OpenRasterDataset("outraster");

                IRasterLayer pRasterLayer = new RasterLayerClass();

                pRasterLayer.CreateFromDataset(pRasterDataset);

                axMapControl1.AddLayer(pRasterLayer);

                string mess = null;

                for (int k = 0; k < gp.MessageCount; k++)

                {

                    mess += gp.GetMessage(k) + "\n";

                }

                MessageBox.Show(mess);

            }

            catch (Exception err)

            {

                string msg = err.Message;

                string mess = null;

                for (int k = 0; k < gp.MessageCount; k++)

                {

                    mess += gp.GetMessage(k) + "\n";

                }

                MessageBox.Show(mess);

            }

        }

 

  • 调用IExtractionOp接口对栅格数据裁剪

        public void ExtractionRasterData(IGeoDataset pGeoDataset, ESRI.ArcGIS.Geometry.IPolygon pPolygone, bool binside)

        {

            ESRI.ArcGIS.SpatialAnalyst.IExtractionOp pExtractionOp = new ESRI.ArcGIS.SpatialAnalyst.RasterExtractionOpClass();

            ESRI.ArcGIS.Geodatabase.IGeoDataset pGeoOutput = pExtractionOp.Polygon(pGeoDataset, pPolygone, binside);

        }

转载于:https://www.cnblogs.com/LCGIS/archive/2013/05/31/3111040.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值