AngularJS进阶(十九)在AngularJS应用中集成百度地图实现定位功能_angular gps代码

最后

喜欢的话别忘了关注、点赞哦~

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

前端校招面试题精编解析大全

	/*
	 * 获取地理位置信息
	 */
	$rootScope.getAddr = function() {
		console.log("定位操作ing..............");
		/*-------------------- 利用百度API定位 ------------------------*/
		var geolocation = new BMap.Geolocation();
		geolocation.getCurrentPosition(
			//获取位置信息成功
			function(position){
				if(this.getStatus() == BMAP_STATUS_SUCCESS){
	//				alert('您的位置:' + position.point.lng + ',' + position.point.lat);
					$rootScope.longitude = position.point.lng;
					$rootScope.latitude  = position.point.lat;
					// 根据坐标得到地址描述    
					$rootScope.getGeo();
				} else {
					alert('无法获取定位信息,可能影响对服务药店的筛选');
				}        
			},{
				// 指示浏览器获取高精度的位置,默认为false
				enableHighAccuracy: true,
				// 指定获取地理位置的超时时间,默认不限时,单位为毫秒
	//	        timeout: 5000,
				// 最长有效期(30S),在重复获取地理位置时,此参数指定多久再次获取位置
		        maximumAge: 30*1000
    		});
	};

HTML5地理位置功能源码分析

源代码如下所示:

<!--百度地图-->
<script src="http://api.map.baidu.com/components?ak=bOwh2i9zIWG7Ucl8xPitV2TM&v=1.0">
</script>
/*
 * 获取地理位置信息
 */
$rootScope.getAddr = function() {
if (navigator.geolocation) {
navigator.geolocation.getCurrentPosition(
//获取位置信息成功
function(position) {
$rootScope.latitude = position.coords.latitude;
$rootScope.longitude = position.coords.longitude;
var myGeo = new BMap.Geocoder();
//根据坐标得到地址描述    
$rootScope.getGeo();
},
//获取位置信息失败
function(error) {
switch (error.code) {
case error.PERMISSION_DENIED:
$rootScope.showAlert("请打开设备定位功能!");
break;
case error.POSITION_UNAVAILABLE:
$rootScope.showAlert("定位信息不可用!");
break;
case error.TIMEOUT:
$rootScope.showAlert("定位请求超时!");
break;
case error.UNKNOWN_ERROR:
$rootScope.showAlert("未知错误!");
break;
}
},
{
        // 指示浏览器获取高精度的位置,默认为false
        enableHighAccuracy: true,
        // 指定获取地理位置的超时时间,默认不限时,单位为毫秒
        timeout: 5000,
        // 最长有效期,在重复获取地理位置时,此参数指定多久再次获取位置。
        maximumAge: 3000
    });
} else {
$rootScope.showAlert("您的设备不支持GPS定位!");
}
};
 
$rootScope.getAddr();
 
$rootScope.getGeo = function() {
var myGeo = new BMap.Geocoder();
// 根据坐标得到地址描述    
myGeo.getLocation(new BMap.Point($rootScope.longitude, $rootScope.latitude), function(result) {
if (result) {
console.log(JSON.stringify(result));
$rootScope.geoaddress = {
'fulladdress': result.addressComponents.city + result.addressComponents.district + result.addressComponents.street,
'city': result.addressComponents.city,
'area': result.addressComponents.district,
'street': result.addressComponents.street,
};
console.log(JSON.stringify($rootScope.geoaddress));
}else {
$rootScope.showAlert("定位失败,地址解析失败");
}
});
};

感悟

通过阅读参考资料3,得知上面使用的定位方式是采用的 HTML5 的地理位置功能。

注:

总的来说,在PC的浏览器中 HTML5 的地理位置功能获取的位置精度不够高,如果借助这个 HTML5 特性做一个城市天气预报是绰绰有余,但如果是做一个地图应用,那误差还是太大了。不过,如果是移动设备上的 HTML5 应用,可以通过设置 enableHighAcuracy 参数为 true,调用设备的 GPS 定位来获取高精度的地理位置信息。

附:

手机定位方式汇总

GPS,基站,Wi-Fi等多种定位方式

什么是GPS定位、基站定位和Wi-Fi定位?

1、GPS定位:根据设备GPS芯片和GPS卫星实现定位,GPS定位在室内是不可以使用的。GPS定位精度和芯片本身以及实际使用环境有关,一般情况下,GPS定位精度在10m左右。

2、基站定位:根据设备获取的基站信息实现定位,基站定位精度一般不受使用环境影响,主要和基站的覆盖半径有关。百度的基站定位服务精度目前在200m左右。

3、Wi-Fi定位:根据设备获取的Wi-Fi的信息进行定位,Wi-Fi定位精度一般不受使用环境影响,主要和Wi-Fi半径,密度有关。百度的Wi-Fi定位精度目前在20m左右。

疑问

如何判断手机的定位方式?

css

1,盒模型
2,如何实现一个最大的正方形
3,一行水平居中,多行居左
4,水平垂直居中
5,两栏布局,左边固定,右边自适应,左右不重叠
6,如何实现左右等高布局
7,画三角形
8,link @import导入css
9,BFC理解

js

1,判断 js 类型的方式
2,ES5 和 ES6 分别几种方式声明变量
3,闭包的概念?优缺点?
4,浅拷贝和深拷贝
5,数组去重的方法
6,DOM 事件有哪些阶段?谈谈对事件代理的理解
7,js 执行机制、事件循环
8,介绍下 promise.all
9,async 和 await,
10,ES6 的 class 和构造函数的区别
11,transform、translate、transition 分别是什么属性?CSS 中常用的实现动画方式,
12,介绍一下rAF(requestAnimationFrame)
13,javascript 的垃圾回收机制讲一下,
14,对前端性能优化有什么了解?一般都通过那几个方面去优化的?

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

的垃圾回收机制讲一下,
14,对前端性能优化有什么了解?一般都通过那几个方面去优化的?

[外链图片转存中…(img-aWSk93L1-1715773817633)]

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值