<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="keywords" content="百度地圖,百度地圖API,百度地圖自定義工具,百度地圖所見即所得工具" /> <meta name="description" content="百度地圖API自定義地圖,幫助用戶在可視化操做下生成百度地圖" /> <title>HTML5 Geolocation和百度地圖API結合使用</title> <!--引用百度地圖API--> <style type="text/css"> html,body {margin: 0;padding: 0;} .iw_poi_title {color: #CC5522;font-size: 14px;font-weight: bold;overflow: hidden;padding-right: 13px;white-space: nowrap} .iw_poi_content {font: 12px arial, sans-serif;overflow: visible;padding-top: 4px;white-space: -moz-pre-wrap;word-wrap: break-word;} </style> <script type="text/javascript" src="http://api.map.baidu.com/api?key=&v=1.1&services=true"></script> </head> <body> <p id="demo">點擊這個按鈕,得到您的位置:</p> <button onclick="getLocation()">試一下</button> <div id="mapholder"></div> <!--百度地圖容器--> <div style="width:697px;height:550px;border:#ccc solid 1px;" id="dituContent"></div> </body> <script type="text/javascript"> /* * 獲取位置信息 */ function getLocation() { if (!!navigator.geolocation) {//進行瀏覽器是否支持HTML5的定位 /* * navigator.geolocation.getCurrentPosition(successCallback, [errorCallback] , [positionOptions])方法接受三個參數, * 其中第一個參數爲必填。 * successCallback 獲取定位成功時執行的回調函數 * errorCallback 定位失敗時執行的回調函數 * positionOptions 用來設置positionOptions來更精細的執行定位 * 詳細參數說明 :http://www.cnblogs.com/lecaf/archive/2011/08/01/2123593.html */ navigator.geolocation.getCurrentPosition(showPosition, showError); //實時獲取位置信息 setInterval(function(){ //持續更新位置信息 :navigator.geolocation.watchPosition(successCallback, [errorCallback] , [positionOptions]) - 參數和getCurrentPosition一致。 var watchId = navigator.geolocation.watchPosition(updateLocation, handleeLocationError); //中止更新 :中止 watchPosition() 方法 //navigator.geolocation.clearWatch(watchId); },5000); } else { document.getElementById("mapholder").innerHTML = "Geolocation is not supported by this browser."; } } /* * 地理位置獲取成功 * 在百度地圖上顯示位置 */ function showPosition(position) { var lat = position.coords.latitude; var lon = position.coords.longitude; var acc = position.coords.accuracy; document.getElementById("demo").innerHTML = "維度:" + lat + ",經度:" + lon + ",精度:" + acc; map.clearOverlays(); var new_point = new BMap.Point(lon, lat); var marker = new BMap.Marker(new_point); // 建立標註 map.addOverlay(marker); // 將標註添加到地圖中 map.panTo(new_point); } /* * 地理位置信息獲取失敗 */ function showError(error) { switch (error.code) { case error.PERMISSION_DENIED: x.innerHTML = "User denied the request for Geolocation." break; case error.POSITION_UNAVAILABLE: x.innerHTML = "Location information is unavailable." break; case error.TIMEOUT: x.innerHTML = "The request to get user location timed out." break; case error.UNKNOWN_ERROR: x.innerHTML = "An unknown error occurred." break; } } //********************************************************************************* //#region 百度地圖API /* * API : http://developer.baidu.com/map/ * 建立百度地圖 : http://api.map.baidu.com/lbsapi/createmap/index.html */ //建立和初始化地圖函數: function initMap() { createMap(); //建立地圖 setMapEvent(); //設置地圖事件 addMapControl(); //向地圖添加控件 addMarker(); //向地圖中添加marker } //建立地圖函數: function createMap() { var map = new BMap.Map("dituContent"); //在百度地圖容器中建立一個地圖 var point = new BMap.Point(116.667343, 39.886004); //定義一箇中心點座標 map.centerAndZoom(point, 19); //設定地圖的中心點和座標並將地圖顯示在地圖容器中 window.map = map; //將map變量存儲在全局 } //地圖事件設置函數: 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); } //標註點數組 var markerArr = [{ title: "家", content: "個人備註", point: "116.666988|39.886308", isOpen: 0, icon: { w: 21, h: 21, l: 46, t: 46, x: 1, lb: 10 } }]; //建立marker function addMarker() { for (var i = 0; i < markerArr.length; i++) { var json = markerArr[i]; var p0 = json.point.split("|")[0]; var p1 = json.point.split("|")[1]; var point = new BMap.Point(p0, p1); var iconImg = createIcon(json.icon); var marker = new BMap.Marker(point, { icon: iconImg }); var iw = createInfoWindow(i); var label = new BMap.Label(json.title, { "offset": new BMap.Size(json.icon.lb - json.icon.x + 10, -20) }); marker.setLabel(label); map.addOverlay(marker); label.setStyle({ borderColor: "#808080", color: "#333", cursor: "pointer" }); (function() { var index = i; var _iw = createInfoWindow(i); var _marker = marker; _marker.addEventListener("click", function() { this.openInfoWindow(_iw); }); _iw.addEventListener("open", function() { _marker.getLabel().hide(); }) _iw.addEventListener("close", function() { _marker.getLabel().show(); }) label.addEventListener("click", function() { _marker.openInfoWindow(_iw); }) if (!!json.isOpen) { label.hide(); _marker.openInfoWindow(_iw); } })() } } //建立InfoWindow function createInfoWindow(i) { var json = markerArr[i]; var iw = new BMap.InfoWindow("<b class='iw_poi_title' title='" + json.title + "'>" + json.title + "</b><div class='iw_poi_content'>" + json.content + "</div>"); return iw; } //建立一個Icon function createIcon(json) { var icon = new BMap.Icon("http://app.baidu.com/map/images/us_mk_icon.png", new BMap.Size(json.w, json.h), { imageOffset: new BMap.Size(-json.l, -json.t), infoWindowOffset: new BMap.Size(json.lb + 5, 1), offset: new BMap.Size(json.x, json.h) }) return icon; } initMap(); //建立和初始化地圖 //#endregion 百度地圖API </script> </html>