废话
今天我们开始集成百度地图AR识别SDK(后面简称AR SDK)的第二章,这一章我们主要讲Android Studio如何配置AR SDK
我们如果单单只看文档的话,很难看懂如何集成,我们需要结合官网的给的demo去集成,但是这里我参考官网的demo集成完成了,所以就看我如何集成
注册开发者账号
这是第一步,我们要有了自己的开发者账号才能继续进行下一步
打开百度地图开发者官网,使用自己的百度账号登录,如何没有就注册一个
创建应用
注册完成之后,我们就可以打开右上角账号信息旁边的控制台,然后点击创建应用
image.png
点击之后会出现下图所示内容
image.png我们填写相应的内容,包括包名(包名是你待会创建工程的包名)和SHA1,需要注意的是SHA1,这个不知道怎么获取的可以百度,最后提交即可
提交之后我们的应用列表就会出现下图所示内容
image.png
创建了之后我们只需记住AK即可,这个是key,现在我们还没用到,待会会回来这里复制。
接下里我们就要创建工程了
创建工程
我们在AS新建一个工程,包名要和刚才创建应用填写的包名一样
然后下载相应的jar包和so库,jar包放入libs中,so库放入Java同级目录下的jniLibs文件夹下,如下图所示
image.png
配置工程
我们先来配置AndroidManifest.xml
- 添加权限
<!--访问相机权限-->
<uses-permission android:name="android.permission.CAMERA"/>
<!--访问闪光灯-->
<uses-permission android:name="android.permission.FLASHLIGHT"/>
<!-- 这个权限用于进行网络定位-->
<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"/>
- 添加屏幕及版本支持
<supports-screens
android:anyDensity="true"
android:largeScreens="true"
android:normalScreens="true"
android:smallScreens="true" />
- 添加开发密钥
这个就是我们刚才创建应用所得到的AK
<meta-data android:name="com.baidu.lbsapi.API_KEY" android:value="开发密钥">
</meta-data>
在value中填上你key
4.添加定位服务
<!--百度定位SDK-->
<service
android:name="com.baidu.location.f"
android:enabled="true"
android:process=":remote" />
- 配置Application
创建一个MyApplication,并做如下配置
MyApplication.java
public class MyApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
//初始化百度地图
initBaiduSDK();
}
/**
* 初始化百度地图
*/
private void initBaiduSDK() {
ArSdkManager.getInstance().initApplication(MyApplication.this, new MyGeneralListener());
LocSdkClient.getInstance(this).getLocationStart();
SDKInitializer.initialize(this);
SDKInitializer.setCoordType(CoordType.BD09LL);
}
static class MyGeneralListener implements MKGeneralListener {
@Override
public void onGetPermissionState(int i) {
}
@Override
public ArBDLocation onGetBDLocation() {
BDLocation location= LocSdkClient.getInstance(ArSdkManager.getInstance().getAppContext()).getLocationStart().getLastKnownLocation();
if(location==null){
return null;
}
ArBDLocation arBDLocation=new ArBDLocation();
arBDLocation.setLatitude(location.getLatitude());
arBDLocation.setLongitude(location.getLongitude());
return arBDLocation;
}
}
}
需要注意的是在初始化时我们用到了一个类LocSdkClient,这个类是在官网的demo里的,我们直接从demo里拷贝过来用
LocSdkClient.java
package com.yk.mchat.utils;
import android.content.Context;
import com.baidu.location.LocationClient;
import com.baidu.location.LocationClientOption;
public class LocSdkClient {
private static LocSdkClient mInstance = null;
public LocationClient mLocationClient = null;
private LocSdkClient(Context context) {
mLocationClient = new LocationClient(context.getApplicationContext());
// 声明LocationClient类
// mLocationClient.registerLocationListener(myListener);
// 注册监听函数
LocationClientOption option = new LocationClientOption();
option.setLocationMode(LocationClientOption.LocationMode.Hight_Accuracy);
// 可选,设置定位模式,默认高精度
// LocationMode.Hight_Accuracy:高精度;
// LocationMode. Battery_Saving:低功耗;
// LocationMode. Device_Sensors:仅使用设备;
option.setCoorType("bd09");
// 可选,设置返回经纬度坐标类型,默认gcj02
// gcj02:国测局坐标;
// bd09ll:百度经纬度坐标;
// bd09:百度墨卡托坐标;
// 海外地区定位,无需设置坐标类型,统一返回wgs84类型坐标
option.setScanSpan(2000);
// 可选,设置发起定位请求的间隔,int类型,单位ms
// 如果设置为0,则代表单次定位,即仅定位一次,默认为0
// 如果设置非0,需设置1000ms以上才有效
option.setOpenGps(true);
// 可选,设置是否使用gps,默认false
// 使用高精度和仅用设备两种定位模式的,参数必须设置为true
option.setLocationNotify(true);
// 可选,设置是否当GPS有效时按照1S/1次频率输出GPS结果,默认false
option.setIgnoreKillProcess(false);
// 可选,定位SDK内部是一个service,并放到了独立进程。
// 设置是否在stop的时候杀死这个进程,默认(建议)不杀死,即setIgnoreKillProcess(true)
option.SetIgnoreCacheException(false);
// 可选,设置是否收集Crash信息,默认收集,即参数为false
option.setWifiCacheTimeOut(5 * 60 * 1000);
// 可选,7.2版本新增能力
// 如果设置了该接口,首次启动定位时,会先判断当前WiFi是否超出有效期,若超出有效期,会先重新扫描WiFi,然后定位
option.setEnableSimulateGps(false);
// 可选,设置是否需要过滤GPS仿真结果,默认需要,即参数为false
mLocationClient.setLocOption(option);
// mLocationClient为第二步初始化过的LocationClient对象
// 需将配置好的LocationClientOption对象,通过setLocOption方法传递给LocationClient对象使用
// 更多LocationClientOption的配置,请参照类参考中LocationClientOption类的详细说明
mLocationClient.start();
// mLocationClient为第二步初始化过的LocationClient对象
// 调用LocationClient的start()方法,便可发起定位请求e
}
public LocationClient getLocationStart() {
return mLocationClient;
}
public static LocSdkClient getInstance(Context context) {
if (mInstance == null) {
Class var0 = LocSdkClient.class;
synchronized (LocSdkClient.class) {
if (mInstance == null) {
mInstance = new LocSdkClient(context);
}
}
}
return mInstance;
}
}
这样,我们就完成了工程的初始化,今天就到这里。
网友评论