100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > 百度地图拖动标注后获取坐标

百度地图拖动标注后获取坐标

时间:2020-09-09 02:26:25

相关推荐

百度地图拖动标注后获取坐标

本来想用图吧的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 {

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./api?v=2.0&ak=fjEOTea6oQGEcK1GSUHruG4efO9fccei"></script>

<title>设置点是否可拖拽</title>

</head>

<body>

<div id="l-map"></div>

<!--<div id="r-result">

<input type="button" οnclick="marker.enableDragging();" value="可拖拽" />

<input type="button" οnclick="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>

在线查看:/drop_baidumap.html

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。