zoukankan      html  css  js  c++  java
  • 百度地图拖动标注后获取坐标

    本来想用图吧的API来做的,结果弄了下,在手机上弄不了。换用百度地图了。。本功能个人觉得在很多地方用到,先记下来,省得每次都得翻地图API文档一点一点弄。

    功能表现为: 地图一开始打开就定位到你的附近(以百度地图的浏览器定位为准),地图中心有一标注,鼠标拖去标注结果后弹框显示经纬度,自己测试过在手机上也是可以拖动的

    代码如下:

    <!DOCTYPE html>
    <html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
        <style type="text/css">
            body, html, #allmap {
                100%;
                height: 100%;
                margin: 0;
                font-family: "微软雅黑";
            }

            #l-map {
                height: 500px;
                100%;
            }

            #r-result {
                100%;
            }
        </style>
        <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=fjEOTea6oQGEcK1GSUHruG4efO9fccei"></script>
        <title>设置点是否可拖拽</title>
    </head>
    <body>
        <div id="l-map"></div>
        <!--<div id="r-result">
            <input type="button" onclick="marker.enableDragging();" value="可拖拽" />
            <input type="button" onclick="marker.disableDragging();" value="不可拖拽" />
        </div>-->
    </body>
    </html>
    <script type="text/javascript">
     // 百度地图API功能


        //浏览器定位
     var geolocation = new BMap.Geolocation();
     geolocation.getCurrentPosition(function (r) {
         if (this.getStatus() == BMAP_STATUS_SUCCESS) {
             var map = new BMap.Map("l-map");
            // var point = new BMap.Point(116.400244, 39.92556);
             map.centerAndZoom(r.point, 12); //定义地图等级,就是放大倍数
             map.enableScrollWheelZoom(true); //启用地图滚轮放大缩小  
             var marker = new BMap.Marker(r.point);// 创建标注
             map.addOverlay(marker);  // 将标注添加到地图中
             map.panTo(r.point);
            // alert('您的位置:' + r.point.lng + ',' + r.point.lat);
              
             marker.enableDragging(); //标注可拖拽
             //marker.disableDragging();           // 不可拖拽

             // 开启事件监听
             marker.addEventListener("dragend", function (e) {

                 var x = e.point.lng; //经度
                 var y = e.point.lat; //纬度
                 alert("拖到的地点的经纬度:" + x + "," + y);

             });
         }
         else {
             alert('failed' + this.getStatus());
         }
     }, { enableHighAccuracy: true })


        //关于状态码
        //BMAP_STATUS_SUCCESS 检索成功。对应数值“0”。
        //BMAP_STATUS_CITY_LIST 城市列表。对应数值“1”。
        //BMAP_STATUS_UNKNOWN_LOCATION 位置结果未知。对应数值“2”。
        //BMAP_STATUS_UNKNOWN_ROUTE 导航结果未知。对应数值“3”。
        //BMAP_STATUS_INVALID_KEY 非法密钥。对应数值“4”。
        //BMAP_STATUS_INVALID_REQUEST 非法请求。对应数值“5”。
        //BMAP_STATUS_PERMISSION_DENIED 没有权限。对应数值“6”。(自 1.1 新增)
        //BMAP_STATUS_SERVICE_UNAVAILABLE 服务不可用。对应数值“7”。(自 1.1 新增)
        //BMAP_STATUS_TIMEOUT 超时。对应数值“8”。(自 1.1 新增)
    </script>

    在线查看:http://niaoren.niunan.net/drop_baidumap.html

  • 相关阅读:
    平衡树之splay BZOJ3224 普通平衡树
    线段树 洛谷P1531 I Hate It
    倍增LCA code[vs]1036商务旅行
    线段树 hdu1698 Just a Hook
    猥琐的暴搜 NOIP2011 Mayan游戏
    [BZOJ2301][HAOI2011]Problem b
    [BZOJ1101][POI2007]Zap
    [BZOJ1100][POI2007]对称轴osi
    [BZOJ3167][Heoi2013]Sao
    [BZOJ3039]玉蟾宫
  • 原文地址:https://www.cnblogs.com/niunan/p/6822124.html
Copyright © 2011-2022 走看看