在谷歌地圖上繪製行政區域輪廓【結合高德地圖的API】

實現思路:javascript

1.利用高德地圖行政區域API得到座標列表html

2.將座標列表繪製在谷歌地圖上【由於高德地圖和國內的谷歌地圖都是採用GCJ02座標系,全部偏差很小,能夠不進行座標偏差轉換】java

 

注意點:git

1.用百度地圖的API來繪製行政區域,不太準確,很不推薦。(1)百度地圖查詢行政區域自己不許確,有的地方原本應該屬於該區,被劃分到其餘區了(2)即便要用百度api,也要注意轉換座標,由於百度,谷歌座標系不一樣。貼段轉換代碼github

複製代碼
var x_pi = Math.PI * 3000.0 / 180.0; 
//將 BD-09 座標轉換成 GCJ-02 座標(例如:百度座標-->谷歌座標)
function bd_decrypt(bd_lat, bd_lon)  {  
    var x = bd_lon - 0.0065, y = bd_lat - 0.006;  
    var z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi);  
    var theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi);  
    var gg_lon = z * Math.cos(theta);  
    var gg_lat = z * Math.sin(theta);
    var result = {};
    result.gg_lon = gg_lon;//緯度
    result.gg_lat = gg_lat;//經度
    return result;
}
複製代碼

2.高德地圖API文檔寫的很好,推薦使用高德地圖api

不完美的地方:工具

1.高德地圖API提供的座標,不能完整的畫出一個區的輪廓,好比上海崇明區的被劃分紅幾個小圈,而實際上,應該用一個大圈把崇明區包裹起來google

 

對應的需求,繪製出上海的全部行政區的輪廓,實現效果:編碼

 

核心代碼:spa

複製代碼
showBoundarys();
//顯示行政區域
function showBoundarys() {
    //利用高德地圖的【行政區劃查詢】api獲取上海包含的全部區
    AMap.service('AMap.DistrictSearch', function() {
        var opts = {
            subdistrict: 2,   ////返回下一級行政區。取值2,能夠獲取到上海的全部區
            extensions: 'all',  //返回行政區邊界座標組等具體信息
            level: 'city'  //查詢行政級別爲 市
        };
        //實例化DistrictSearch
        var district = new AMap.DistrictSearch(opts);
        //行政區查詢
        district.search("上海市", function(status, result) {
            var cityArr = result.districtList[0].districtList[0].districtList;
            for(var i=0;i<cityArr.length;i++){
                showBoundary(cityArr[i].adcode);
            }
        })
    });
}

/**
 * 用adcode(區域編碼)查詢,能夠惟必定位到具體的地址。
 * 用name(行政區名稱)可能查出多個地址,不精確
 */
function showBoundary(adcode) {
    //利用高德地圖的【行政區劃查詢】api獲取每一個區的行政區邊界座標點,再根據這些座標點在谷歌地圖上繪製區域輪廓線
    //加載行政區劃插件
    AMap.service('AMap.DistrictSearch', function() {
        var opts = {
                subdistrict: 0,   //返回下一級行政區
                extensions: 'all',  //返回行政區邊界座標組等具體信息
                level: 'district'  //查詢行政級別爲 市
        };
        //實例化DistrictSearch
        var district = new AMap.DistrictSearch(opts);
        district.setLevel('district');
        //行政區查詢
        district.search(adcode, function(status, result) {
            var bounds = result.districtList[0].boundaries;

            if (bounds) {
                for (var i = 0, l = bounds.length; i < l; i++) {//每一個區域可能有分能幾個小塊,好比金山區除了有一塊陸地圈,還有海上獨立的三個小島
                    var boundsItem = bounds[i];
                    var triangleCoords = [];
                    for(var j = 0; j < boundsItem.length; j++){
                        triangleCoords.push(new google.maps.LatLng(boundsItem[j].lat, boundsItem[j].lng));
                    }
                    var bermudaTriangle = new google.maps.Polygon({
                        paths : triangleCoords,
                        strokeColor : "#1c49ff",
                        strokeOpacity : 0.8,
                        strokeWeight : 1,
                        // fillColor : "#FF0000",
                        fillOpacity : 0,
                        text:"xxxxx"
                    });
                    bermudaTriangle.setMap(map);
                    map.setZoom(9);    
                }

            }
        });
    });
}
複製代碼

 

 

參考網址:

1.高德,百度,Google地圖定位偏移以及座標系轉換: https://www.jianshu.com/p/8975586a820e
2.座標拾取工具(GCJ-02座標)  http://zhaoziang.com/amap/picpoint.html
3.WGS8四、GCJ0二、BD09地圖座標系間的座標轉換及座標距離計算  http://nightfarmer.github.io/2016/12/01/GPSUtil/
4.高德地圖的API比百度、谷歌的好用,好比行政區域的座標比百度的精確,接口文檔詳細,而谷歌的文檔仍是英文的,例子也不夠全。之後選擇地圖,首選高德地圖
6.地球座標系 (WGS-84)到火星座標系 (GCJ-02) Javascript版  https://github.com/hiwanz/wgs2mars.js
相關文章
相關標籤/搜索