首页 ArCGIS Engine开发

ArCGIS Engine开发

举报
开通vip

ArCGIS Engine开发 ArCGIS Engine开发 缓冲区分析 1 概述 缓冲区分析(Buffer)是对选中的一组或一类地图要素(点、线或面)按设定的距离条件,围绕其要素而形成一定缓冲区多边形实体,从而实现数据在二维空间得以扩展的信息分析方法。缓冲区应用的实例有如:污染源对其周围的污染量随距离而减小,确定污染的区域;为失火建筑找到距其500米范围内所有的消防水管等。 2 缓冲区的基础 缓冲区是地理空间,目标的一种影响范围或服务范围在尺度上的表现。它是一种因变量,由所研究的要素的形态而发生改变。从数学的角度来看,缓冲区是给定空间...

ArCGIS Engine开发
ArCGIS Engine开发 缓冲区分析 1 概述 缓冲区分析(Buffer)是对选中的一组或一类地图要素(点、线或面)按设定的距离条件,围绕其要素而形成一定缓冲区多边形实体,从而实现数据在二维空间得以扩展的信息分析 方法 快递客服问题件处理详细方法山木方法pdf计算方法pdf华与华方法下载八字理论方法下载 。缓冲区应用的实例有如:污染源对其周围的污染量随距离而减小,确定污染的区域;为失火建筑找到距其500米范围内所有的消防水管等。 2 缓冲区的基础 缓冲区是地理空间,目标的一种影响范围或服务范围在尺度上的 关于同志近三年现实表现材料材料类招标技术评分表图表与交易pdf视力表打印pdf用图表说话 pdf 现。它是一种因变量,由所研究的要素的形态而发生改变。从 数学 数学高考答题卡模板高考数学答题卡模板三年级数学混合运算测试卷数学作业设计案例新人教版八年级上数学教学计划 的角度来看,缓冲区是给定空间对象或集合后获得的它们的领域,而邻域的大小由邻域的半径或缓冲区建立条件来决定,因此对于一个给定的对象A,它的缓冲区可以定义为: P={x | d(x , A)<=r} (d一般是指欧式距离,也可以是其它的距离,其中r为邻域半径或缓冲区建立的条件) 缓冲区建立的形态多种多样,这是根据缓冲区建立的条件来确定的,常用的对于点状要素有圆形,也有三角形、矩形和环形等;对于线状要素有双侧对称、双侧不对称或单侧缓冲区;对于面状要素有内侧和外侧缓冲区,虽然这些形体各异,但是可以适合不同的应用要求,建立的原理都是一样的。点状要素,线状要素和面状要素的缓冲区示意图如下。 3 定制工具的使用 1 打开工程GPBufferLayer\CSharp\GpBufferLayer.sln 2 在VS2005内选择重新生成解决 方案 气瓶 现场处置方案 .pdf气瓶 现场处置方案 .doc见习基地管理方案.doc关于群访事件的化解方案建筑工地扬尘治理专项方案下载 3 开发需要添加工具的工程 4 在ToolBarControl上点右键,选择属性 5 选择条目,点击添加 6 在命令类中选择“自定义工具集”,选择“缓冲区分析”,可通过双击或者拖放到工具条上。 7 运行程序 8 使用“选择要素”命令,选择需要建立缓冲区的要素(点或线) 9 点击工具条上的“缓冲区分析按钮”,弹出缓冲区分析对话框 选择要素 选择缓冲区分析按钮 10 选择缓存分析的图层,选择距离及单位,设置输出的图层 11 点击分析按钮,当出现“分析完成”字样时,工作完成 12 这时通过附加新的图层,即可看到结果 4 核心源代码分析 4.1 BufferSelectedLayerCmd.cs 主要完成定制command的相关代码,具体原理可参见《ArcGIS Engine中文开发指南》 4.2 BufferDlg.cs 为缓冲区分析的输入对话框。其中最主要的是“分析”按钮的处理事件。源代码及分析如下: double bufferDistance;  //转换distance为double类型 double.TryParse(txtBufferDistance.Text, out bufferDistance); if (0.0 == bufferDistance) { MessageBox.Show("Bad buffer distance!"); return; } //判断输出路径是否合法 if (!System.IO.Directory.Exists(System.IO.Path.GetDirectoryName(txtOutputPath.Text)) || ".shp" != System.IO.Path.GetExtension(txtOutputPath.Text)) { MessageBox.Show("Bad output filename!"); return; } //判断图层个数 if (m_hookHelper.FocusMap.LayerCount == 0) return; //get the layer from the map IFeatureLayer layer = GetFeatureLayer((string)cboLayers.SelectedItem); if (null == layer) { txtMessages.Text += "Layer " + (string)cboLayers.SelectedItem + "cannot be found!\r\n"; return; } //scroll the textbox to the bottom ScrollToBottom(); txtMessages.Text += "\r\n分析开始,这可能需要几分钟时间,请稍候..\r\n"; txtMessages.Update(); //get an instance of the geoprocessor Geoprocessor gp = new Geoprocessor(); gp.OverwriteOutput = true; //create a new instance of a buffer tool ESRI.ArcGIS.AnalysisTools.Buffer buffer = new ESRI.ArcGIS.AnalysisTools.Buffer(layer, txtOutputPath.Text, Convert.ToString(bufferDistance) + " " + (string)cboUnits.SelectedItem); buffer.dissolve_option = "ALL";//这个要设成ALL,否则相交部分不会融合 //buffer.line_side = "FULL";//默认是"FULL",最好不要改否则出错 //buffer.line_end_type = "ROUND";//默认是"ROUND",最好不要改否则出错 //execute the buffer tool (very easy :-)) IGeoProcessorResult results=null; try { results = (IGeoProcessorResult)gp.Execute(buffer, null); } catch (Exception ex) { txtMessages.Text += "Failed to buffer layer: " + layer.Name + "\r\n"; } if (results.Status != esriJobStatus.esriJobSucceeded) { txtMessages.Text += "Failed to buffer layer: " + layer.Name + "\r\n"; } //scroll the textbox to the bottom ScrollToBottom(); txtMessages.Text += "\r\n分析完成.\r\n"; txtMessages.Text += "-----------------------------------------------------------------------------------------\r\n"; //scroll the textbox to the bottom ScrollToBottom(); 第 7 页 共 7 页
本文档为【ArCGIS Engine开发】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_436027
暂无简介~
格式:doc
大小:249KB
软件:Word
页数:7
分类:互联网
上传时间:2013-06-13
浏览量:31