使用高德地圖繪制多邊形區域


最近遇到一個需求,在網頁上面編輯多邊形的區域,並且需要能夠判斷一個點是否在這個多邊形區域里面。

看了一下高德地圖的jsapi,簡單的做了一個demo。

1.你需要一個高德地圖的賬號,注冊地址點擊這里

2.登陸進去創建一個應用,這個時候就會給你一個對應的Key

3.查看高德地圖的的demo,進入示例中心

4.學習一下左側分類里面的 點標記 的示例,點標記里有涉及到高德地圖事件,以及基礎的類。

5.看完上面的,接下來我們接着學習折線,多邊形,圓,這里我們就可以接觸到AMap.Polygon這個類,以及高德地圖提供編輯多邊形的類AMap.PolyEditor

6.下面我們就要開始將上面的功能組合起來,進行高德地圖多邊形的編輯了

    6.1 首先,我先用點標記在地圖上選中3個點,組成一個最基本的多邊形(三角形)

 

//用來存儲3個基本點的數組 第一個存點坐標 第二個存Marker(點標記)對象
var beginPoints;
var beginMarks ;
//地圖上面的click事件對象
var clickListener ;
//當前繪制的點個數,用來控制前面3個點
var beginNum;
//初始化
function init(){
        beginPoints = [];
        beginMarks = [];
        beginNum = 0;
        clickListener = AMap.event.addListener(map, "click", mapOnClick);
    }
init();
//地圖上面綁定的點擊事件
function mapOnClick(e) {
        // document.getElementById("lnglat").value = e.lnglat.getLng() + ',' + e.lnglat.getLat()
        beginMarks.push(addMarker(e.lnglat));
        beginPoints.push(e.lnglat);
        beginNum++;
        if(beginNum == 3){
            //處理有了3個點以后,轉化為多邊形的邏輯
        }
    };

// 實例化點標記
function addMarker(lnglat) {
        
        var marker = new AMap.Marker({
            icon: "http://webapi.amap.com/theme/v1.3/markers/n/mark_b.png",
            position: lnglat
        });
        marker.setMap(map);
        return marker;
    }

       在上面的代碼里需要說一點的是,高德地圖的事件綁定跟java的事件綁定有些類似 clickListener = AMap.event.addListener(map, "click", mapOnClick);

         其中第一個參數是要綁定事件的對象,第二個參數是事件類型,第三個參數是對應是事件函數。取消綁定事件的方法AMap.event.removeListener(clickListener);

    6.2 繪制好3個點之后,構建多邊形對象,綁定對應的多邊形編輯對象

//在上面的留空處,處理有了3個點以后的邏輯,繼續開始
AMap.event.removeListener(clickListener);
var polygon = createPolygon(beginPoints);
polygonEditor = createEditor(polygon);
clearMarks();
//處理結束

//上面用到的幾個函數
//創建一個多邊形對象
function createPolygon(arr){
        var polygon = new AMap.Polygon({
            map: map,
            path: arr,
            strokeColor: "#0000ff",
            strokeOpacity: 1,
            strokeWeight: 3,
            fillColor: "#f5deb3",
            fillOpacity: 0.35
        });
        return polygon;
    }
//創建一個多邊形對象的編輯類對象
function createEditor(polygon){
        var polygonEditor = new AMap.PolyEditor(map, polygon);
        polygonEditor.open();
        AMap.event.addListener(polygonEditor,'end',polygonEnd);
        return polygonEditor;
    }
//編輯結束事件
function polygonEnd(res){
        resPolygon.push(res.target);
        alert(resPolygon[resNum].contains([116.386328, 39.913818]));
        appendHideHtml(resNum,res.target.getPath());
        
        resNum++;
        init();
    }
//將多邊形路徑保存到html隱藏域里
function appendHideHtml(index,arr){
        var strify = JSON.stringify(arr);
        var html = '<input type="hidden" id="index'+index+'" name="paths[]" value="'+strify+'">';
        $('body').append(html);
        console.log(html);
    }

//清除前面的3個點標記
function clearMarks(){
        map.remove(beginMarks);
}

        上面的代碼里需要主要的主要是 1.高德地圖清除點標記,支持清除一組,按照數組清除。2.PolyEditor這個多邊形編輯對象,主要使用到了open()和close()兩個函數,以及end事件(當調用了close函數后觸發)3.我按照多邊形的次序,將他們append到html的隱藏域中,並且將id使用了index+次序的方式生成。

       然后可以選擇將隱藏域中的內容提交到服務器,或者做其他的處理。

       下面給出一個完整的demo,希望能夠給大家一點幫助~

       下載點擊這里

       目前在做外賣領域的項目,有想合作的掃一掃吧~~~~~~~~~~

   

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM