利用高德地图api进行定位

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

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

1.首先引入高德地图api

<script type="text/javascript" src="http://webapi.amap.com/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就使用上一次存储的city
				var xcity = localStorage.getItem("xcity") 
			} else {   //否则重新定位
				map.plugin('AMap.Geolocation', function() {
					geolocation = new AMap.Geolocation({
						enableHighAccuracy: true, //是否使用高精度定位,默认:true
						timeout: 10000, //超过10秒后停止定位,默认:无穷大
						noIpLocate: 0,
						maximumAge: 0, //定位结果缓存0毫秒,默认:0
						convert: true, //自动偏移坐标,偏移后的坐标为高德坐标,默认:true
						showButton: false, //显示定位按钮,默认:true
						buttonPosition: 'LB', //定位按钮停靠位置,默认:'LB',左下角
						buttonOffset: new AMap.Pixel(10, 20), //定位按钮与设置的停靠位置的偏移量,默认:Pixel(10, 20)
						showMarker: false, //定位成功后在定位到的位置显示点标记,默认:true
						showCircle: false, //定位成功后用圆圈表示定位精度范围,默认:true
						panToLocation: false, //定位成功后将定位到的位置作为地图中心点,默认:true
						zoomToAccuracy: 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就使用上一次存储的city
				var 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

猜你喜欢

转载自blog.csdn.net/yuyuking/article/details/80005801