轉載 https://www.cnblogs.com/mengxingxinqing/p/6087201.html 謝謝
最近遇到一個需求,在網頁上面編輯多邊形的區域,并且需要能夠判斷一個點是否在這個多邊形區域裡面。
看了一下高德地圖的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);
}
轉載于:https://www.cnblogs.com/otsf/p/8515012.html