gis
gis
管理员
管理员
  • 注册日期2003-07-16
  • 发帖数15951
  • QQ
  • 铜币25345枚
  • 威望15368点
  • 贡献值0点
  • 银元0个
  • GIS帝国居民
  • 帝国沙发管家
  • GIS帝国明星
  • GIS帝国铁杆
阅读:870回复:0

MapX 控件在C# 中的应用

楼主#
更多 发布于:2004-09-30 12:53
<P ><b><FONT size=3>关键字:MapX,C#,Net,ActiveX控件<p></p></FONT></b></P>
<P ><b><FONT size=3> <p></p></FONT></b></P>
<P  align=left>/*<p></p></P>
<P  align=left> * 在这段代码中,我们应用MapX控件结合老美地图做了最基本的<p></p></P>
<P  align=left> * 地图浏览功能:放大、缩小、拖动、全图、测量距离、测量面积。<p></p></P>
<P  align=left> * <p></p></P>
<P  align=left> * 杨雨田 YangYutian@Hotmail.Com<p></p></P>
<P > */</P>
<P  align=left>using System;<p></p></P>
<P  align=left>using System.Drawing;<p></p></P>
<P  align=left>using System.Collections;<p></p></P>
<P  align=left>using System.ComponentModel;<p></p></P>
<P  align=left>using System.Windows.Forms;<p></p></P>
<P  align=left>using System.Data;<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>namespace wa<p></p></P>
<P  align=left>{<p></p></P>
<P  align=left>    public class frmMain : System.Windows.Forms.Form<p></p></P>
<P  align=left>    {<p></p></P>
<P  align=left>        private AxMapXLib.AxMap mapMain;<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        private double MapZoom;<p></p></P>
<P  align=left>        private double CenterX;<p></p></P>
<P  align=left>        private double CenterY;<p></p></P>
<P  align=left>        private System.Windows.Forms.StatusBar sbMain;<p></p></P>
<P  align=left>        private System.Windows.Forms.MainMenu mainMenu;<p></p></P>
<P  align=left>        private System.Windows.Forms.MenuItem miMap;<p></p></P>
<P  align=left>        private System.Windows.Forms.MenuItem miMapToolZoomIn;<p></p></P>
<P  align=left>        private System.Windows.Forms.MenuItem miMapToolZoomout;<p></p></P>
<P  align=left>        private System.Windows.Forms.MenuItem miMapToolPan;<p></p></P>
<P  align=left>        private System.Windows.Forms.MenuItem miMapToolRestore;<p></p></P>
<P  align=left>        private System.Windows.Forms.MenuItem miMapToolDistance;<p></p></P>
<P  align=left>        private System.Windows.Forms.MenuItem miMapToolArea;<p></p></P>
<P  align=left>        private System.Windows.Forms.MenuItem miMapTool;<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        private System.ComponentModel.Container components = null;<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        public frmMain()<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>           InitializeComponent();<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        protected override void Dispose( bool disposing )<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>       //略<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        #region Windows 窗体设计器生成的代码<p></p></P>
<P  align=left>        private void InitializeComponent()<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>       //略<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left>        #endregion<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        [STAThread]<p></p></P>
<P  align=left>        static void Main() <p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>           Application.Run(new Form1());<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        private void mapMain_PolyToolUsed(object sender, AxMapXLib.CMapXEvents_PolyToolUsedEvent e)<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>           if(e.toolNum == 99)//测量距离<p></p></P>
<P  align=left>           {<p></p></P>
<P  align=left>               MapXLib.Points pts = (MapXLib.Points)e.points;<p></p></P>
<P  align=left>               MapXLib.Point pt1,pt2;<p></p></P>
<P  align=left>               double d=0.0;<p></p></P>
<P  align=left>               //计算顺序两个点距离,累计得到总距离<p></p></P>
<P  align=left>               for(int i=1;i<pts.Count;i++)<p></p></P>
<P  align=left>               {<p></p></P>
<P  align=left>                   pt1=pts.Item(i);<p></p></P>
<P  align=left>                   pt2=pts.Item(i+1);<p></p></P>
<P  align=left>                  d += mapMain.Distance(pt1.X,pt1.Y,pt2.X,pt2.Y);<p></p></P>
<P  align=left>               }<p></p></P>
<P  align=left>               sbMain.Text = "距离:" + d.ToString();<p></p></P>
<P  align=left>           }<p></p></P>
<P  align=left>           else if(e.toolNum == 98)//面积<p></p></P>
<P  align=left>           {<p></p></P>
<P  align=left>               MapXLib.Points pts = (MapXLib.Points)e.points;<p></p></P>
<P  align=left>               //偷懒了但是很正确<p></p></P>
<P  align=left>               MapXLib.FeatureFactory dd = mapMain.FeatureFactory;<p></p></P>
<P  align=left>               MapXLib.Style style = mapMain.DefaultStyle;<p></p></P>
<P  align=left>               sbMain.Text = "面积:" + dd.CreateRegion(pts,style).Area.ToString();<p></p></P>
<P  align=left>           }<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        private void miMapToolZoomIn_Click(object sender, System.EventArgs e)<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>           //放大<p></p></P>
<P  align=left>           mapMain.CurrentTool = MapXLib.ToolConstants.miZoomInTool;<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        private void miMapToolZoomout_Click(object sender, System.EventArgs e)<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>           //缩小<p></p></P>
<P  align=left>           mapMain.CurrentTool = MapXLib.ToolConstants.miZoomOutTool;<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        private void miMapToolPan_Click(object sender, System.EventArgs e)<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>           //拖动<p></p></P>
<P  align=left>           mapMain.CurrentTool = MapXLib.ToolConstants.miPanTool;<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        private void miMapToolRestore_Click(object sender, System.EventArgs e)<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>           //缩放到初始大小(全图)<p></p></P>
<P  align=left>           mapMain.ZoomTo(this.MapZoom,this.CenterX,this.CenterY);<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        private void miMapToolDistance_Click(object sender, System.EventArgs e)<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>           //测量距离<p></p></P>
<P  align=left>           mapMain.CurrentTool = (MapXLib.ToolConstants)99;<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        private void miMapToolArea_Click(object sender, System.EventArgs e)<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>           //测量面积<p></p></P>
<P  align=left>           mapMain.CurrentTool = (MapXLib.ToolConstants) 98;<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left> <p></p></P>
<P  align=left>        private void frmMain_Load(object sender, System.EventArgs e)<p></p></P>
<P  align=left>       {<p></p></P>
<P  align=left>           //记录地图的比例合中心点<p></p></P>
<P  align=left>           this.MapZoom = mapMain.Zoom;<p></p></P>
<P  align=left>           this.CenterX = mapMain.CenterX;<p></p></P>
<P  align=left>           this.CenterY = mapMain.CenterY;<p></p></P>
<P  align=left>           //创建测量距离的工具<p></p></P>
<P  align=left>           mapMain.CreateCustomTool(99,(short)MapXLib.ToolTypeConstants.miToolTypePoly,MapXLib.CursorConstants.miCrossCursor,MapXLib.CursorConstants.miCrossCursor,MapXLib.CursorConstants.miCrossCursor,false);<p></p></P>
<P  align=left>           //创建测量面积的工具<p></p></P>
<P  align=left>           mapMain.CreateCustomTool(98,(short)MapXLib.ToolTypeConstants.miToolTypePolygon,MapXLib.CursorConstants.miCrossCursor,MapXLib.CursorConstants.miCrossCursor,MapXLib.CursorConstants.miCrossCursor,false);<p></p></P>
<P  align=left>       }<p></p></P>
<P  align=left>    }<p></p></P>
<P  align=left>}<p></p></P>
<P ><b><FONT size=3> <p></p></FONT></b></P>
喜欢0 评分0
GIS麦田守望者,期待与您交流。
游客

返回顶部