首页 > 代码库 > (转)深入理解最强桌面地图控件GMAP.NET ---搜狗(sougou地图)
(转)深入理解最强桌面地图控件GMAP.NET ---搜狗(sougou地图)
这应该是我集成国内地图的最后一篇了,以后如果有精力会继续分析Google地图,Bing地图,Yahoo地图,Ovi地图。
同时,会尽快将离线地图的使用以及数据存储部分分享出来。
前面的相关文章链接:
深入理解最强桌面地图控件GMAP.NET --- 原理篇
深入理解最强桌面地图控件GMAP.NET --- SOSO地图
深入理解最强桌面地图控件GMAP.NET --- 百度地图
深入理解最强桌面地图控件GMAP.NET --- 初用
深入理解最强桌面地图控件GMAP.NET --- 初识
如何在你的程序中使用GMAP.NET 搜狗地图
要使用以下代码,建议看看初用篇,具体代码如下所示。
this.MainMap.Position = new PointLatLng(double.Parse(ConfigurationManager.AppSettings["defaultLat"]),double.Parse(ConfigurationManager.AppSettings["defaultLng"]));this.MainMap.MapProvider.Area = new RectLatLng(30.981178, 105.351914, 2.765142, 4.120995);this.MainMap.BoundsOfMap = new RectLatLng(30.981178, 105.351914, 2.765142, 4.120995);this.MainMap.Manager.Mode = AccessMode.CacheOnly;this.MainMap.MapProvider = GMapProviders.SogouMapProvider;this.MainMap.DragButton = MouseButton.Left;this.MainMap.Zoom = 13;this.MainMap.MinZoom = 8;this.MainMap.MaxZoom = 24;
GMAP.NET 搜狗地图的效果
普通地图
卫星地图
搜狗地图加载原理
要理解如何加载搜狗地图,也要理解下加载原理,我们用Chrome打开 http://map.sogou.com/,随便定位一个地址,打开开发者工具:
可以看到Tile的地址如下:http://p2.go2map.com/seamless1/0/174/717/3/1/744_212.png
分析下Url链接参数:
http://p2.go2map.com/seamless1/0/174是固定的
717=729-缩放级别(Zoom)
3=网格横坐标/200最接近的整数值=Math.Floor(x/200)。
1=网格纵坐标/200最接近的整数值=Math.Floor(y/200)。
744是网格横坐标。
212是网格纵坐标。
反正上面这些参数我也是东拼西凑了很多资料来的,确实搜狗的很诡异。
下面我们看看如何在GMAP.NET中实现搜狗地图吧。
SogouMapProvider
1)添加abstract class SougouMapProviderBase
由于搜狗地图也有普通地图和卫星地图,因此提供了一个有公共方法的抽象类,可以复用。
public abstract class SogouMapProviderBase : GMapProvider { public SogouMapProviderBase() { MaxZoom = null; RefererUrl = "http://map.sougou.com"; Copyright = string.Format("©{0} Sogou Corporation, ©{0} NAVTEQ, ©{0} Image courtesy of NASA", DateTime.Today.Year); } public override PureProjection Projection { get { return MercatorProjection.Instance; } } GMapProvider[] overlays; public override GMapProvider[] Overlays { get { if (overlays == null) { overlays = new GMapProvider[] { this }; } return overlays; } } protected override bool CheckTileImageHttpResponse(System.Net.HttpWebResponse response) { var pass = base.CheckTileImageHttpResponse(response); if (!pass) { return response.ResponseUri.AbsoluteUri.EndsWith(".png") || response.ResponseUri.AbsoluteUri.EndsWith(".JPG"); } return true; } }
2)添加SougouMapProvider
public class SogouMapProvider: SogouMapProviderBase { public static readonly SogouMapProvider Instance; readonly Guid id = new Guid("7E2A0100-7A75-4c49-A2C9-EE1C73947E10"); public override Guid Id { get { return id; } } readonly string name = "SohuMap"; public override string Name { get { return name; } } static SogouMapProvider() { Instance = new SogouMapProvider(); } public override PureImage GetTileImage(GPoint pos, int zoom) { string url = MakeTileImageUrl(pos, zoom, LanguageStr); return GetTileImageUsingHttp(url); } string MakeTileImageUrl(GPoint pos, int zoom, string language) { zoom = zoom - 1; var offsetX = Math.Pow(2, zoom); var offsetY = offsetX - 1; var numX = pos.X - offsetX; var numY = -pos.Y + offsetY; zoom = zoom + 1; var zoomLevel = 729 - zoom; if (zoomLevel == 710) { zoomLevel = 792; } var blo = Math.Floor(numX/200); var bla = Math.Floor(numY/200); string blos, blas; if (blo < 0) { blos = "M" + (-blo); } else { blos = blo.ToString(); } if (bla < 0) { blas = "M" + (-bla); } else { blas = bla.ToString(); } var x = numX.ToString().Replace("-","M"); var y = numY.ToString().Replace("-","M"); //http://p1.go2map.com/seamless1/0/174/720/0/0/95_25.pngstring url = string.Format(UrlFormat, "1", zoomLevel, blos, blas, x, y); Console.WriteLine("url:" + url); return url; } static readonly string UrlFormat = "http://p{0}.go2map.com/seamless1/0/174/{1}/{2}/{3}/{4}_{5}.png"; }
原文链接:http://www.cnblogs.com/enjoyeclipse/archive/2013/01/29/2880791.html
(转)深入理解最强桌面地图控件GMAP.NET ---搜狗(sougou地图)