美文网首页
Android 集成百度地图AR识别SDK(二)

Android 集成百度地图AR识别SDK(二)

作者: JYangkai | 来源:发表于2019-03-05 21:33 被阅读0次

废话

今天我们开始集成百度地图AR识别SDK(后面简称AR SDK)的第二章,这一章我们主要讲Android Studio如何配置AR SDK

我们如果单单只看文档的话,很难看懂如何集成,我们需要结合官网的给的demo去集成,但是这里我参考官网的demo集成完成了,所以就看我如何集成

注册开发者账号

这是第一步,我们要有了自己的开发者账号才能继续进行下一步
打开百度地图开发者官网,使用自己的百度账号登录,如何没有就注册一个

image.png

创建应用

注册完成之后,我们就可以打开右上角账号信息旁边的控制台,然后点击创建应用


image.png

点击之后会出现下图所示内容

image.png

我们填写相应的内容,包括包名(包名是你待会创建工程的包名)和SHA1,需要注意的是SHA1,这个不知道怎么获取的可以百度,最后提交即可

提交之后我们的应用列表就会出现下图所示内容


image.png

创建了之后我们只需记住AK即可,这个是key,现在我们还没用到,待会会回来这里复制。

接下里我们就要创建工程了

创建工程

我们在AS新建一个工程,包名要和刚才创建应用填写的包名一样

然后下载相应的jar包和so库,jar包放入libs中,so库放入Java同级目录下的jniLibs文件夹下,如下图所示


image.png

配置工程

我们先来配置AndroidManifest.xml

  1. 添加权限
<!--访问相机权限-->
<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"/>
  1. 添加屏幕及版本支持
<supports-screens
    android:anyDensity="true"
    android:largeScreens="true"
    android:normalScreens="true"
    android:smallScreens="true" />
  1. 添加开发密钥
    这个就是我们刚才创建应用所得到的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" />
  1. 配置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;
    }

}

这样,我们就完成了工程的初始化,今天就到这里。

相关文章

网友评论

      本文标题:Android 集成百度地图AR识别SDK(二)

      本文链接:https://www.haomeiwen.com/subject/xwrauqtx.html