1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 利用高德地图api进行定位

利用高德地图api进行定位

时间:2019-02-03 08:52:25

相关推荐

利用高德地图api进行定位

一、精准定位,需要https,需要用户手动同意。

在初次进入时进行定位,定位成功,保存定位所在城市。再次进入不定位,使用上一次的定位。

1.首先引入高德地图api

<script type="text/javascript" src="/maps?v=1.4.1&key=你自己的key"></script>

2.在页面加入一个div

<div id="container" style="display: none;"></div>

3.定位

var map = new AMap.Map('container', {resizeEnable: true});//定位if(localStorage.getItem("xcity") != null || localStorage.getItem("xcity") != "") {//如果存储了city就使用上一次存储的cityvar xcity = localStorage.getItem("xcity") } else { //否则重新定位map.plugin('AMap.Geolocation', function() {geolocation = new AMap.Geolocation({enableHighAccuracy: true, //是否使用高精度定位,默认:truetimeout: 10000, //超过10秒后停止定位,默认:无穷大noIpLocate: 0,maximumAge: 0, //定位结果缓存0毫秒,默认:0convert: true, //自动偏移坐标,偏移后的坐标为高德坐标,默认:trueshowButton: false, //显示定位按钮,默认:truebuttonPosition: 'LB', //定位按钮停靠位置,默认:'LB',左下角buttonOffset: new AMap.Pixel(10, 20), //定位按钮与设置的停靠位置的偏移量,默认:Pixel(10, 20)showMarker: false, //定位成功后在定位到的位置显示点标记,默认:trueshowCircle: false, //定位成功后用圆圈表示定位精度范围,默认:truepanToLocation: false, //定位成功后将定位到的位置作为地图中心点,默认:truezoomToAccuracy: false //定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false});map.addControl(geolocation);geolocation.getCurrentPosition();AMap.event.addListener(geolocation, 'complete', onComplete); //返回定位信息AMap.event.addListener(geolocation, 'error', onError); //返回定位出错信息});function onComplete(data) {var xcity = data.addressComponent.city //定位的城市名称//经纬度var lng = data.position.getLng()var lat = data.position.getLat()localStorage.setItem("xcity", xcity) //把定位存在localStorage,下次进入不会重新定位}//解析定位错误信息function onError(data) {//alert("定位失败")var xcity = "青岛市" //在这里可以添加一个默认城市,在定位出错之后使用此默认城市(或者返回定位出错)}}

//在这里写获取定位之后的ajax//比如获取离我最近的景点地区

4.在手动选择城市之后更改localStorage

二、只获得城市的定位,缺点:不精准,有几率出错。优点:不弹窗,http也可以使用

1.2.4.同上

3.定位

if(localStorage.getItem("xcity") == null || localStorage.getItem("xcity") == "") { //如果存储了city就使用上一次存储的cityvar xcity = localStorage.getItem("xcity")} else { //否则重新定位map.getCity(function(data) {if(data['province'] && typeof data['province'] === 'string') {var xcity = data['city'] || data['province']localStorage.setItem("xcity", xcity) //把定位存在localStorage,下次进入不会重新定位}});}//写获取定位之后的ajax

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