GMap.NET是一个强大、免费、跨平台、开源的.NET控件,它在Windows Forms和WPF环境中能够通过Google, Yahoo!, Bing, OpenStreetMap, ArcGIS, Pergo, SigPac等实现路径规划、地理编码以及地图展示功能,并支持缓存和运行在Mobile环境中。
本文介绍了从下载安装到如何使用GMap.NET。
本文介绍了从下载安装到如何使用GMap.NET。
本文所使用的GMap.NET版本为1.7稳定版。
下载和安装

添加GMapControl到工具箱。在“选择项”时,选择“GMap.NET.WindowsForms.dll”文件即可添加。

使用NuGet安装

添加地图控件
拖拽GMapControl到Windows Form中,可看到控件中心有个小十字。查看属性,你会发现GMap.NET的一些特有属性。通过设置这些属性可以配置地图的行为,但是不能设置其内容。

* Bearing - 按照指定的度数向左旋转地图 * CanDragMap – 是否启用鼠标右键拖动(平移)地图 * EmptyTileColor – 设置没有数据的切片所显示的颜色 * MarkersEnabled – 是否显示定义的标记,同PolygonsEnabled和RoutesEnabled * ShowTileGridLines – 显示网格线 * Zoom,MinZoom和MaxZoom - 缩放级别
this.gMapControl1.MapProvider = OpenStreet4UMapProvider.Instance; // 设置地图源 GMaps.Instance.Mode = AccessMode.ServerAndCache; // GMap工作模式 this.gMapControl1.SetPositionByKeywords("北京"); // 地图中心位置 //使用经纬度设置地图中心 //this.gMapControl1.Position = new GMap.NET.PointLatLng(39.923518, 116.539009);
① MapProvider:设置地图源,输入GMapProviders可以看到GMap所支持的所有地图源。
② GMaps.Instance.Mode: GMap可以从服务器、本地缓存、服务器或本地缓存获取数据。这适用于在应用程序中创建的所有GMap控件实例,只需要设置一次该值。
③ 设置地图中心位置可以使用关键字或者经纬度。
④ 地图显示结果。按住鼠标右键可以拖拽地图,当然也可以设置其他键来拖拽。
③ 设置地图中心位置可以使用关键字或者经纬度。
④ 地图显示结果。按住鼠标右键可以拖拽地图,当然也可以设置其他键来拖拽。
this.gMapControl1.DragButton = MouseButtons.Left;
添加标记
//创建一个名为“markers”的图层 GMapOverlay markers = new GMapOverlay("markers"); //创建标记,并设置位置及样式 GMapMarker marker = new GMarkerGoogle(new PointLatLng(39.923518, 116.539009), GMarkerGoogleType.blue_pushpin); //将标记添加到图层 markers.Markers.Add(marker); //将图层添加到地图 this.gMapControl1.Overlays.Add(markers);
① GMapOverlay:图层。添加的标记、图形、路径等都是在图层上操作的。
② GMapMarker:GMarkerGoogle,提供标记位置(PointLatLng)和标记样式。 它有两个重载,可以使用GMarkerGoogleType和位图。GMap.NET还提供了GMarkerCross,这是一个简单的十字,不允许使用图标。
public GMarkerGoogle(PointLatLng p, GMarkerGoogleType type); public GMarkerGoogle(PointLatLng p, Bitmap Bitmap);
GMapMarker还可以设置ToolTip。
marker.ToolTipText = "我在这里"; marker.ToolTip.Fill = new SolidBrush(Color.FromArgb(100, Color.Black)); marker.ToolTip.Foreground = Brushes.White; marker.ToolTip.TextPadding = new Size(20, 20);
③ 地图显示结果。(发现中心的小十字没了吗,因为这是可以设置的)
this.gMapControl1.ShowCenter = false; //隐藏中心十字
④ 标记点击事件
标记本身没有任何事件钩子,GMapControl的OnMarkerClick事件即为标记点击事件。在下面的示例中,点击标记会弹出提示框显示ToolTip的文本内容。当然GMap.NET不只有点击事件,还有OnMarkerEnter、OnMarkerLeave。
标记本身没有任何事件钩子,GMapControl的OnMarkerClick事件即为标记点击事件。在下面的示例中,点击标记会弹出提示框显示ToolTip的文本内容。当然GMap.NET不只有点击事件,还有OnMarkerEnter、OnMarkerLeave。
private void gMapControl1_OnMarkerClick(GMapMarker item, MouseEventArgs e) { MessageBox.Show(String.Format("Marker:{0} 被点了。", item.ToolTipText)); }
添加多边形
添加多边形和添加标记的原理是一样的。
GMapOverlay polygons = new GMapOverlay("polygons"); // 多边形的顶点 List<PointLatLng> points = new List<PointLatLng>(); points.Add(new PointLatLng(39.92244, 116.3922)); points.Add(new PointLatLng(39.92280, 116.4015)); points.Add(new PointLatLng(39.91378, 116.4019)); points.Add(new PointLatLng(39.91346, 116.3926)); GMapPolygon polygon = new GMapPolygon(points, "故宫"); polygon.Fill = new SolidBrush(Color.FromArgb(50, Color.Red)); polygon.Stroke = new Pen(Color.Red, 1); polygons.Polygons.Add(polygon); this.gMapControl1.Overlays.Add(polygons);
显示结果

路径规划
GMap.NET中路径规划主要用RoutingProvider类的以下两种方法:
//avoidHighways:是否避免走高速公路 //walkingMode:是否步行 //zoom:查找路径时的zoom //根据起止点经纬度查找路径 MapRoute GetRoute(PointLatLng start, PointLatLng end, bool avoidHighways, bool walkingMode, int Zoom); //根据起止点地址查找路径 MapRoute GetRoute(string start, string end, bool avoidHighways, bool walkingMode, int Zoom);
通过点击地图,添加起止点
添加地图标记之前,需要先清除(Clear)以下,这样可以避免重复点击地图时,显示多个标记。
int isSetPoint; //设置起止点,1为起点,2为终点 PointLatLng startPoint; //起点 PointLatLng endPoint; //终点 private void btn_SetStart_Click(object sender, EventArgs e) { isSetPoint = 1; } private void btn_SetEnd_Click(object sender, EventArgs e) { isSetPoint = 2; } //点击地图添加起止点 private void gMapControl1_MouseClick(object sender, MouseEventArgs e) { PointLatLng point = this.gMapControl1.FromLocalToLatLng(e.X, e.Y); switch (isSetPoint) { case 1: //起点 startPoint = point; GMapMarker marker1 = new GMarkerGoogle(startPoint, GMarkerGoogleType.red_pushpin); //清除上一次添加的起点 markerStart.Markers.Clear(); markerStart.Markers.Add(marker1); break; case 2: //终点 endPoint = point; GMapMarker marker2 = new GMarkerGoogle(endPoint, GMarkerGoogleType.blue_pushpin); markerEnd.Markers.Clear(); markerEnd.Markers.Add(marker2); break; default: break; } }
查找路径
private void btn_FindRoute_Click(object sender, EventArgs e) { //点击查找路径后,不再添加点 isSetPoint = 0; RoutingProvider rp = this.gMapControl1.MapProvider as RoutingProvider; //获取路径 MapRoute route = rp.GetRoute(startPoint, endPoint, false, false, (int)this.gMapControl1.Zoom); if (route != null) { //添加routes图层 GMapOverlay routes = new GMapOverlay("routes"); GMapRoute r = new GMapRoute(route.Points, route.Name); r.Stroke = new Pen(Color.Red, 3); routes.Routes.Add(r); //添加到地图 this.gMapControl1.Overlays.Add(routes); this.gMapControl1.ZoomAndCenterRoute(r); } else { MessageBox.Show("未能找到路线"); } }
查找路径结果
如果路径查找结果(route)为null,要么时确实没有结果,要么是GMap封装的地址搜索服务失效。我在写这篇文章时,就无法使用GoogleChinaMap,上图是使用OpenStreetMap的搜索结果。