zoukankan      html  css  js  c++  java
  • 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="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>
  • 相关阅读:
    MyEclipse修改Servlet模板
    AndroidStudio启动时不自动打开项目
    Android Studio启动时出现unable to access android sdk add-on list
    基础概述
    Java环境变量设置
    eclipse安装adt插件
    设置一个.exe文件开机启动
    笔记本玩游戏设置全屏
    记一次服务器病毒查杀过程:lsass.exe占用内存高
    LayUI制作日历工作记录簿
  • 原文地址:https://www.cnblogs.com/blog-leo/p/4457692.html
Copyright © 2011-2022 走看看