| ¶Ô±ÈÐÂÎļþ |
| | |
| | | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" |
| | | "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> |
| | | <html xmlns="http://www.w3.org/1999/xhtml"> |
| | | <head> |
| | | <meta charset="utf-8"/> |
| | | <meta name="keywords" content="ç¾åº¦å°å¾,ç¾åº¦å°å¾APIï¼ç¾åº¦å°å¾èªå®ä¹å·¥å
·ï¼ç¾åº¦å°å¾æè§å³æå¾å·¥å
·"/> |
| | | <meta name="description" content="ç¾åº¦å°å¾APIèªå®ä¹å°å¾ï¼å¸®å©ç¨æ·å¨å¯è§åæä½ä¸çæç¾åº¦å°å¾"/> |
| | | <title>ç¾åº¦å°å¾APIèªå®ä¹å°å¾</title> |
| | | <!--å¼ç¨ç¾åº¦å°å¾API--> |
| | | <style type="text/css"> |
| | | html, body { |
| | | margin: 0; |
| | | padding: 0; |
| | | overflow: hidden; |
| | | } |
| | | </style> |
| | | <script type="text/javascript" src="http://api.map.baidu.com/api?key=&v=1.1&services=true"></script> |
| | | </head> |
| | | |
| | | <body onload="initMap();"> |
| | | <!--ç¾åº¦å°å¾å®¹å¨--> |
| | | <div style="width:697px;height:550px;border:#ccc solid 1px;" id="dituContent"></div> |
| | | </body> |
| | | <script type="text/javascript"> |
| | | function getParam(name) { |
| | | return location.href.match(new RegExp('[?#&]' + name + '=([^?#&]+)', 'i')) ? RegExp.$1 : ''; |
| | | } |
| | | var map, marker; |
| | | var centerParam = getParam('center'); |
| | | var zoomParam = getParam('zoom'); |
| | | var widthParam = getParam('width'); |
| | | var heightParam = getParam('height'); |
| | | var markersParam = getParam('markers'); |
| | | var markerStylesParam = getParam('markerStyles'); |
| | | |
| | | //å建ååå§åå°å¾å½æ°ï¼ |
| | | function initMap() { |
| | | // [FF]åæ¢æ¨¡å¼åæ¥é |
| | | if (!window.BMap) { |
| | | return; |
| | | } |
| | | var dituContent = document.getElementById('dituContent'); |
| | | dituContent.style.width = widthParam + 'px'; |
| | | dituContent.style.height = heightParam + 'px'; |
| | | |
| | | createMap();//å建å°å¾ |
| | | setMapEvent();//设置å°å¾äºä»¶ |
| | | addMapControl();//åå°å¾æ·»å æ§ä»¶ |
| | | |
| | | // åå»ºæ æ³¨ |
| | | var markersArr = markersParam.split(','); |
| | | var point = new BMap.Point(markersArr[0], markersArr[1]); |
| | | marker = new BMap.Marker(point); |
| | | marker.enableDragging(); |
| | | map.addOverlay(marker); // å°æ 注添å å°å°å¾ä¸ |
| | | |
| | | if(parent.editor && parent.document.body.contentEditable=="true") { //å¨ç¼è¾ç¶æä¸ |
| | | setMapListener();//å°å¾æ¹åä¿®æ¹å¤å±çiframeæ ç¾src屿§ |
| | | } |
| | | } |
| | | |
| | | //å建å°å¾å½æ°ï¼ |
| | | function createMap() { |
| | | map = new BMap.Map("dituContent");//å¨ç¾åº¦å°å¾å®¹å¨ä¸å建ä¸ä¸ªå°å¾ |
| | | var centerArr = centerParam.split(','); |
| | | var point = new BMap.Point(parseFloat(centerArr[0]), parseFloat(centerArr[1]));//å®ä¹ä¸ä¸ªä¸å¿ç¹åæ |
| | | map.centerAndZoom(point, parseInt(zoomParam));//设å®å°å¾çä¸å¿ç¹ååæ å¹¶å°å°å¾æ¾ç¤ºå¨å°å¾å®¹å¨ä¸ |
| | | } |
| | | |
| | | //å°å¾äºä»¶è®¾ç½®å½æ°ï¼ |
| | | function setMapEvent() { |
| | | map.enableDragging();//å¯ç¨å°å¾ææ½äºä»¶ï¼é»è®¤å¯ç¨(å¯ä¸å) |
| | | map.enableScrollWheelZoom();//å¯ç¨å°å¾æ»è½®æ¾å¤§ç¼©å° |
| | | map.enableDoubleClickZoom();//å¯ç¨é¼ æ å廿¾å¤§ï¼é»è®¤å¯ç¨(å¯ä¸å) |
| | | map.enableKeyboard();//å¯ç¨é®çä¸ä¸å·¦å³é®ç§»å¨å°å¾ |
| | | } |
| | | |
| | | //å°å¾æ§ä»¶æ·»å 彿°ï¼ |
| | | function addMapControl() { |
| | | //åå°å¾ä¸æ·»å ç¼©æ¾æ§ä»¶ |
| | | var ctrl_nav = new BMap.NavigationControl({anchor: BMAP_ANCHOR_TOP_LEFT, type: BMAP_NAVIGATION_CONTROL_LARGE}); |
| | | map.addControl(ctrl_nav); |
| | | //åå°å¾ä¸æ·»å 缩ç¥å¾æ§ä»¶ |
| | | var ctrl_ove = new BMap.OverviewMapControl({anchor: BMAP_ANCHOR_BOTTOM_RIGHT, isOpen: 1}); |
| | | map.addControl(ctrl_ove); |
| | | //åå°å¾ä¸æ·»å æ¯ä¾å°ºæ§ä»¶ |
| | | var ctrl_sca = new BMap.ScaleControl({anchor: BMAP_ANCHOR_BOTTOM_LEFT}); |
| | | map.addControl(ctrl_sca); |
| | | } |
| | | |
| | | function setMapListener() { |
| | | var editor = parent.editor, containerIframe, |
| | | iframes = parent.document.getElementsByTagName('iframe'); |
| | | for (var key in iframes) { |
| | | if (iframes[key].contentWindow == window) { |
| | | containerIframe = iframes[key]; |
| | | break; |
| | | } |
| | | } |
| | | if (containerIframe) { |
| | | map.addEventListener('moveend', mapListenerHandler); |
| | | map.addEventListener('zoomend', mapListenerHandler); |
| | | marker.addEventListener('dragend', mapListenerHandler); |
| | | } |
| | | |
| | | function mapListenerHandler() { |
| | | var zoom = map.getZoom(), |
| | | center = map.getCenter(), |
| | | marker = window.marker.getPoint(); |
| | | containerIframe.src = containerIframe.src. |
| | | replace(new RegExp('([?#&])center=([^?#&]+)', 'i'), '$1center=' + center.lng + ',' + center.lat). |
| | | replace(new RegExp('([?#&])markers=([^?#&]+)', 'i'), '$1markers=' + marker.lng + ',' + marker.lat). |
| | | replace(new RegExp('([?#&])zoom=([^?#&]+)', 'i'), '$1zoom=' + zoom); |
| | | editor.fireEvent('saveScene'); |
| | | } |
| | | } |
| | | </script> |
| | | </html> |