1. 程式人生 > >『實踐』百度地圖給多個marker新增右鍵選單(刪除、更新)

『實踐』百度地圖給多個marker新增右鍵選單(刪除、更新)

 1 $.getJSON("./GetStationPlaceServlet",function(json){  
 2         for(var i=0;i<json.length;i++){
 3             var obj1 = eval(json);
 4             //獲取經緯度
 5             fStationlon = parseFloat(obj1[i].Stationlon);
 6             fStationlat = parseFloat(obj1[i].Stationlat);    
 7             var
pt = new BMap.Point(fStationlon,fStationlat); 8 var myIcon = new BMap.Icon("photo/station.png",new BMap.Size(50,50),{ anchor: new BMap.Size(10, 10) }); 9 var marker = new BMap.Marker(pt,{icon:myIcon}); // 建立標註 10 map.addOverlay(marker); //將標註新增到地圖中 11 var
strRes = parseFloat(obj1[i].StationId); 12 addClickHandler(strRes,marker);//左鍵單擊marker事件 13 RightClickHandler(strRes,marker);//右鍵單擊marker出現右鍵選單事件 14 RightClick();//右鍵地圖出現右鍵選單事件 15 } 16 }); 17 //右鍵單擊marker出現右鍵選單事件 18 function RightClickHandler(stationId,marker){
19 var removeMarker = function(e,ee,marker){//右鍵刪除站點 20 var json={ 21 "StationId":stationId, 22 }; 23 if (confirm("要刪除站點"+stationId+"嗎?")){ 24 if(true){ 25 $.getJSON("./DeleteStationServlet",{json:JSON.stringify(json)},function(json){ 26 if(json.result==true){ 27 alert("刪除站點"+stationId+"成功!"); 28 map.removeOverlay(marker); //將地圖中的標記刪除 29 } 30 }); 31 } 32 } 33 }; 34 var updateMarker = function(marker){//右鍵更新站名 35 if (confirm("要修改站點"+stationId+"的站名嗎?")){ 36 if(true){ 37 $(".AllUpdateMassage").show(); 38 $("#stationId").val(stationId); 39 } 40 } 41 }; 42 var markerMenu=new BMap.ContextMenu(); 43 markerMenu.addItem(new BMap.MenuItem('刪除站點',removeMarker.bind(marker))); 44 markerMenu.addItem(new BMap.MenuItem('修改站名',updateMarker.bind(marker))); 45 marker.addContextMenu(markerMenu);//給標記新增右鍵選單 46 } 47 //滑鼠左鍵單擊marker事件 48 function addClickHandler(stationId,marker){ 49 marker.addEventListener("click",function(e){ 50 var p = marker.getPosition(); //獲取marker的位置 51 var staId={ 52 "StationId":stationId, 53 }; 54 $.getJSON("./GetStationInfoServlet",{json:JSON.stringify(staId)},function(json){ 55 56 for(var i=0;i<json.length;i++){ 57 var obj1 = eval(json); 58 59 stationName = obj1[i].stationName; 60 61 var content = "站點編號:"+stationId+"<br/>"+ "站點名稱:"+stationName; 62 openInfo(content,e); 63 } 64 }); 65 }); 66 } 67 //左鍵單擊marker彈出視窗事件 68 function openInfo(content,e){ 69 var p = e.target; 70 var point = new BMap.Point(p.getPosition().lng, p.getPosition().lat); 71 var infoWindow = new BMap.InfoWindow(content,opts); // 建立資訊視窗物件 72 map.openInfoWindow(infoWindow,point); //開啟資訊視窗 73 } 74 //修改站點站名 75 function update(){ 76 var stationId=$("#stationId").val();//編號 77 var stationName=$(".AllUpdateMassage_name").val();//名字 78 79 var json={ 80 "StationId":stationId, 81 "StationName":stationName 82 }; 83 84 $.getJSON("./UpdateStationServlet",{json:JSON.stringify(json)},function(json){ 85 86 if(json.result==true){ 87 alert("站點"+stationId+"站名修改成功!"); 88 $(".AllUpdateMassage").hide(); 89 } 90 else{ 91 alert("失敗!"); 92 } 93 }); 94 95 }