百度官方GPS定位官方Demo

1 篇文章 0 订阅
1 篇文章 0 订阅

CSDN没积分,又没有钱的看这里,找到了一个GitHub上的一个免费的Demo:https://github.com/YoungBear/BaiduLocDemo

该GitHub连接引用于博客:https://blog.csdn.net/Next_Second/article/details/77540204

(注:libs中引用的库一定是百度官方的最新版本的库,否则可能出现地图不显示)

里面有

基础定位功能:

配置定位参数:

自定义回调示例:

连续定位示例:

位置消息提醒:

室内定位功能:

判断移动热点:

android 8.0后台定位示例:

常见问题说明:

 

现在没时间,之后再加图片示例

使用GPS 定位,首先,需要在清单文件(AndroidManifest.xml)中注册获取定位的权限: **1.获取位置管理器对象LocationManager** ``` import android.location.LocationManager; LocationManager lm; // lm =(LocationManager) this.getSystemService(Context`.LOCATION_SERVICE); // ``` **2.一般使用LocationManager的getLastKnownLocation(LocationManager.GPS_PROVIDER);方法获取Location对象** ``` String provider = LocationManager.GPS_PROVIDER;// 指定LocationManager的定位方法 Location location = locationManager.getLastKnownLocation(provider);// 调用getLastKnownLocation()方法获取当前的位置信息 ``` 不过不建议用这种方法,有几点原因: 一,在很多提供定位服务的应用程序中,不仅需要获取当前的位置信息,还需要监视位置的变化,在位置改变时调用特定的处理方法 ,其中LocationManager提供了一种便捷、高效的位置监视方法requestLocationUpdates(),可以根据位置的距离变化和时间间隔设定,产生位置改变事件的条件,这样可以避免因微小的距离变化而产生大量的位置改变事件 。 二,当你开启GPS,provider的值为GPS。这时的定位方式为GPS,由于GPS定位慢,所以它不可能立即返回你一个Location对象,所以就返回null了。 **3.推荐locationManager.requestLocationUpdates();方法** LocationManager中设定监听位置变化的代码如下: ``` lm.requestLocationUpdates(LocationManager.GPS_PROVIDER, 2000, 10,new MyLocationListener()); ```
1. 引入百度地图API的JS文件 ```html <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=你的AK值"></script> ``` 其中,AK值需要在百度地图开放平台申请获得。 2. 创建地图对象 ```javascript var map = new BMap.Map("container"); // container为地图容器的ID值 ``` 3. 启用GPS定位 ```javascript var geolocation = new BMap.Geolocation(); geolocation.getCurrentPosition(function(r){ if(this.getStatus() == BMAP_STATUS_SUCCESS){ var mk = new BMap.Marker(r.point); map.addOverlay(mk); map.panTo(r.point); } else { alert('failed'+this.getStatus()); } },{enableHighAccuracy: true}) ``` 其中,BMap.Geolocation()为百度地图API提供的GPS定位功能,getCurrentPosition()为获取当前位置信息的方法。如果定位成功,将当前位置标记在地图上,并将地图中心点设置为当前位置。如果定位失败,弹出提示框。 完整代码如下: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>百度地图GPS定位</title> <style type="text/css"> html,body,#container{ width:100%; height:100%; margin:0; font-family:"微软雅黑"; } </style> <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=你的AK值"></script> </head> <body> <div id="container"></div> <script type="text/javascript"> // 创建地图对象 var map = new BMap.Map("container"); // 启用GPS定位 var geolocation = new BMap.Geolocation(); geolocation.getCurrentPosition(function(r){ if(this.getStatus() == BMAP_STATUS_SUCCESS){ var mk = new BMap.Marker(r.point); map.addOverlay(mk); map.panTo(r.point); } else { alert('failed'+this.getStatus()); } },{enableHighAccuracy: true}) </script> </body> </html> ``` 注意事项: 1. 需要在HTTPS环境下使用GPS定位功能。 2. 定位功能需要用户授权,浏览器会弹出提示框,用户需要点击允许才能使用定位功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值