Android 位置服务——BaiduLocation的使用

Android 位置服务——BaiduLocation的使用
原文:Android 位置服务——BaiduLocation的使用

版权声明:本文为博主原创文章,欢迎转载,转载请在文章显眼处说明文章出处并给出连接。 https://blog.csdn.net/To_be_Designer/article/details/48685475

  这一节我们使用Baidu的定位服务,我们同样要向上一篇博客一样下载Baidu定位的SDK。因为在《Android 位置服务——BaiduMap的使用 》这篇博客中我们已经讲过下载步骤,这里我们不在重复讲解下载的过程,不明白的可以直接去上一篇博客中学习。
  这一节的讲解是以上一节中百度地图为基础的,使用的是上一节的项目工程。建议大家先看一下《Android 位置服务——BaiduMap的使用 》。

  其实这里的步骤和Baidu定位中提供的文档是差不多的,此处整理的目的只为加深楼主的印象。

Baidu定位环境配置

1. 首先将jar包拷贝到libs文件夹下。
2. 通过Android Studio “File——>Project Structure——>Dependencies”中的File Dependency将我们刚才拷贝的.jar包导入。
3. 其次在main文件夹下创建一个“jniLibs”的文件夹,将包含.so文件的文件夹复制到此处。
4. 配置AndroidManifext.xml.

  • 在application标签中声明service组件,每个app拥有自己单独的定位service
 <service
            android:name="com.baidu.location.f"android:enabled="true"android:process=":remote"></service>
  • 设置AcessKey
<meta-data
            android:name="com.baidu.lbsapi.API_KEY"android:value="key" />
  • 声明权限
<!-- 这个权限用于进行网络定位-->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"></uses-permission>
<!-- 这个权限用于访问GPS定位-->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
<!-- 用于访问wifi网络信息,wifi信息会用于进行网络定位-->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
<!-- 获取运营商信息,用于支持提供运营商信息相关的接口-->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
<!-- 这个权限用于获取wifi的获取权限,wifi信息会用来进行网络定位-->
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission>
<!-- 用于读取手机当前的状态-->
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
<!-- 写入扩展存储,向扩展卡写入数据,用于写入离线定位数据-->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<!-- 访问网络,网络定位需要上网-->
<uses-permission android:name="android.permission.INTERNET" />
<!-- SD卡读取权限,用户写入离线定位数据-->
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"></uses-permission>

Baidu定位使用

  再次声明下这里使用的项目是基于《Android 位置服务——BaiduMap的使用 》这篇博客的,在此基础上进行定位功能呢的添加。

1.初始化LocationClient类。

public LocationClient mLocationClient = null;
public BDLocationListener myListener = new MyLocationListener();public void onCreate() {mLocationClient = new LocationClient(getApplicationContext());     //声明LocationClient类mLocationClient.registerLocationListener( myListener );    //注册监听函数//以上两句卸载setContentView(R.layout.activity_main)之前。
}

2. 配置定位SDK参数。

private void initLocation(){LocationClientOption option = new LocationClientOption();option.setLocationMode(LocationMode.Hight_Accuracy
);//可选,默认高精度,设置定位模式,高精度,低功耗,仅设备option.setCoorType("bd09ll");//可选,默认gcj02,设置返回的定位结果坐标系int span=1000;option.setScanSpan(span);//可选,默认0,即仅定位一次,设置发起定位请求的间隔需要大于等于1000ms才是有效的option.setIsNeedAddress(true);//可选,设置是否需要地址信息,默认不需要option.setOpenGps(true);//可选,默认false,设置是否使用gpsoption.setLocationNotify(true);//可选,默认false,设置是否当gps有效时按照1S1次频率输出GPS结果option.setIsNeedLocationDescribe(true);//可选,默认false,设置是否需要位置语义化结果,可以在BDLocation.getLocationDescribe里得到,结果类似于“在北京天安门附近”option.setIsNeedLocationPoiList(true);//可选,默认false,设置是否需要POI结果,可以在BDLocation.getPoiList里得到
option.setIgnoreKillProcess(false);//可选,默认false,定位SDK内部是一个SERVICE,并放到了独立进程,设置是否在stop的时候杀死这个进程,默认杀死option.SetIgnoreCacheException(false);//可选,默认false,设置是否收集CRASH信息,默认收集
option.setEnableSimulateGps(false);//可选,默认false,设置是否需要过滤gps仿真结果,默认需要mLocationClient.setLocOption(option);}

高精度定位模式:这种定位模式下,会同时使用网络定位和GPS定位,优先返回最高精度的定位结果;

低功耗定位模式:这种定位模式下,不会使用GPS,只会使用网络定位(Wi-Fi和基站定位);

仅用设备定位模式:这种定位模式下,不需要连接网络,只使用GPS进行定位,这种模式下不支持室内环境的定位。

3. 实现BDLocationListener接口,在舰艇中对定位进行处理。这里我们做的处理是在定位处方放置定位符号,并添加连线。

        @Overridepublic void onReceiveLocation(BDLocation location) {if (location.getLocType() == BDLocation.TypeServerError) {} else if (location.getLocType() == BDLocation.TypeNetWorkException) {} else if (location.getLocType() == BDLocation.TypeCriteriaException) {} else {mTextViewLocation.setText(location.getAddress().address);currentLongtitude = location.getLongitude();currentLatitude = location.getLatitude();mBaiduMap.addOverlay(new MarkerOptions().position(new LatLng(currentLatitude, currentLongtitude)).icon(BitmapDescriptorFactory.fromResource(R.mipmap.icon_marka)));LatLng p = new LatLng(currentLatitude, currentLongtitude);points.add(p);}}}

结果如下:

这里写图片描述

全部代码如下:

public class MainActivity extends Activity implements View.OnClickListener {private Button mButtonStart;//开始定位按钮private Button mButtonOne;//获取地址一按钮private Button mButtonTwo;//获取地址二按钮private Button mButtonLine;//划线按钮private TextView mTextViewLocation;//显示当前的地址MapView mMapView = null;//地图视图BaiduMap mBaiduMap;//地图对象//连线点的集合private List<LatLng> points = new ArrayList<LatLng>();//通过地址获得经纬度GeoCoder mSearch = null; // 搜索模块,也可去掉地图模块独立使用public LocationClient mLocationClient = null;public BDLocationListener myListener = new MyLocationListener();@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);//定位mLocationClient = new LocationClient(getApplicationContext());     //声明LocationClient类mLocationClient.registerLocationListener(myListener);    //注册监听函数//使用BaiduMap  SDK//在使用SDK各组件之前初始化context信息,传入ApplicationContextSDKInitializer.initialize(getApplicationContext());setContentView(R.layout.activity_main);//获取地图控件引用mMapView = (MapView) findViewById(R.id.bmapView);//获得地图视图的对象mBaiduMap = mMapView.getMap();//获得地图对象//初始化搜索模块,注册事件监听mSearch = GeoCoder.newInstance();//获得搜索的对象mSearch.setOnGetGeoCodeResultListener(new OnGetGeoCoderResultListener() {@Overridepublic void onGetGeoCodeResult(GeoCodeResult geoCodeResult) {if (geoCodeResult == null || geoCodeResult.error != SearchResult.ERRORNO.NO_ERROR) {Toast.makeText(MainActivity.this, "抱歉,未能找到结果", Toast.LENGTH_LONG).show();return;}mBaiduMap.addOverlay(new MarkerOptions().position(geoCodeResult.getLocation()).icon(BitmapDescriptorFactory.fromResource(R.mipmap.icon_marka)));mBaiduMap.setMapStatus(MapStatusUpdateFactory.newLatLng(geoCodeResult.getLocation()));LatLng p = new LatLng(geoCodeResult.getLocation().latitude, geoCodeResult.getLocation().longitude);//添加点points.add(p);String strInfo = String.format("纬度:%f 经度:%f",geoCodeResult.getLocation().latitude, geoCodeResult.getLocation().longitude);Log.d("data", strInfo);Toast.makeText(MainActivity.this, strInfo, Toast.LENGTH_LONG).show();}@Overridepublic void onGetReverseGeoCodeResult(ReverseGeoCodeResult reverseGeoCodeResult) {}});//获取布局中的各个控件对象mButtonStart = (Button) findViewById(R.id.button_start);mButtonOne = (Button) findViewById(R.id.button_one);mButtonTwo = (Button) findViewById(R.id.button_two);mButtonLine = (Button) findViewById(R.id.button_three);mTextViewLocation = (TextView) findViewById(R.id.textview_location);//设置点击事件mButtonStart.setOnClickListener(this);mButtonOne.setOnClickListener(this);mButtonTwo.setOnClickListener(this);mButtonLine.setOnClickListener(this);PushManager.startWork(getApplicationContext(), PushConstants.LOGIN_TYPE_API_KEY, "5CjXwt6IZgRSfYxwA8dtOuG5");}/*Activity关闭时将地图关闭*/@Overrideprotected void onDestroy() {super.onDestroy();//在activity执行onDestroy时执行mMapView.onDestroy(),实现地图生命周期管理mMapView.onDestroy();}/*ActivityonResume时,将地图onResume。*/@Overrideprotected void onResume() {super.onResume();//在activity执行onResume时执行mMapView. onResume (),实现地图生命周期管理mMapView.onResume();}/*ActivityonPause时,将地图onPause。*/@Overrideprotected void onPause() {super.onPause();//在activity执行onPause时执行mMapView. onPause (),实现地图生命周期管理mMapView.onPause();}/*初始化定位*/private void initLocation() {LocationClientOption option = new LocationClientOption();option.setLocationMode(LocationClientOption.LocationMode.Hight_Accuracy);//可选,默认高精度,设置定位模式,高精度,低功耗,仅设备option.setCoorType("bd09ll");//可选,默认gcj02,设置返回的定位结果坐标系int span = 1000;option.setScanSpan(span);//可选,默认0,即仅定位一次,设置发起定位请求的间隔需要大于等于1000ms才是有效的option.setIsNeedAddress(true);//可选,设置是否需要地址信息,默认不需要option.setOpenGps(true);//可选,默认false,设置是否使用gpsoption.setLocationNotify(true);//可选,默认false,设置是否当gps有效时按照1S1次频率输出GPS结果option.setIsNeedLocationDescribe(true);//可选,默认false,设置是否需要位置语义化结果,可以在BDLocation.getLocationDescribe里得到,结果类似于“在北京天安门附近”option.setIsNeedLocationPoiList(true);//可选,默认false,设置是否需要POI结果,可以在BDLocation.getPoiList里得到option.setIgnoreKillProcess(false);//可选,默认false,定位SDK内部是一个SERVICE,并放到了独立进程,设置是否在stop的时候杀死这个进程,默认杀死option.SetIgnoreCacheException(false);//可选,默认false,设置是否收集CRASH信息,默认收集option.setEnableSimulateGps(false);//可选,默认false,设置是否需要过滤gps仿真结果,默认需要mLocationClient.setLocOption(option);}@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.button_start:initLocation();mLocationClient.start();//开始定位break;case R.id.button_one://获得天安门的地址mSearch.geocode(new GeoCodeOption().city("北京市").address("海淀区中关村海龙大厦"));break;case R.id.button_two://获得中关村的地址mSearch.geocode(new GeoCodeOption().city("北京市").address("西城区西便门"));break;case R.id.button_three://获得当地的地址// 添加折线OverlayOptions ooPolyline = new PolylineOptions().width(10).color(0xAAFF0000).points(points);mBaiduMap.addOverlay(ooPolyline);break;}}//获得当前的经纬度private double currentLongtitude;private double currentLatitude;class MyLocationListener implements BDLocationListener {@Overridepublic void onReceiveLocation(BDLocation location) {if (location.getLocType() == BDLocation.TypeServerError) {} else if (location.getLocType() == BDLocation.TypeNetWorkException) {} else if (location.getLocType() == BDLocation.TypeCriteriaException) {} else {mTextViewLocation.setText(location.getAddress().address);currentLongtitude = location.getLongitude();currentLatitude = location.getLatitude();mBaiduMap.addOverlay(new MarkerOptions().position(new LatLng(currentLatitude, currentLongtitude)).icon(BitmapDescriptorFactory.fromResource(R.mipmap.icon_marka)));LatLng p = new LatLng(currentLatitude, currentLongtitude);points.add(p);}}}
}
posted on 2018-09-21 16:54 NET未来之路 阅读(...) 评论(...) 编辑 收藏

转载于:https://www.cnblogs.com/lonelyxmas/p/9687386.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/464917.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

推挽输出和开漏输出的区别

https://zhuanlan.zhihu.com/p/41942876

asp.net通过登录后修改个人信息_微信号终于可以修改了!快来改一个

上周&#xff0c;微信在安卓端开启了“修改微信号”功能的灰度测试&#xff0c;这也预示着这项新功能很快就能和我们见面了。果不其然&#xff0c;就在刚才微信正式上线了修改微信号的功能&#xff0c;大家期盼多年的功能终于上线了&#xff01;&#xff01;&#xff01;安卓用…

python进程池pool_python多任务--进程池Pool

进程池Pool在利用Python进行系统管理的时候&#xff0c;特别是同时操作多个文件目录&#xff0c;或者远程控制多台主机&#xff0c;并行操作可以节约大量的时间。当被操作对象数目不大时&#xff0c;可以直接利用multiprocessing中的Process动态成生多个进程&#xff0c;但如果…

数据集 结构化数据

数据集 一个数据的集和&#xff0c;每一行是一条数据记录&#xff0c;每一列是一个字段。 我们把表中的每一行叫做一个“记录”&#xff0c;每一个记录包含这行中的所有信息&#xff0c;就像在通讯录数据库中某个人全部的信息。字段是比记录更小的单位&#xff0c;字段集合组成…

STM32 ADC 单次模式、连续模式、扫描模式(转载)

ADC单通道&#xff1a; 要求进行一次ADC转换&#xff1a;配置为单次模式使能&#xff0c;扫描模式失能。这样ADC的这个通道&#xff0c;转换一次后&#xff0c;就停止转换。 要求进行连续ADC转换&#xff1a;配置为连续模式使能&#xff0c;扫描模式失能。这样ADC的这个通道&…

LeetCode:验证回文串【125】

LeetCode&#xff1a;验证回文串【125】 题目描述 给定一个字符串&#xff0c;验证它是否是回文串&#xff0c;只考虑字母和数字字符&#xff0c;可以忽略字母的大小写。 说明&#xff1a;本题中&#xff0c;我们将空字符串定义为有效的回文串。 示例 1: 输入: "A man, a …

一些好玩的创客玩件

桌面天气预报站&#xff1a;https://mc.dfrobot.com.cn/thread-311127-1-1.html

云数据中心网络遇到的问题_云数据中心面临安全问题,华为SDN解决方案有一个安全大脑...

CNET科技资讯网 9月23日 北京消息(文/周雅)&#xff1a;当越来越多的企业开始采用云服务&#xff0c;安全问题往往成为待考虑的问题。在传统IT环境中&#xff0c;企业默认的逻辑架构是可信的&#xff0c;数据在自己手里&#xff0c;系统部署在自己的数据中心&#xff0c;有自己…

会唱歌的路

文 | 贰沐编辑 | 贰沐 子鱼会唱歌的路&#xff1f;&#xff01;是什么意思&#xff1f;是说路会自己唱歌吗&#xff1f;开车行驶在普通的道路上&#xff0c;我们能够听到“嗡嗡”的各种杂乱无章的声音&#xff0c;而在有些特殊的路上&#xff0c;我们可以听到路面在发出有节奏的…

linux查看wifi信号命令_使用Nmcli命令从Linux终端连接WiFi

i使用Nmcli命令从Linux终端连接WiFi在linux系统中有几种用于管理无线网络接口的命令行工具。 其中的一些可用于简单查看无线网络接口状态(无论是启动还是关闭 &#xff0c;或者是否连接到任何网络)&#xff0c;如iw &#xff0c; iwlist &#xff0c; ip &#xff0c; ifconfig…

Modbus crc16校验

CRC-16 / MODBUS &#xff1a; 1&#xff09;CRC寄存器初始值为 FFFF&#xff1b;即16位全为1&#xff1b; 2&#xff09;CRC-16 / MODBUS的多项式A001H (1010 0000 0000 0001B) ‘H’表示16进制数&#xff0c;‘B’表示二进制数 计算步骤为&#xff1a; (1).预置 16 位寄存…

我的前同事,阿里大牛的技术感悟

以下内容转自前同事现阿里技术大牛-王怀利——现在想想&#xff0c;从业十年了&#xff0c;现在做的活&#xff0c;都不如我大学的时候做的项目&#xff0c;那么具有“技术含量”和挑战。一个是&#xff0c;我用最便宜的12M单片机开发的计时算法&#xff0c;帮老师赚了一笔钱。…

算法熟记-排序系列-堆排序

1. 简述 假设待排序数组为 int array[], 数组长度为n。 主要是利用堆的性质。对于升序排序&#xff0c;使用最大堆。 首先&#xff0c;建堆&#xff0c;使用递归后根序遍历得方法&#xff0c;通过交换元素&#xff0c;保证根元素比孩子元素大。 第1趟&#xff0c;堆顶…

oracle入库的速度能到多少_多线程能提高Oracle的入库速度吗

多线程能提高Oracle的入库速度吗最近常常和同事们讨论“系统架构”&#xff0c;其中有不免提到如何使用“多线程”来改善系统性能。有些同事普遍有一种“认为”&#xff1a;他们认为“多线程”是改善系统性能的“灵丹妙药”&#xff0c;他们简单的认为&#xff0c;“多线程”导…

数据结构-- 线性表之链式存储

https://www.cnblogs.com/ZWOLF/p/10604252.html

那些年,我和发哥在恒大的日子

在广州上班那会&#xff0c;我们在恒大中心旁边的利通大厦上班&#xff0c;我和薛总每天一起上下班&#xff0c;那时候宿舍还有盼盼&#xff0c;有时候玩开心的时候&#xff0c;我就会跟他们说&#xff0c;等过了很多年后&#xff0c;我们要写一本说&#xff0c;书的名字就叫做…

十六进制转化为十进制

package lsh.element.numbersystem;import java.util.Scanner;/*** * desc 有意思的地方&#xff1a;两种思想得到的结果都是正确的&#xff0c;但是超出int类型最大之后&#xff0c;错误值却不同* * author * LSH* 2018年9月23日*/ public class HexToDecimalConver…

回来了

三年了 又回来了 未来去哪里转载于:https://blog.51cto.com/itcnjd/589429

KEIL高级调试——条件断点

在线调试程序时&#xff0c;打断点是非常有效的一种方式&#xff0c;配合单步调试&#xff0c;可以快速定位问题。但是有时候&#xff0c;手动打断点用起来不是那么方便。比如想要在一个循环的第N次停下来&#xff0c;如果手动打断点&#xff0c;那就要不停的点击单步运行&…

emailjava中怎么校验_Java使用注解实现参数统一校验功能

在项目开发中&#xff0c;当使用配置文件的时候&#xff0c;需要对一些配置参数进行合法校验&#xff0c;如果不存在则会抛出异常或者提醒用户重新修改配置文件后运行系统。 以前的做法就是读取到配置文件后&#xff0c;每个配置项挨个检查&#xff0c;写多个if判断是否存在问题…