Android Studio使用原生反向地址编码方法和使用百度地图SDK的对比以及遇到的问题

项目中需要对获取到的地理位置信息(经纬度)进行反向地址编码,就是根据经纬度反查出地址来。

首先想到的是android自带的那个GeoCoder,测试代码片段如下:

  android.location.Geocoder geocoder = new android.location.Geocoder(this, Locale.CHINA);
            try {
                List addressList = geocoder.getFromLocation(location[0], location[1], 3);
                for (android.location.Address address : addressList) {
                    Log.i(TAG, address.toString());
                }
            } catch (IOException e) {
                e.printStackTrace();
            }

注意,上面那些个长长的类名,

android.location.Geocoder和android.location.Address
你正常import之后是不需要这么写的,我故意如此是为了方便和百度地图SDK做对比,因为百度地图里面也叫GeoCoder啊。。。

在浙江的地图上随便找一个点,得到经纬度,然后测试,输出结果示例:

[addressLines=[0:"中国",1:"浙江省金华市东阳市"],
        feature=歌山镇新浦,admin=浙江省,sub-admin=null,locality=金华市,
        thoroughfare=null,postalCode=null,countryCode=CN,countryName=中国,
        hasLatitude=true,latitude=29.268876512302988,
        hasLongitude=true,longitude=120.35351869072791,phone=null,url=null,extras=null

这个地方看起来可能有点偏。。。一大堆的null。

不管它,然后看看咱们的大百度。

首先呢,需要下载百度地图SDK,因为我只需要这个检索的功能,我就只下载了包含地址检索的最小库。解压之后两个文件:

Android Studio使用原生反向地址编码方法和使用百度地图SDK的对比以及遇到的问题_第1张图片

很明显,jar包放入工程的libs目录下,并且右键->add as library,触发gradle的自动sync files。等待完成后,jar包导入完毕。

那个so文件呢?用过eclipse的朋友都会想当然的在libs目录下新建一个目录叫armeabi,然后把so文件放进去即可。

我不会告诉我就是这么做的,然后,很不幸的,运行时爆了Unsatified 错误,做过NDK开发就知道,这个native库没加载成功。多半是so文件放的地方不对。

看来eclipse的老经验在AndroidStudio下完全不好使。

放到哪里呢?首先想到jni目录,好吧,在项目(实际上叫module)上右键,新建一个jni folder

Android Studio使用原生反向地址编码方法和使用百度地图SDK的对比以及遇到的问题_第2张图片

然后把这个so文件放进去,编译,嗯,提示我要配置NDK的path,好吧,我承认我都是用Eclipse来测试NDK程序。但是,很明显,这个提示说明,这个目录也不对,这里是放JNI源代码的地方,这个so是编译好的库,正确导入肯定是不需要NDK再次编译的。

那么会是哪里呢?已经有人研究出来了,正解是放到jniLibs目录下面。

注意路径:src->main->jniLibs->armeabi->libxxxx.so

接下来呢,就是根据百度的官方文档,申请密钥,添加一大堆权限,以及必要的初始化代码等等,这些不再赘述了。

只单独讲讲在使用AS的时候,关于申请密钥时需要获取到当前签名key对应的SHA1指纹,这一点和Eclipse有点不同。

顺便问一句:哪位大神知道AS默认使用的debugkey是什么?在哪里?我没找到。。。就新建了一个key。通过菜单

Build-》Generate Signed APK 新建了一个key,比如叫做signkey.jks。

获取key的SHA1指纹的命令:

cd 到你存放key的目录下,执行

$ keytool -list -v -keystore signkey.jks
就可以得到SHA1指纹。

那么怎么让AS在debug和release的时候都使用这个新建的key在签名呢?,看图

Android Studio使用原生反向地址编码方法和使用百度地图SDK的对比以及遇到的问题_第3张图片

然后进入上图中 BuildType选项卡中,给debug和release都指定我们在上面新建的配置来签名。

OK,签名的问题搞定!这个签名不搞定,百度可不会让你使用他的服务哦。

最后,测试百度地图反向地址编码的代码部分:

            //利用百度地图SDK提供的方法进行地理反向编码查询
            GeoCoder geoCoder = GeoCoder.newInstance();
            ReverseGeoCodeOption option = new ReverseGeoCodeOption();
            option.location(new LatLng(location[0], location[1]));
            geoCoder.setOnGetGeoCodeResultListener(new OnGetGeoCoderResultListener() {
                @Override
                public void onGetGeoCodeResult(GeoCodeResult geoCodeResult) {

                }

                @Override
                public void onGetReverseGeoCodeResult(ReverseGeoCodeResult reverseGeoCodeResult) {
                    if (reverseGeoCodeResult == null || reverseGeoCodeResult.error != SearchResult.ERRORNO.NO_ERROR) {
                        //没有找到检索结果
                        Log.i(TAG, "No result!!");
                        return;
                    }
                    
		    Log.i(TAG,reverseGeoCodeResult.getAddress());
                    Log.i(TAG,reverseGeoCodeResult.getBusinessCircle());
List poiInfoList = reverseGeoCodeResult.getPoiList(); if (poiInfoList == null) { Log.i(TAG, "poilist null.."); return; } for (PoiInfo info : poiInfoList) { Log.i(TAG, info.toString()); Log.i(TAG, info.address); Log.i(TAG, info.name);
                        Log.i(TAG, info.phoneNum);
} } }); geoCoder.reverseGeoCode(option);
 有个重要的初始化代码,一定要放在最前面执行,在setContentView()之前。 
  

    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        SDKInitializer.initialize(getApplicationContext());
        setContentView(R.layout.activity_bmap_address);
最后就是用完了销毁。

geoCoder.destroy();

测试结果,还是利用刚才一样的经纬度,输出的结果和使用原生方法差不多,就不贴出来了。不过如果有附近商圈和兴趣点的需求,那使用百度地图SDK还是不错的。

其实用谷歌提供的playservice也是可以的,就是由于你懂的原因,可能不如百度的稳定一些吧。以前也弄过,效果很好的,这里就不说了。




你可能感兴趣的:(Android)