高德地圖WEB版基礎(chǔ)控件展示 <font color=red>原創(chuàng)</font
之前想自己做一個旅游導(dǎo)航的項目,在網(wǎng)上一搜發(fā)現(xiàn)了高德地圖開放平臺,發(fā)現(xiàn)原來高德可以很簡單的就應(yīng)用到自己的項目里面,當(dāng)即我就申請了一個key來學(xué)一學(xué),仔細研究了一下,感覺還挺難的,網(wǎng)上找了找案例什么的,經(jīng)過這幾天,小編把高德的一些基礎(chǔ)控件差不多弄了一下,效果圖如下圖所示:
廢話不多說,直接上源碼,下面是js代碼:
<script language="javascript" src="/a1/uploads/allimg/200111/1021132923-0.jpg">//引入高德地圖API</script> <script language="javascript"> var mapObj; var scale; var mapType; var toolBar; var overView; var circleEditor; var circle; var polygonEditor; var polygon; var homeControl; var controlUI; var ruler; var mousetool; //刷新頁面 function reload(){ location.reload(); } function mapInit(){ mapObj = new AMap.Map("iCenter",{ center:new AMap.LngLat(116.397728,39.90423), //地圖中心點 level:13, //地圖顯示的比例尺級別 }); mapObj.plugin(["AMap.ToolBar"],function(){ //在地圖中添加ToolBar插件 toolBar = new AMap.ToolBar(); mapObj.addControl(toolBar); }); mapObj.plugin(["AMap.Scale"],function(){ //加載比例尺插件 scale = new AMap.Scale(); mapObj.addControl(scale); scale.show(); }); mapObj.plugin(["AMap.OverView"],function(){ //在地圖中添加鷹眼插件 //加載鷹眼 overView = new AMap.OverView({ visible:true //初始化顯示鷹眼 }); mapObj.addControl(overView); overView.open(); //展開鷹眼 }); mapObj.plugin(["AMap.RangingTool"],function(){ ruler = new AMap.RangingTool(mapObj); AMap.event.addListener(ruler,"end",function(e){ ruler.turnOff(); }); }); mapObj.plugin(["AMap.MouseTool"],function(){ //鼠標(biāo)工具插件 mousetool = new AMap.MouseTool(mapObj); }); } function Coordinate(){ AMap.event.addListener(mapObj,'click',getLnglat); //點擊事件 } function toolBarShow(){ toolBar.show(); toolBar.showRuler(); toolBar.showDirection(); } function toolBarDirection(){ toolBar.show(); toolBar.showDirection(); toolBar.hideRuler(); } function toolBarLong(){ toolBar.show(); toolBar.hideDirection(); toolBar.showRuler(); } function toolBarShot(){ toolBar.show(); toolBar.hideRuler(); toolBar.hideDirection(); } function iMapType(){ mapObj.plugin(["AMap.MapType"],function(){ //添加地圖類型切換插件 //地圖類型切換 mapType= new AMap.MapType({defaultType:1,showRoad:true}); mapObj.addControl(mapType); }); } function removeMapType(){ mapObj.removeControl(mapType); } function iCircleEditor(){ //圓形編輯器 circle = new AMap.Circle({ //圓形編輯器的樣式 map: mapObj, center:new AMap.LngLat("116.40332221984863","39.90025505675715"), radius:1000, strokeColor: "#F33", strokeOpacity: 1, strokeWeight: 3, fillColor: "ee2200", fillOpacity: 0.35 }); mapObj.plugin(["AMap.CircleEditor"],function(){ circleEditor = new AMap.CircleEditor(mapObj,circle); //創(chuàng)建圓形編輯器對象 circleEditor.open(); //打開圓形編輯器 }); } function removeCicleEditor(){ //關(guān)閉圓形編輯器,隱藏圓形 circleEditor.close(); circle.hide(); } function iPloygonEditor(){ //編輯多邊形 var arr=new Array();//經(jīng)緯度坐標(biāo)數(shù)組 arr.push(new AMap.LngLat("116.403322","39.920255")); arr.push(new AMap.LngLat("116.410703","39.897555")); arr.push(new AMap.LngLat("116.402292","39.892353")); arr.push(new AMap.LngLat("116.389846","39.891365")); polygon = new AMap.Polygon({ path:arr, //設(shè)置多邊形輪廓的節(jié)點數(shù)組 strokeColor:"#0000ff", strokeOpacity:0.2, strokeWeight:3, fillColor: "#f5deb3", fillOpacity: 0.35 }); //地圖上添加多邊形 mapObj.addOverlays(polygon); //構(gòu)造多邊形編輯對象,并開啟多邊形的編輯狀態(tài) mapObj.plugin(["AMap.PolyEditor"],function(){ polygonEditor = new AMap.PolyEditor(mapObj,polygon); polygonEditor.open(); }); } function removePloygonEditor(){ polygonEditor.close(); polygon.hide(); } AMap.homeControlDiv = function(){} AMap.homeControlDiv.prototype = { addTo: function(map, dom){ dom.appendChild(this._getHtmlDom(map)); }, _getHtmlDom:function(map){ this.map=map; // 創(chuàng)建一個能承載控件的<div>容器 controlUI = document.createElement("DIV"); controlUI.style.width='80px'; //設(shè)置控件容器的寬度 controlUI.style.height='20px'; //設(shè)置控件容器的高度 controlUI.style.backgroundColor='white'; controlUI.style.borderStyle='solid'; controlUI.style.borderWidth='2px'; controlUI.style.cursor='pointer'; controlUI.style.textAlign='center'; // 設(shè)置控件的位置 controlUI.style.position='absolute'; controlUI.style.left='120px'; //設(shè)置控件離地圖的左邊界的偏移量 controlUI.style.top='5px'; //設(shè)置控件離地圖上邊界的偏移量 controlUI.style.zIndex='300'; //設(shè)置控件在地圖上顯示 // 設(shè)置控件字體樣式 controlUI.style.fontFamily='Arial,sens-serif'; controlUI.style.fontSize='12px'; controlUI.style.paddingLeft='4px'; controlUI.style.paddingRight='4px'; controlUI.innerHTML="換中心點"; // 設(shè)置控件響應(yīng)點擊onclick事件 controlUI.onclick = function(){ map.setCenter(new AMap.LngLat(116.234404, 39.12915)); } return controlUI; } } AMap.event.trigger(homeControlDiv,"hide"); AMap.event.addListener(homeControlDiv,"hide",function(){ controlUI.style.display = 'none'; }) function myControl(){ homeControl = new AMap.homeControlDiv(mapObj); //新建自定義插件對象 mapObj.addControl(homeControl); //地圖上添加插件 } function removeMyControl(){ homeControl.hide(); //controlUI.style.display='none'; } function iRangingTool(){ ruler.turnOn(); } function removeRangingTool(){ ruler.turnOff(); mapObj.clearMap(); //ruler.hide(); //ruler.setMap(null); //mapObj.removeControl(ruler); } function iMarker(){ mousetool.marker(); //使用鼠標(biāo)工具,在地圖上畫標(biāo)記點 } function iMeasureArea(){ mousetool.measureArea(); } function iRectZoomIn(){ mousetool.rectZoomIn(); } function iRectZoomOut(){ mousetool.rectZoomOut(); } function iPolyline(){ mousetool.polyline(); } function iPolygon(){ mousetool.polygon(); } function iCircle(){ mousetool.circle(); } function iRectangle(){ mousetool.rectangle(); } function iRule(){ mousetool.rule(); } function removeMouseTool(){ mousetool.close(true); } function geocoder() { var MGeocoder; //加載地理編碼插件 mapObj.plugin(["AMap.Geocoder"], function() { MGeocoder = new AMap.Geocoder({ radius: 1000, extensions: "all" }); //返回地理編碼結(jié)果 AMap.event.addListener(MGeocoder, "complete", geocoder_CallBack); //逆地理編碼 MGeocoder.getAddress(lnglatXY); }); //加點 var marker = new AMap.Marker({ map:mapObj, icon: new AMap.Icon({ image: "http://api.amap.com/Public/images/js/mark.png", size:new AMap.Size(58,30), imageOffset: new AMap.Pixel(-32, -0) }), position: lnglatXY, offset: new AMap.Pixel(-5,-30) }); // mapObj.setFitView(); } //回調(diào)函數(shù) function geocoder_CallBack(data) { var address; //返回地址描述 address = data.regeocode.formattedAddress; //返回結(jié)果拼接輸出 document.getElementById("iAddress").innerHTML = address; } //鼠標(biāo)點擊,獲取經(jīng)緯度坐標(biāo) function getLnglat(e){ mapObj.clearMap(); var x = e.lnglat.getLng(); var y = e.lnglat.getLat(); document.getElementById("lnglat").innerHTML = x + "," + y; lnglatXY = new AMap.LngLat(x,y); geocoder(); } </script>
下面是HTML代碼:
<body onLoad="mapInit()"> <div id="iCenter"></div> <div id="iControlbox"> <ul> <li><button onclick="javascript:toolBarShow();">顯示完整魚骨</button><button onclick="javascript:toolBar.hide();">隱藏魚骨</button><button onclick="javascript:toolBarDirection();">方向盤</button><button onclick="javascript:toolBarLong();">長標(biāo)尺</button><button onclick="javascript:toolBarShot();">短標(biāo)尺</button></li> <li><button onclick="javascript:scale.show();">顯示比例尺</button><button onclick="javascript:scale.hide();">隱藏比例尺</button></li> <li><button onclick="javascript:overView.show();">顯示鷹眼</button><button onclick="javascript:overView.hide();">隱藏鷹眼</button></li> <li><button onclick="javascript:iMapType();">添加地圖類型切換</button><button onclick="javascript:removeMapType();">移除地圖類型切換</button></li> <li><button onclick="javascript:iCircleEditor();">添加圓形編輯器</button><button onclick="javascript:removeCicleEditor();">刪除圓形編輯器</button></li> <li><button onclick="javascript:iPloygonEditor();">添加多邊形編輯器</button><button onclick="javascript:removePloygonEditor();">刪除多邊形編輯器</button></li> <li><button onclick="javascript:iMarker();">鼠標(biāo)打點工具</button><button onclick="javascript:removeMouseTool();">清除</button></li> <li><button onclick="javascript:iPolyline();">鼠標(biāo)畫折線工具</button><button onclick="javascript:removeMouseTool();">清除</button></li> <li><button onclick="javascript:iPolygon();">鼠標(biāo)畫多邊形工具</button><button onclick="javascript:removeMouseTool();">清除</button></li> <li><button onclick="javascript:iCircle();">鼠標(biāo)畫圓形工具</button><button onclick="javascript:removeMouseTool();">清除</button></li> <li><button onclick="javascript:iRectangle();">鼠標(biāo)畫矩形工具</button><button onclick="javascript:removeMouseTool();">清除</button></li> <li><button onclick="javascript:iRule();">鼠標(biāo)測距工具</button><button onclick="javascript:removeMouseTool();">清除</button></li> <li><button onclick="javascript:iMeasureArea();">鼠標(biāo)測面積</button><button onclick="javascript:removeMouseTool();">移除</button></li> <li><button onclick="javascript:iRectZoomIn();">鼠標(biāo)框選縮小</button><button onclick="javascript:iRectZoomOut();">鼠標(biāo)框選放大</button><button onclick="javascript:removeRangingTool();">關(guān)閉鼠標(biāo)放大縮小</button></li> <li><button onclick="javascript:iRangingTool();">測距插件</button><button onclick="javascript:removeRangingTool();">隱藏測距</button></li> <li><button onclick="javascript:myControl();">添加自定義控件</button><button onclick="javascript:removeMyControl();">移除自定義控件</button></li> <li><div class="detail"><p><span id="lnglat"> </span></p><p><span id="iAddress"> </span></p></div></li> <li><button onclick="javascript:Coordinate();">坐標(biāo)拾取控件</button><button onclick="javascript:reload();">取消坐標(biāo)拾取</button></li> </ul> </div> </body>
在js第一行引入高德地圖API中,key值是我自己在高德地圖里面創(chuàng)建的也可以用,你們也可以上高德開放平臺自行申請key值試一試。
高德開放平臺:developer.amap.com/
這里是本效果圖源碼下載地址,感興趣的朋友可以直接下載
點擊此處下載
欄 目:CSS/HTML
下一篇:HTML5實戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)
本文標(biāo)題:高德地圖WEB版基礎(chǔ)控件展示 <font color=red>原創(chuàng)</font
本文地址:http://mengdiqiu.com.cn/a1/CSS_HTML/11491.html
您可能感興趣的文章


閱讀排行
本欄相關(guān)
- 04-02html5算法,html5協(xié)議
- 04-02html5圖形,html5圖形縮放
- 04-02html5登錄模板,html5登錄注冊模板
- 04-02html5的例子,HTML示例
- 04-02html5的canvas,html5的canvas的作用
- 04-02關(guān)于html5 視頻代碼的信息
- 04-02html5chm手冊,html操作手冊
- 04-02朋友圈html5,朋友圈發(fā)泄情緒的句子
- 04-02html5的新特性有哪些,HTML5的新特性有哪
- 04-02html5掃二維碼,html5調(diào)用手機攝像頭掃描
隨機閱讀
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實例總結(jié)
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10delphi制作wav文件的方法
- 01-11ajax實現(xiàn)頁面的局部加載