(1)ISurfaceOp.Contour 根据DEM生成等高线图层:

private void button1_Click(object sender, EventArgs e)
        {
            //得到Raster
            ILayer tLayer=this.axMapControl1.get_Layer(0);
            IRasterLayer tRasterLayer=(IRasterLayer)tLayer;

IFeatureClass tFeatureClass=null;
            IGeoDataset tGeodataset=null;
            //使用接口 参数(Raster,等高线间距,基值)
            ISurfaceOp tSurfaceop = new RasterSurfaceOpClass();
            object obj = 0;
            tGeodataset=tSurfaceop.Contour((IGeoDataset)tRasterLayer.Raster, 10, ref obj);
            //判断是否生成等高线层,如果生成,加载到Map中
            if (tGeodataset != null)
            {
                tFeatureClass = (IFeatureClass)tGeodataset;
                if (tFeatureClass != null)
                {
                    IFeatureLayer tFeatureLayer = new FeatureLayerClass();
                    tFeatureLayer.FeatureClass = tFeatureClass;
                    this.axMapControl1.AddLayer((ILayer)tFeatureLayer);
                    this.axMapControl1.Refresh();
                }
            }
        }

(2) ISurfaceOp.ContourAsPolyline 根据已知点,返回穿过改点的等高线和改点的高程

private void axMapControl1_OnMouseDown(object sender, ESRI.ArcGIS.Controls.IMapControlEvents2_OnMouseDownEvent e)
        {
            //通过鼠标获取点击的点坐标
            IPoint tPoint = new PointClass();
            tPoint.X = e.mapX;
            tPoint.Y = e.mapY;
            //得到Raster
            ILayer tLayer = this.axMapControl1.get_Layer(0);
            IRasterLayer tRasterLayer = (IRasterLayer)tLayer;

ISurfaceOp tSurfaceop = new RasterSurfaceOpClass();

//定义返回的线
            IPolyline tPolygline = new PolylineClass();
            //定义返回的高程点
            double tEve = 0;
            tSurfaceop.ContourAsPolyline((IGeoDataset)tRasterLayer.Raster, tPoint, out tPolygline, out tEve);//tSurfaceop.Contour((IGeoDataset)tRasterLayer.Raster, 10, ref obj);

//把生成的等高线画到Map上
            ILineElement tLineElement = new LineElementClass();
            IElement tElement = (IElement)tLineElement;
            tElement.Geometry = tPolygline;
            this.axMapControl1.ActiveView.GraphicsContainer.AddElement(tElement, 0);
            //刷新Map
            this.axMapControl1.Refresh();
        }

作者: cglnet
本文版权归cglNet和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
 

(3)ISurfaceOp.ContourList 根据一系列高程点生成等高线图层:

private void button1_Click(object sender, EventArgs e)
        {

//得到Raster
            ILayer tLayer = this.axMapControl1.get_Layer(0);
            IRasterLayer tRasterLayer = (IRasterLayer)tLayer;
            //定义高程点数组
            double[] tDouble = new double[] { 100, 120, 150, 200 };

IFeatureClass tFeatureClass = null;
            IGeoDataset tGeodataset = null;
            //使用接口
            ISurfaceOp tSurfaceop = new RasterSurfaceOpClass();
            object obj = tDouble;

tGeodataset = tSurfaceop.ContourList((IGeoDataset)tRasterLayer.Raster, ref obj);
            //判断是否生成等高线层,如果生成,加载到Map中
            if (tGeodataset != null)
            {
                tFeatureClass = (IFeatureClass)tGeodataset;
                if (tFeatureClass != null)
                {
                    IFeatureLayer tFeatureLayer = new FeatureLayerClass();
                    tFeatureLayer.FeatureClass = tFeatureClass;
                    this.axMapControl1.AddLayer((ILayer)tFeatureLayer);
                    this.axMapControl1.Refresh();
                }
            }
        }

(4)ISurfaceOp.ContoursAsPolylines根据一系列点生成多根等高线

//定义点坐标集合
        IPointCollection _PointCollect = new MultipointClass();
        private void axMapControl1_OnMouseDown(object sender, ESRI.ArcGIS.Controls.IMapControlEvents2_OnMouseDownEvent e)
        {
            //通过鼠标获取点击的点坐标集合
            IPoint tPoint = new PointClass();
            tPoint.X = e.mapX;
            tPoint.Y = e.mapY;
            object obj = Type.Missing;
            _PointCollect.AddPoint(tPoint, ref obj, ref obj);
        }

private void button1_Click(object sender, EventArgs e)
        {
            //得到Raster
            ILayer tLayer = this.axMapControl1.get_Layer(0);
            IRasterLayer tRasterLayer = (IRasterLayer)tLayer;
            
            ISurfaceOp tSurfaceop = new RasterSurfaceOpClass();
            //定义返回的线集合
            IGeometryCollection tGeometryCollection;
            //定义返回的高程点集合
            IPointCollection tEveColl;
            tSurfaceop.ContoursAsPolylines((IGeoDataset)tRasterLayer.Raster, _PointCollect, out tGeometryCollection, out tEveColl);//tSurfaceop.Contour((IGeoDataset)tRasterLayer.Raster, 10, ref obj);
            if (tGeometryCollection!=null && tGeometryCollection.GeometryCount > 0)
            {
                //把生成的等高线画到Map上
                for (int i = 0; i < tGeometryCollection.GeometryCount; i++)
                {
                    IGeometry tGeometry = tGeometryCollection.get_Geometry(i);
                    ILineElement tLineElement = new LineElementClass();
                    IElement tElement = (IElement)tLineElement;
                    tElement.Geometry = tGeometry;
                    this.axMapControl1.ActiveView.GraphicsContainer.AddElement(tElement, 0);
                }
            }
            //刷新Map
            this.axMapControl1.Refresh();
        }

作者: cglnet
本文版权归cglNet和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
 
from:http://www.cnblogs.com/cglNet/archive/2011/03/03/1970061.html
http://www.cnblogs.com/cglNet/archive/2011/03/03/1970100.html

ISurfaceOp 接口生成等高线的更多相关文章

  1. arcgis中DEM如何生成等高线

    地形图指比例尺大于1∶100万的着重表示地形的普通地图(根据经纬度进行分幅,常用有1:100万,1:50万,1比25万,1:15万,1:10万,1:5万等等).由于制图的区域范围比较小,因此能比较精确 ...

  2. Delphi 提示在Delphi的IDE中,按Ctrl+Shift+G键可以为一个接口生成一个新的GUID。

    对于Object Pascal语言来说,最近一段时间最有意义的改进就是从Delphi3开始支持接口(interface),接口定义了能够与一个对象进行交互操作的一组过程和函数.对一个接口进行定义包含两 ...

  3. Java WebService接口生成和调用 图文详解>【转】【待调整】

    webservice简介: Web Service技术, 能使得运行在不同机器上的不同应用无须借助附加的.专门的第三方软件或硬件, 就可相互交换数据或集成.依据Web Service规范实施的应用之间 ...

  4. Mybatis MapperScannerConfigurer 自动扫描 将Mapper接口生成代理注入到Spring

    Mybatis MapperScannerConfigurer 自动扫描 将Mapper接口生成代理注入到Spring 非原创[只为记录],原博文地址:https://www.cnblogs.com/ ...

  5. (转)Mybatis MapperScannerConfigurer 自动扫描 将Mapper接口生成代理注入到Spring

    Mybatis MapperScannerConfigurer 自动扫描 将Mapper接口生成代理注入到Spring Mybatis在与Spring集成的时候可以配置MapperFactoryBea ...

  6. mybatis如何根据mapper接口生成其实现类

    SpringBoot集成mybatis mybatis的statement的解析与加载 mybatis如何根据mapper接口生成其实现类 mybatis的mapper返回map结果集 mybatis ...

  7. 如何自动在Eclipse里对指定类或接口生成要覆盖的方法?

    我们经常遇到对对指定类或接口生成要覆盖的方法,但是我们不了解这些类和接口,完全手写不能保证完全正确,那么是否可以准确知道指定类或接口要被覆盖的方法,自动生成这些代码呢?是的,完全可以,按照下面步骤操作 ...

  8. Mybaits 源码解析 (十一)----- 设计模式精妙使用:静态代理和动态代理结合使用:@MapperScan将Mapper接口生成代理注入到Spring

    上一篇文章我们讲了SqlSessionFactoryBean,通过这个FactoryBean创建SqlSessionFactory并注册进Spring容器,这篇文章我们就讲剩下的部分,通过Mapper ...

  9. Mybatis MapperScannerConfigurer 自动扫描 将Mapper接口生成代理注入到Spring - 大新博客 - 推酷 - 360安全浏览器 7.1

    Mybatis MapperScannerConfigurer 自动扫描 将Mapper接口生成代理注入到Spring - 大新博客 时间 2014-02-11 21:08:00  博客园-所有随笔区 ...

随机推荐

  1. z-index、display、selector选择器优先级css优先级面试用到

    z-index:控制元素叠放顺序,哪个z-index数值越大,那个优先被叠放在上面. relative.absolute.fixed这三种情况可以使用z-index. static不可以使用. dis ...

  2. HTTP 304

    304 的标准解释是:Not Modified 客户端有缓冲的文档并发出了一个条件性的请求(一般是提供If-Modified-Since头表示客户只想比指定日期更新的文档).服务器告诉客户,原来缓冲的 ...

  3. NPOI 操作Excel

    关于NPOI NPOI是POI项目的.NET版本,是由@Tony Qu(http://tonyqus.cnblogs.com/)等大侠基于POI开发的,可以从http://npoi.codeplex. ...

  4. Jmeter—6 CSV Data Set Config 通过文件导入数据

    线程组循环次数大于1的时候,请求里每次提交的数据都相同.有的系统限制了不能提交相同数据,我们通过 CSV Data Set Config 加载csv文件数据. 1 创建一个文本文件,输入参数值保存为. ...

  5. 《C++primer》v5 第1章 开始 读书笔记 习题答案

    从今天开始在博客里写C++primer的文字.主要以后面的习题作业为主,会有必要的知识点补充. 本人也是菜鸟,可能有不对之处,还望指出. 前期内容可能会比较水. 1.1略 1.2略 1.3 cin和c ...

  6. wireshark使用方法(学习笔记一)

    wireshark是非常流行的网络封包分析软件,功能十分强大.可以截取各种网络封包,显示网络封包的详细信息.使用wireshark的人必须了解网络协议,否则就看不懂wireshark了. 为了安全考虑 ...

  7. js限制文本框只能输入整数或者带小数点[转]

    这篇文章是关于js限制文本框只能输入整数或者带小数点的内容,以下就是该内容的详细介绍. 做表单验证的时候是否会碰到验证某个输入框内只能填写数字呢,仅允许输入整数数字或者带小数点的数字.下面这段代码也许 ...

  8. 一些常用的vim设置

    以下内容皆来源于网络,感谢原作者.如果引用出处错误,请告知以便修改. 1. vim的几种模式和按键映射 转载自:[1] Map是Vim强大的一个重要原因,可以自定义各种快捷键,用起来自然得心应手.vi ...

  9. linux命令:locate

    1.命令介绍: locate用来查找文件,它是在系统的数据库中查找,所以速度非常快. 2.命令格式: locate [选项] 模式         ---这里的模式是指正则表达式 3.命令参数: -e ...

  10. GIT 如何删除某个本地的提交

    一.rm后要commit一下才会生效,但这样只是让文件不再出现在今后的版本中,文件副本仍然会在.git/下(这样git才能让误删的文件恢复). 要彻底消灭文件副本,那就要让文件彻底从历史中消失,分两种 ...