ArcGIS Engine+C#缓冲区分析文档及完整源码

ArcGIS Engine+C#缓冲区分析文档及完整源码

ID:39346957

大小:277.51 KB

页数:7页

时间:2019-07-01

ArcGIS Engine+C#缓冲区分析文档及完整源码_第1页
ArcGIS Engine+C#缓冲区分析文档及完整源码_第2页
ArcGIS Engine+C#缓冲区分析文档及完整源码_第3页
ArcGIS Engine+C#缓冲区分析文档及完整源码_第4页
ArcGIS Engine+C#缓冲区分析文档及完整源码_第5页
资源描述:

《ArcGIS Engine+C#缓冲区分析文档及完整源码》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

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

2、领域,而邻域的大小由邻域的半径或缓冲区建立条件来决定,因此对于一个给定的对象A,它的缓冲区可以定义为:P={x

3、d(x,A)<=r}(d一般是指欧式距离,也可以是其它的距离,其中r为邻域半径或缓冲区建立的条件)缓冲区建立的形态多种多样,这是根据缓冲区建立的条件来确定的,常用的对于点状要素有圆形,也有三角形、矩形和环形等;对于线状要素有双侧对称、双侧不对称或单侧缓冲区;对于面状要素有内侧和外侧缓冲区,虽然这些形体各异,但是可以适合不同的应用要求,建立的原理都是一样的。点状要素,线状要素和面状要素的缓冲区示意图如下。3定制工具的使用1打开工程GPBufferLayerCSha

4、rpGpBufferLayer.sln2在VS2005内选择重新生成解决方案3开发需要添加工具的工程4在ToolBarControl上点右键,选择属性5选择条目,点击添加6在命令类中选择“自定义工具集”,选择“缓冲区分析”,可通过双击或者拖放到工具条上。7运行程序8使用“选择要素”命令,选择需要建立缓冲区的要素(点或线)9点击工具条上的“缓冲区分析按钮”,弹出缓冲区分析对话框选择要素选择缓冲区分析按钮10选择缓存分析的图层,选择距离及单位,设置输出的图层11点击分析按钮,当出现“分析完成”字样时,工作完成12这时通过附加新的图层,即可看到结果4核心源代码分析4.1Buff

5、erSelectedLayerCmd.cs主要完成定制command的相关代码,具体原理可参见《ArcGISEngine中文开发指南》4.2BufferDlg.cs为缓冲区分析的输入对话框。其中最主要的是“分析”按钮的处理事件。源代码及分析如下:doublebufferDistance; //转换distance为double类型double.TryParse(txtBufferDistance.Text,outbufferDistance);if(0.0==bufferDistance){MessageBox.Show("Badbufferdistance!");retu

6、rn;}//判断输出路径是否合法if(!System.IO.Directory.Exists(System.IO.Path.GetDirectoryName(txtOutputPath.Text))

7、

8、".shp"!=System.IO.Path.GetExtension(txtOutputPath.Text)){MessageBox.Show("Badoutputfilename!");return;}//判断图层个数if(m_hookHelper.FocusMap.LayerCount==0)return;//getthelayerfromthemapIFeatureL

9、ayerlayer=GetFeatureLayer((string)cboLayers.SelectedItem);if(null==layer){txtMessages.Text+="Layer"+(string)cboLayers.SelectedItem+"cannotbefound!r";return;}//scrollthetextboxtothebottomScrollToBottom();txtMessages.Text+="r分析开始,这可能需要几分钟时间,请稍候..r";txtMessages.Update();//getaninstan

10、ceofthegeoprocessorGeoprocessorgp=newGeoprocessor();gp.OverwriteOutput=true;//createanewinstanceofabuffertoolESRI.ArcGIS.AnalysisTools.Bufferbuffer=newESRI.ArcGIS.AnalysisTools.Buffer(layer,txtOutputPath.Text,Convert.ToString(bufferDistance)+""+(string)cboUnit

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。