HTML5-Geolocation&地圖.html


 

<!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>
相關文章
相關標籤/搜索