【实训】Android 百度地图SDK简单使用

网上有很多关于百度地图SDK的开发介绍,本篇只是记录下使用时的一些操作和问题


一.申请AppKey

首先和其他普通SDK一样,需要去官网注册账号,申请密钥。

账号这个大家都有吧,密钥的话


百度地图开放平台首页点击申请密钥


然后创建应用


我们理所当然选择Android SDK ,选择自己需要的服务


虽然可能知道了,不过还是提一下,SHA1的获取,开发板的获取是在用户目录下的.android(注意点)文件夹中,输入:

keytool -list -v -keystore debug.keystore

默认口令是android

就会显示开发版的SHA1

而发布版的把debug.keystore换成自己打包时的证书的就行



包名填applicationId,在app gradle中找


提交后,可以获得AppKey



二.配置

配置方面我觉得百度官方写的相当好了,链接:http://lbsyun.baidu.com/index.php?title=androidsdk/guide/buildproject

权限总是会有人忘,还是写上吧

    <!-- MAP_location_map -->
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <uses-permission android:name="android.permission.GET_TASKS" />
    <uses-permission android:name="android.permission.WRITE_SETTINGS" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="com.android.launcher.permission.READ_SETTINGS" />

三.一些代码

获取定位,写了个类,可以参考下

public class Location implements BDLocationListener {
    private LocationClient mLocationClient = null;
    private LocationListener listener;
    private Context context;
    private String location_name;
    private double x, y;
    private float limit;
    private boolean is_first = true;// 需要有这个
    private boolean force_update = false;

    private Location(Context applationContext, LocationListener listener, boolean force_update) {
        this.context = applationContext;
        this.listener = listener;
        this.force_update = force_update;
    }

    private void initLocation() {
        if (!force_update) {
            AnLocation old_location = LocationCache.getLocation(context);
            location_name = old_location.getLocationName();
            if (location_name != null && !location_name.equals("")) {
                listener.locationRespose(location_name,
                        old_location.getX(), old_location.getY(), old_location.getLimit());
                return;
            }
        }
        // SDKInitializer.initialize(context);// 请在界面之前调用一次
        mLocationClient = new LocationClient(context); // 声明LocationClient类
        mLocationClient.registerLocationListener(this); // 注册监听函数
        LocationClientOption option = new LocationClientOption();
        option.setLocationMode(LocationMode.Hight_Accuracy);// 可选,默认高精度,设置定位模式,高精度,低功耗,仅设备
        option.setCoorType("bd09ll");// 可选,默认gcj02,设置返回的定位结果坐标系(要么是百度坐标,或者是国测局02坐标)
        option.setScanSpan(0);// 可选,默认0,即仅定位一次,设置发起定位请求的间隔需要大于等于1000ms才是有效的
        option.setIsNeedAddress(true);// 可选,设置是否需要地址信息,默认不需要
        option.setOpenGps(true);// 可选,默认false,设置是否使用gps
        mLocationClient.setLocOption(option);
        mLocationClient.start();
    }

    @Override
    public void onReceiveLocation(BDLocation location) {
        if (is_first) {
            is_first = false;
        } else {
            return;
        }
        if (location.getLocType() == BDLocation.TypeGpsLocation
                || location.getLocType() == BDLocation.TypeNetWorkLocation
                || location.getLocType() == BDLocation.TypeOffLineLocation) {// 定位成功
            location_name = location.getAddrStr();
            x = location.getLongitude();
            y = location.getLatitude();
            limit = location.getRadius();
        } else {
            location_name = "";
            x = 0;
            y = 0;
            limit = 0;
        }
        AnLocation old_location = new AnLocation(location_name, x, y, limit);
        LocationCache.saveLocation(context, old_location);
        if (listener != null)
            listener.locationRespose(location_name, x, y, limit);
    }

    // ///基于回调的方法///

    /**
     * 获取位置信息
     *
     * @param applationContext 全局的context
     * @param listener         监听回调
     */
    public static void getLocation(Context applationContext,
                                   LocationListener listener) {
        new Location(applationContext, listener, false).initLocation();
    }

    /**
     * 获取位置信息
     *
     * @param applationContext 全局的context
     * @param listener         监听回调
     * @param force_update     是否强制刷新
     */
    public static void getLocation(Context applationContext,
                                   LocationListener listener, boolean force_update) {
        new Location(applationContext, listener, force_update).initLocation();
    }

    /**
     * * 百度地图的位置转换,将坐标位置转换为地名
     *
     * @param x        要转换的x
     * @param y        要转换的y
     * @param listener 监听回调
     */
    public static void transLocation(double x, double y,
                                     final LocationTransListener listener) {
        GeoCoder mSearch = GeoCoder.newInstance();
        OnGetGeoCoderResultListener lis = new OnGetGeoCoderResultListener() {
            public void onGetGeoCodeResult(GeoCodeResult result) {
                if (result == null || result.error != SearchResult.ERRORNO.NO_ERROR) {
                    //没有检索到结果
                    listener.locationRespose("");
                } else {
                    //获取地理编码结果
                    listener.locationRespose(result.getAddress());
                }
            }

            public void onGetReverseGeoCodeResult(ReverseGeoCodeResult result) {
                if (result == null || result.error != SearchResult.ERRORNO.NO_ERROR) {
                    //没有找到检索结果
                    listener.locationRespose("");
                } else {
                    //获取反向地理编码结果
                    listener.locationRespose(result.getAddress());
                }
            }
        };
        mSearch.setOnGetGeoCodeResultListener(lis);
        mSearch.reverseGeoCode(new ReverseGeoCodeOption().location(new LatLng(y, x)));
//        mSearch.destroy();
    }


}







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值