Android Studio实现百度地图及定位

一、功能需求

根据官方文档,开发百度地图定位APP,显示出当前位置坐标。

二、实现过程

1. 实验环境

Android Studio3.1

2.获取百度开发者KEY

https://lbsyun.baidu.com/index.php?title=androidsdk
(1)创建用户
这一部分内容和每一个app注册流程一样,不再赘述。
(2)获取密钥
在这里插入图片描述
创建新的应用,并选择自己所需要的应用类型
在这里插入图片描述
在这里插入图片描述
(3)SHA1和PackageName的获取
打开AndroidStudio的终端terminal,并在命令行操作
先进入C盘中自己用户下,在输入.android命令后再keytool -list -v -keystore debug.keystore
在这里插入图片描述
在build.gradle中可以查看包名
在这里插入图片描述
(4)创建好Key后进行下载
在这里插入图片描述
下载文件并解压在D盘
在这里插入图片描述
复制libs下的文件至项目下的libs
在这里插入图片描述在libs目录下,选中BaiduLbs_Android.jar文件右键,选择Add As Library

在这里插入图片描述
查看build.gradle的dependencies块中生成了工程所依赖的jar文件的对应说明
在这里插入图片描述
(5)配置AndroidManifest.xml文件

<application>  
    <meta-data  
        android:name="com.baidu.lbsapi.API_KEY"  
        android:value="开发者 key" />  
</application>

在这里插入图片描述
在application外部添加权限声明:
在这里插入图片描述

3. 页面设计

在布局文件activity_main.xml中添加地图容器

<com.baidu.mapapi.map.MapView
        android:id="@+id/bmapView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:clickable="true" />

但我想实现下面有地图,上面有经纬度以及地址的展现,添加代码后为:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <com.baidu.mapapi.map.MapView
        android:id="@+id/bmapView"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:clickable="true"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:background="#e0000000"
        android:orientation="vertical"
        tools:ignore="MissingConstraints">
        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="12dp"
            android:layout_marginTop="20dp"
            android:orientation="horizontal" >
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="纬度:"
                android:textColor="#ffffff"
                android:textSize="15dp" />
            <TextView
                android:id="@+id/tv_Lat"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text=""
                android:textColor="#ffffff"
                android:textSize="15dp" />
        </LinearLayout>
        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="12dp"
            android:layout_marginTop="10dp"
            android:orientation="horizontal" >
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="经度:"
                android:textColor="#ffffff"
                android:textSize="15dp" />
            <TextView
                android:id="@+id/tv_Lon"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text=""
                android:textColor="#ffffff"
                android:textSize="15dp" />
        </LinearLayout>
        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginBottom="10dp"
            android:layout_marginLeft="12dp"
            android:layout_marginTop="10dp"
            android:orientation="horizontal" >
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="地址:"
                android:textColor="#ffffff"
                android:textSize="15dp" />

            <TextView
                android:id="@+id/tv_Add"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text=""
                android:textColor="#ffffff"
                android:textSize="15dp" />
        </LinearLayout>
    </LinearLayout>

</androidx.constraintlayout.widget.ConstraintLayout>

在这里插入图片描述

4. Java代码实现

(1)MainActivity的编写

public class MainActivity extends AppCompatActivity {

    MapView mMapView = null;
    BaiduMap mBaiduMap ;
    LocationClient mLocationClient;

    TextView tv_Lat;  //纬度
    TextView tv_Lon;  //经度
    TextView tv_Add;  //地址
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        tv_Add = findViewById(R.id.tv_Add);
        tv_Lon = findViewById(R.id.tv_Lon);
        tv_Lat = findViewById(R.id.tv_Lat);
        mMapView = findViewById(R.id.bmapView);
        mBaiduMap = mMapView.getMap();
        //设置地图类型
        mBaiduMap.setMapType(BaiduMap.MAP_TYPE_NORMAL);
        //开启地图的定位图层
        mBaiduMap.setMyLocationEnabled(true);

        //从系统获取定位权限
        if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
            ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.ACCESS_FINE_LOCATION}, 1);
        }else {
            //设置客户端
            mLocationClient = new LocationClient(this);
            LocationClientOption option = new LocationClientOption();
            option.setOpenGps(true);
            option.setCoorType("bd09ll"); // 设置坐标类型
            option.setIsNeedAddress(true); //设置是否需要地址信息,默认不需要
            mLocationClient.setLocOption(option);
            //设置监听器
            MylocationListener myLocationListener = new MylocationListener();
            mLocationClient.registerLocationListener(myLocationListener);
            //开启地图定位图层
            mLocationClient.start();

            MyLocationConfiguration.LocationMode mCurrentMode = MyLocationConfiguration.LocationMode.FOLLOWING;
            MyLocationConfiguration mLocationConfiguration = new MyLocationConfiguration(mCurrentMode,true,null,0xAAFFFF88,0xAA00FF00);
            mBaiduMap.setMyLocationConfiguration(mLocationConfiguration);
        }


    }
    private class MylocationListener extends BDAbstractLocationListener {
        @Override
        public void onReceiveLocation(BDLocation bdLocation) {
            if (bdLocation == null || mMapView == null){
                return;
            }
            MyLocationData locationData = new MyLocationData.Builder()
                    .accuracy(bdLocation.getRadius())
                    .direction(bdLocation.getDirection())
                    .latitude(bdLocation.getLatitude())
                    .longitude(bdLocation.getLatitude())
                    .build();
            mBaiduMap.setMyLocationData(locationData);

            //输出经纬度和地点
            tv_Add.setText(bdLocation.getAddrStr());
            tv_Lat.setText(bdLocation.getLatitude()+" ");
            tv_Lon.setText(bdLocation.getLongitude()+" ");
            LatLng ll = new LatLng(bdLocation.getLatitude(),bdLocation.getLongitude());
            MapStatusUpdate update = MapStatusUpdateFactory.newLatLng(ll);
            mBaiduMap.animateMapStatus(update);
        }
    }
}

添加Map的生命周期

    @Override
    protected void onResume() {
        mMapView.onResume();
        super.onResume();
    }
    @Override
    protected void onPause() {
        mMapView.onPause();
        super.onPause();

    }
    @Override
    protected void onDestroy() {
        super.onDestroy();
        mLocationClient.stop();
        mBaiduMap.setMyLocationEnabled(false);
        mMapView.onDestroy();
    }
}

创建建一个自定义的Application,在其onCreate方法中完成SDK的初始化

public class DemoApplication extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
        //在使用SDK各组件之前初始化context信息,传入ApplicationContext
        SDKInitializer.initialize(this);
        //自4.3.0起,百度地图SDK所有接口均支持百度坐标和国测局坐标,用此方法设置您使用的坐标类型.
        //包括BD09LL和GCJ02两种坐标,默认是BD09LL坐标。
        SDKInitializer.setCoordType(CoordType.BD09LL);
    }
}

在这里插入图片描述
运行后发现APP根本打不开,而DemoApplication是灰色的,所以我怀疑是这里出现的问题。查看AndroidStudio下的Run也发现错误:you have not supplyed the global app context info from SDKInitializer.initialize(Context) function,明白了是自己在AndroidManifest.xml文件中未声明该Application
解决方式:
在这里插入图片描述

三、运行界面展示

在这里插入图片描述
发现只能显示北京天安门,这里需要添加定位权限

<!-- 这个权限用于进行网络定位 -->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<!-- 这个权限用于访问GPS定位 -->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

声明定位的服务

<service android:name="com.baidu.location.f"
            android:enabled="true"
            android:process=":remote"/>

再次运行,显示虚拟机的位置
在这里插入图片描述
因为这是虚拟机的位置,所以要得到自身定位,还需要我们将apk文件下载至手机后打开。
在这里插入图片描述
将文件下载至自己手机后打开
在这里插入图片描述
再次查看位置
在这里插入图片描述

四、源码

代码仓库

### 集成和使用地图 API 的步骤 要在 Android Studio 中集成并使用地图 API 开发应用程序,可以按照以下方式操作: #### 1. 下载并安装必要的工具 确保已下载并安装最新版本的 Android Studio 和 SDK 工具[^1]。这些工具提供了构建 Android 应用所需的核心环境。 #### 2. 添加依赖项到 `build.gradle` 文件 为了支持地图功能,在项目的模块级 `build.gradle` 文件中添加相应的依赖项。如果使用的是百度地图,则需参考其官方文档中的配置说明[^2];如果是高德地图,则需要引入对应的 Maven 或 AAR 包[^3]。 例如,针对百度地图,可以在 `dependencies` 节点下加入类似下面的内容: ```gradle implementation 'com.baidu.lbsdk:lbssdk:latest_version' ``` 注意替换 `latest_version` 为实际发布的最新版本号。 #### 3. 设计界面布局 创建 XML 布局文件来显示地图视图组件。以下是采用高德地图的一个例子: ```xml <com.amap.api.maps.MapView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/mapView" android:layout_width="match_parent" android:layout_height="match_parent"/> ``` 此部分定义了一个全屏的地图控件用于展示地理信息数据。 #### 4. 初始化 Map 控制器对象 在 Activity 类内的 `onCreate()` 方法里初始化地图实例,并通过它控制地图行为[^4]: ```java MapView mapView; BaiduMap baiduMap; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mapView = (MapView)findViewById(R.id.mapView); baiduMap = mapView.getMap(); // 获取地图控制器引用 } ``` 上述代码片段展示了如何找到布局中的 `MapView` 组件以及获得对其的操作句柄。 #### 5. 处理生命周期事件 记得处理好活动(Activity)或者碎片(Fragment)的整个生命周期,比如暂停、恢复和销毁期间的状态保存与释放资源等问题。这有助于提高性能表现并且避免内存泄漏风险。 --- 关于 **API** 的概念解释已经给出过一次概述[^5],这里不再赘述。总之,利用第三方服务商所提供的各种类型的 APIs 可以为开发者带来极大的便利性和灵活性去快速搭建具备特定功能特性的移动客户端解决方案。
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值