gis软件设计实验报告_第1页
gis软件设计实验报告_第2页
gis软件设计实验报告_第3页
gis软件设计实验报告_第4页
gis软件设计实验报告_第5页
已阅读5页,还剩36页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、 地理与生物信息学院2014 / 2015 学年 第 一 学期GIS软件设计实 验 报 告 课程名称: GIS软件设计 实验名称: 小型GIS软件系统的设计与开发 班 级 学 号 B12090114 学 生 姓 名 别小文 指 导 教 师 姜杰 日 期: 2014 年 12 月1、 实验目的 基于ArcGIS Engine及C#编程语言构建一个小型GIS平台系统。二、实验内容软件为一个小型的GIS平台,主要包括:空间数据存取模块、地图浏览模块、地图编辑模块、空间查询模块、空间分析模块、地图修饰模块。(1)空间数据存取模块该模块实现对地图数据的新建、加载、保存、另存和打印输出对于地图的硬拷贝输出

2、实现所见即所得效果。(2)地图浏览模块该模块主要包括地图工具、滚动条,状态条、鹰眼图、内容视图等。其中地图工具可以实现放大、缩小、中心放大、中心缩小、全景视图、漫游、要素选择和取消、空间查询等具体功能。(3)地图数据编辑模块该模块能够实现新建图层、添加图层、删除所有图层、开始编辑和结束编辑的操作。编辑可以对图层进行创建新特征、修改任务、移动特征和设置捕捉环境等操作。(4)空间查询模块该模块实现的是属性查询。(5)空间分析模块该模块可以进行缓冲区分析。3、 实验要求使用ArcGIS Engine和C#、VB.net等编程语言完成任务。4、 实验过程1. 空间数据存储模块该模块实现对地图数据的新建

3、、加载、保存、另存和打印输出对于地图的硬拷贝输出实现所见即所得效果。新建项目a. 启动VS2005,选择“文件|新建|项目”,在项目类型中选择Visual C#,再选择Windows应用程序模板,输入名称“3bxwMap”,点击确定。b. 在解决方案管理器中将“Form1.cs”重命名为“3bxwMap.cs”,在设计视图中,选中窗体,将其属性中的“Text”改为“3bxwMap”。添加控件c.选择工具箱中的“菜单和工具栏|MenuStrip”,将其拖入窗体。选择工具箱中的“ArcGIS Windows Forms”节,将“ToolbarControl”控件拖入窗体,并将其属性中的Dock设置

4、为Top。选择工具箱中的“菜单和工具栏|StatusStrip”,将其拖入到窗体。选择工具箱中的“容器|SplitContainer”容器拖入窗体,并将其属性中的Dock设置为Fill。将TabControl控件拖入Panel1,将Alignment属性设置为Bottom,Dock属性设置为Fill。点击TabPages属性右边的按钮,弹出TabPage集合编辑器,将tabPage1的Name设置为tabPageLayer,Text设置为图层,将tabPage2的Name设置为tabPageProperty,Text设置为属性。如下所示。d. 选择“图层”选项卡,拖入TOCControl控件,

5、设置Dock属性为Fill。选择“属性”选项卡,拖入DataGridView控件,设置Dock属性为Fill。拖入TabControl控件到Panel2,设置Dock属性为Fill。并上述类似的方法,将两个选项卡的Name和Text分别设置为:(tabPageMap、地图),(tabPageLayout,制版)。选择“地图”选项卡,拖入MapControl控件,设置Dock属性为Fill。选择“制版”选项卡,拖入PageLayoutControl控件,设置Dock属性为Fill。最后将LicenseControl控件拖入到窗体的任意地方。按F5编译运行。控件绑定e. 分别右击ToolbarCo

6、ntrol、TOCControl控件,将Buddy设置为axMapControl1,如下图所示。添加工具f.右击ToolbarControl,选择“属性|Items”,点击Add,选择Commands选项卡中的Generic,双击Open、SaveAs、Redo、Undo。添加菜单g. 在设计视图中,单击菜单栏,出现“请在此处键入”的提示,单击提示键入菜单名称,如“文件”,再单击“文件”,输入其下拉子菜单:添加新建( New )、打开( Open )、添加数据( AddData )、保存( Save )、另存为( SaveAs )、退出( Exit )这些菜单,()内为相应的 Name 属性值

7、。h.在属性面板中的 Image 属性中设置菜单图标。单击 Image 那一行右边的按钮,弹出如下菜单。选择“项目资源文件”,再单击导入最终效果如下所示。实现相关菜单i. 首先定义指针(写在 public partial class Form1 : Form 下面): private ESRI.ArcGIS.Controls.IMapControl3 m_mapControl = null; private ESRI.ArcGIS.Controls.IPageLayoutControl2 m_pageLayoutControl = null; private IMapDocument pMap

8、Document; 添加以下引用: usinrto; using ESRI.ArcGIS.Controls; using ESRI.ArcGIS.esriSystem; using ESRI.ArcGIS.Display; using ESRI.ArcGIS.Geometry; using ESRI.ArcGIS.SystemUI; 在设计视图中的属性面板中,选择 Form1 ,即主窗体,单击事件按钮,打到“ Load ”事件并双击,添加此事件。在 Form1_Load 函数中初始化这些指针: m_mapControl = (IMapControl3)this.axMapControl1.Ob

9、ject; m_pageLayoutControl = (IPageLayoutControl2)this.axPageLayoutControl1.Object;地图数据的新建功能j.在设计视图下,双击“文件”菜单下的“新建”,添加菜单响应函数。private void New_Click(object sender, EventArgs e) DialogResult res = MessageBox.Show(" 是 否 保 存 当 前 地 图 ?", " 提 示 ", MessageBoxButtons.YesNo,MessageBoxIcon.

10、Question); if (res = DialogResult.Yes) ICommand command = new ControlsSaveAsDocCommandClass(); if (m_mapControl != null) command.OnCreate(m_controlsSynchronizer.MapControl.Object); else command.OnCreate(m_controlsSynchronizer.PageLayoutControl.Object); command.OnClick(); IMap map = new MapClass(); =

11、 "Map" m_controlsSynchronizer.MapControl.Document = string.Empty; m_controlsSynchronizer.ReplaceMap(map); 加载功能k. 双击“文件”菜单下的“添加数据”,添加菜单响应函数。private void AddData_Click(object sender, EventArgs e) int currentLayerCount = this.axMapControl1.LayerCount; ICommand pCommand = new ControlsAddDataCo

12、mmandClass(); pCommand.OnCreate(this.axMapControl1.Object); pCommand.OnClick(); 保存功能l. 双击“文件”菜单下的“保存”,添加菜单响应函数。private void Save_Click(object sender, EventArgs e) / 首先确认当前地图文档是否有效if (null != m_pageLayoutControl.Document m_mapControl.CheckMx LayoutControl.Document) / 创建一个新的地图文档实例IMapDocument mapDoc =

13、 new MapDocumentClass(); / 打开当前地图文档mapDoc.Open(m_pageLayoutControl.Document, string.Empty); / 用 PageLayout 中的文档替换当前文档中的 PageLayout 部分mapDoc.ReplaceContents(IMxdContents)m_pageLayoutControl.PageLayout); / 保存地图文档mapDoc.SavesRelativePaths, false); mapDoc.Close(); 另存为功能m. 双击“文件”菜单下的“另存为”,添加菜单响应函数。privat

14、e void SaveAs_Click(object sender, EventArgs e) / 调用另存为命令ICommand command = new ControlsSaveAsDocCommandClass(); command.OnCreate(m_controlsSynchronizer.ActiveControl); command.OnClick(); MapControl与PageLayoutControl同步n. 新建同步类ControlsSynchronizer 在解决方案面板中右击项目名,选择“添加|类”,在类别中选择“Visual C#项目项”,在模板中选择“类”

15、,输入类名“ControlsSynchronizer.cs”,将以下代码覆盖自动生成的代码: using System; using System.Drawing; using System.Collections; usinponentModel; using System.Windows.Forms; using System.IO; using System.Runtime.InteropServices; using ESRI.ArcGIS.esriSystem; usinrto; using ESRI.ArcGIS.Controls; using ESRI.ArcGIS.System

16、UI; namespace _sdnMap public class ControlsSynchronizer #region class members private IMapControl3 m_mapControl = null; private IPageLayoutControl2 m_pageLayoutControl = null; private ITool m_mapActiveTool = null; private ITool m_pageLayoutActiveTool = null; private bool m_IsMapCtrlactive = true; pr

17、ivate ArrayList m_frameworkControls = null; #endregion #region constructor public ControlsSynchronizer() /初始化ArrayList m_frameworkControls = new ArrayList(); public ControlsSynchronizer(IMapControl3 mapControl, IPageLayoutControl2 pageLayoutControl) : this() /为类成员赋值 m_pageLayoutControl = pageLayoutC

18、ontrol; #endregion #region properties public IMapControl3 MapControl get return m_mapControl; set m_mapControl = value; public IPageLayoutControl2 PageLayoutControl get return m_pageLayoutControl; set m_pageLayoutControl = value; public string ActiveViewType get if (m_IsMapCtrlactive) return "M

19、apControl" else return "PageLayoutControl" public object ActiveControl get if (m_mapControl = null | m_pageLayoutControl = null) throw new Exception("ControlsSynchronizer:ActiveControl:rnEither MapControl or PageLayoutControlare not initialized!"); if (m_IsMapCtrlactive) ret

20、urn m_mapControl.Object; else return m_pageLayoutControl.Object; #endregion #regio public void ActivateMap() try if (m_pageLayoutControl = null | m_mapControl = null) throw new Exception("ControlsSynchronizer:ActivateMap:rnEither MapControl or PageLayoutControl are not initialized!") if (m

21、_pageLayoutControl.CurrentTool != null) m_pageLayoutActiveTool = m_pageLayoutControl.CurrentTool; m_pageLayoutControl.ActiveView.Deactivate(); m_mapControl.ActiveView.Activate(m_mapControl.hWnd); MapControl 的 CurrentTool if (m_mapActiveTool != null) m_mapControl.CurrentTool = m_mapActiveTool; m_IsMa

22、pCtrlactive = true; MapControl this.SetBuddies(m_mapControl.Object); catch (Exception ex) throw new Exception(string.Format("ControlsSynchronizer:ActivateMap:rn0", ex.Message); public void ActivatePageLayout() try if (m_pageLayoutControl = null | m_mapControl = null) Exception("Contro

23、lsSynchronizer:ActivatePageLayout:rnEither MapControlorPageLayoutControl are not initialized!"); if (m_mapControl.CurrentTool != null) m_mapActiveTool = m_mapControl.CurrentTool; m_mapControl.ActiveView.Deactivate(); m_pageLayoutControl.ActiveView.Activate(m_pageLayoutControl.hWnd); if (m_pageL

24、ayoutActiveTool != null) m_pageLayoutControl.CurrentTool = m_pageLayoutActiveTool; m_IsMapCtrlactive = false; this.SetBuddies(m_pageLayoutControl.Object); catch (Exception ex) throw new Exception(string.Format("ControlsSynchronizer:ActivatePageLayout:rn0", ex.Message); public void ReplaceM

25、ap(IMap newMap) if (newMap = null) throw new Exception("ControlsSynchronizer:ReplaceMap:rnNew map for replacement is not initialized!"); if (m_pageLayoutControl = null | m_mapControl = null) throw new Exception("ControlsSynchronizer:ReplaceMap:rnEither MapControl or PageLayoutControl

26、are not initialized!"); IMaps maps = new Maps(); maps.Add(newMap); bool bIsMapActive = m_IsMapCtrlactive; this.ActivatePageLayout(); m_pageLayoutControl.PageLayout.ReplaceMaps(maps); m_mapControl.Map = newMap; m_pageLayoutActiveTool = null; m_mapActiveTool = null; if (bIsMapActive) this.Activat

27、eMap(); m_mapControl.ActiveView.Refresh(); else this.ActivatePageLayout(); m_pageLayoutControl.ActiveView.Refresh(); public void BindControls(IMapControl3 mapControl, IPageLayoutControl2 pageLayoutControl, bool activateMapFirst) if (mapControl = null | pageLayoutControl = null) throw new Exception(&

28、quot;ControlsSynchronizer:BindControls:rnEither MapControl or PageLayoutControl are not initialized!"); m_mapControl = MapControl; m_pageLayoutControl = pageLayoutControl; this.BindControls(activateMapFirst); public void BindControls(bool activateMapFirst) if (m_pageLayoutControl = null | m_map

29、Control = null) throw new Exception("ControlsSynchronizer:BindControls:rnEither MapControl or PageLayoutControl are not initialized!"); IMap newMap = new MapClass(); = "Map" IMaps maps = new Maps(); maps.Add(newMap); m_pageLayoutControl.PageLayout.ReplaceMaps(maps); m_mapControl.

30、Map = newMap; m_pageLayoutActiveTool = null; m_mapActiveTool = null; if (activateMapFirst) this.ActivateMap(); else this.ActivatePageLayout(); public void AddFrameworkControl(object control) if (control = null) throw new Exception("ControlsSynchronizer:AddFrameworkControl:rnAdded control is not

31、 initialized!"); m_frameworkControls.Add(control); public void RemoveFrameworkControl(object control) if (control = null) throw new Exception("ControlsSynchronizer:RemoveFrameworkControl:rnControl to be removed is not initialized!"); m_frameworkControls.Remove(control); public void Re

32、moveFrameworkControlAt(int index) if (m_frameworkControls.Count < index) throw new Exception("ControlsSynchronizer:RemoveFrameworkControlAt:rnIndex is out of range!"); m_frameworkControls.RemoveAt(index); private void SetBuddies(object buddy) try if (buddy = null) throw new Exception(&q

33、uot;ControlsSynchronizer:SetBuddies:rnTarget Buddy Control is not initialized!"); foreach (object obj in m_frameworkControls) if (obj is IToolbarControl) (IToolbarControl)obj).SetBuddyControl(buddy); else if (obj is ITOCControl) (ITOCControl)obj).SetBuddyControl(buddy); catch (Exception ex) thr

34、ow new Exception(string.Format("ControlsSynchronizer:SetBuddies:rn0", ex.Message); #endregion 新建 Maps 类在同步类中,要用到 Maps 类,用于管理地图对象。与新建同步类 ControlsSynchronizer 类似,我们新建一 Maps 类,其所有代码如下所示:using System;using System.Collections;using System.Collections.Generic;using System.Text;using System.Runti

35、me.InteropServices;usinrto;namespace _sdnMap Guid("f27d8789-fbbc-4801-be78-0e3cd8fff9d5") ClassInterface(ClassInterfaceType.None) ProgId("_sdnMap.Maps") public class Maps : IMaps, IDisposable /class member - using internally an ArrayList to manage the Maps collection private Arra

36、yList m_array = null; #region class constructor public Maps() m_array = new ArrayList(); #endregion #region IDisposable Members public void Dispose() if (m_array != null) m_array.Clear(); m_array = null; #endregion #region IMaps Members public void RemoveAt(int Index) if (Index > m_array.Count |

37、Index < 0) throw new Exception("Maps:RemoveAt:rnIndex is out of range!"); m_array.RemoveAt(Index); public void Reset() m_array.Clear(); public int Count get return m_array.Count; public IMap get_Item(int Index) if (Index > m_array.Count | Index < 0) throw new Exception("Maps:

38、get_Item:rnIndex is out of range!"); return m_arrayIndex as IMap; public void Remove(IMap Map) m_array.Remove(Map); public IMap Create() IMap newMap = new MapClass(); m_array.Add(newMap); return newMap; public void Add(IMap Map) if (Map = null) throw new Exception("Maps:Add:rnNew Map is mo

39、t initialized!"); m_array.Add(Map); #endregion 两种视图的同步在 3bxwMap.cs 中添加成员变量,即同步类对象: private ControlsSynchronizer m_controlsSynchronizer = null; 在 Form1_Load 函数中进行初始化工作: controls synchronization calssm_controlsSynchronizer = new ControlsSynchronizer(m_mapControl, m_pageLayoutControl); m_controlsSynchronizer.BindControls(true); m_controlsSynchronizer.AddFrameworkControl(axToolbarControl1.Object); m_controlsSynchronizer.AddFrameworkControl(this.axTOCControl1.Object); OpenNewMapDocument openMapDoc = new OpenNewMapDocument(m_controlsSynchronizer); axToolbarControl1.AddItem(openMa

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论