百度地图API之百度地图退拽标记点获取经纬度的实现代码

转至 https://www.jb51.net/article/102887.htm
本文给大家分享百度地图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 {
            width: 100%;
            height: 100%;
            margin: 0;
            font-family: "微软雅黑";
        }

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

        #r-result {
            width: 100%;
        }
    </style>
    <script type="text/javascript"
            src="http://api.map.baidu.com/api?v=3.0&ak=nXGqtIcvGfaq3jhvZQ6lKf4kmuDAKFHn"></script>
    <title>设置点是否可拖拽</title>
</head>
<body>
    <div id="l-map"></div>
    <input id="l-map-lng" type="text" />
    <input id="l-map-lat" type="text" />
</body>
</html>
<script type="text/javascript">
    // 百度地图API功能
    var map = new BMap.Map("l-map");
    var point = new BMap.Point(116.400244, 39.92556);
    map.centerAndZoom(point, 12);
    var marker = new BMap.Marker(point);// 创建标注
    map.addOverlay(marker);  // 将标注添加到地图中
    marker.enableDragging();
    marker.addEventListener("dragend", function (e) { //拖动事件
        document.getElementById("l-map-lng").value = e.point.lng;
        document.getElementById("l-map-lat").value = e.point.lat; //打印拖动结束坐标
    });    </script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以通过以下步骤实现百度地图API多个渲染路径: 1. 获取多个经纬度坐标,可以通过百度地图API的搜索服务、定位服务或者手动输入获取。 2. 根据获取经纬度坐标,在地图标记多个,可以使用百度地图API的覆盖物(marker)功能实现。 3. 使用百度地图API的路线规划服务,根据多个经纬度坐标计算出路径,生成路线规划结果。 4. 将路线规划结果显示在地图上,可以使用百度地图API的折线(polyline)功能实现。 以下是示例代码: ```javascript // 多个经纬度坐标 var points = [ new BMap.Point(116.404, 39.915), new BMap.Point(116.407, 39.920), new BMap.Point(116.410, 39.912) ]; // 在地图标记多个 for (var i = 0; i < points.length; i++) { var marker = new BMap.Marker(points[i]); map.addOverlay(marker); } // 创建路线规划服务实例 var driving = new BMap.DrivingRoute(map, { renderOptions: { map: map, autoViewport: true } }); // 根据多个经纬度坐标计算路径 driving.search(points[0], points[points.length - 1], { waypoints: points.slice(1, -1) }); // 显示路线规划结果 driving.setSearchCompleteCallback(function () { var path = driving.getResults().getPlan(0).getRoute(0).getPath(); var polyline = new BMap.Polyline(path, { strokeColor: "#FF0000", strokeWeight: 3, strokeOpacity: 0.5 }); map.addOverlay(polyline); }); ``` 其中,`points`数组中的每个元素都是一个`BMap.Point`对象,表示一个经纬度坐标。`driving`是一个`BMap.DrivingRoute`对象,用于计算路线规划结果。`driving.search`方法用于计算路径,其中第一个参数为起坐标,第二个参数为终坐标,第三个参数`waypoints`为途经坐标数组。`driving.setSearchCompleteCallback`方法用于设置计算完成后的回调函数,该回调函数中可以获取到路线规划结果`path`,并用`BMap.Polyline`对象将其显示在地图上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值