zoukankan      html  css  js  c++  java
  • 深入理解最强桌面地图控件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.png
                string 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";
        }
  • 相关阅读:
    「BJOI2018」治疗之雨
    「NOIP2016」换教室
    「HNOI2015」亚瑟王
    2019/9/15 四校联训
    【AtCoder】 ARC 097
    【AtCoder】 ARC 098
    【AtCoder】 ARC 099
    【AtCoder】 ARC 100
    React:JS中的this和箭头函数
    React:styled-components
  • 原文地址:https://www.cnblogs.com/enjoyeclipse/p/2880791.html
Copyright © 2011-2022 走看看