android: 高德地图

kangtingting0 2019-07-01

分为地图,定位,搜索(我还没做导航功能)

建议采用gradle方式集成

添加依赖

在project/build.gradle文件下添加jcenter的仓库地址

allprojects {
    repositories {
        jcenter() // 或者 mavenCentral()
    }
 }

在app/build.gradle下添加依赖

android {
    defaultConfig {
        ndk {
            //设置支持的SO库架构(开发者可以根据需要,选择一个或多个平台的so)
            abiFilters "armeabi", "armeabi-v7a", "arm64-v8a", "x86","x86_64"
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    //3D地图so及jar
    compile 'com.amap.api:3dmap:latest.integration'
    //定位功能
    compile 'com.amap.api:location:latest.integration'
    //搜索功能
    compile 'com.amap.api:search:latest.integration'
}
navi导航SDK 5.0.0以后版本包含了3D地图SDK,所以请不要同时引入 map3d 和 navi SDK。

添加权限

在AndroidManifest.xml文件下添加权限

<!--允许程序打开网络套接字-->
<uses-permission android:name="android.permission.INTERNET" />
<!--允许程序设置内置sd卡的写权限-->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />   
<!--允许程序获取网络状态-->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
<!--允许程序访问WiFi网络信息-->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> 
<!--允许程序读写手机状态和身份-->
<uses-permission android:name="android.permission.READ_PHONE_STATE" />     
<!--允许程序访问CellID或WiFi热点来获取粗略的位置-->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />

添加高德key

如何获取key看这里 -> 点我查看Key注册时必要数据SHA1和包名的获取方法

同时创建debug和release的密钥文件,在app/build.gradle下做配置:

android {
    signingConfigs {
        release {
            keyAlias 'xxxxxx'
            keyPassword 'xxxxxx'
            //..表示工程目录路径
            storeFile file('../jks/map_release.jks')
            storePassword 'xxxxxx'
        }
        debug {
            keyAlias 'xxxxxx'
            keyPassword 'xxxxxx'
            storeFile file('../jks/map_debug.jks')
            storePassword 'xxxxxx'
        }
    }
 }

然后获取debug和release下的sha1值,在高德地图控制台创建key
android: 高德地图
然后在app/build.gradle下设置两种key,这里的key-value是一样的。因为高德控制台同一个应用下配置了debug和release的sha1值。

android {
       buildTypes {
            debug {
              manifestPlacesholders = [
                      //左边的键MAP_API_KEY是自定义的名字,右边的key-value是你申请的key值
                    "MAP_API_KEY" : "key-value"
               ]
            }
            
            release{
            manifestPlacesholders = [
                      //左边的键MAP_API_KEY要和debug下的保持一致,右边的key-value是你申请的key值
                    "MAP_API_KEY" : "key-value"
               ]
            }
       }
  }

采用gradle方式集成,不需要在AndroidManifest.xml中添加key,添加定位服务

<application>
    <meta-data
            android:name="com.amap.api.v2.apikey"
            //要和app/build.gradle文件中设置的保持一致
            android:value="${MAP_API_KEY}"/>
            
    <service android:name="com.amap.api.location.APSService"/>
  </application>

使用地图

在布局中引入地图MapView

// R.layout.activity_your_activity
  <com.amap.api.maps.MapView

    android:id="@+id/map"

    android:layout_width="match_parent"

    android:layout_height="match_parent"/>

管理地图的生命周期(非常重要),以Activity为例

public class YourActivity extends AppcompatActivity{

     MapView mMapView = null;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_your_activity);
    //获取地图控件引用
    mMapView = (MapView) findViewById(R.id.map);
    //在activity执行onCreate时执行mMapView.onCreate(savedInstanceState),创建地图
    mMapView.onCreate(savedInstanceState);
  }
  @Override
  protected void onDestroy() {
    super.onDestroy();
    //在activity执行onDestroy时执行mMapView.onDestroy(),销毁地图
    mMapView.onDestroy();
  }
 @Override
 protected void onResume() {
    super.onResume();
    //在activity执行onResume时执行mMapView.onResume (),重新绘制加载地图
    mMapView.onResume();
    }
 @Override
 protected void onPause() {
    super.onPause();
    //在activity执行onPause时执行mMapView.onPause (),暂停地图的绘制
    mMapView.onPause();
    }
 @Override
 protected void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
    //在activity执行onSaveInstanceState时执行mMapView.onSaveInstanceState (outState),保存地图当前的状态
    mMapView.onSaveInstanceState(outState);
  } 

}

构造一个AMap对象

if(mAMap == null){
   mAMap = mapView.getMap();
  }

初始化地图的相关属性

相关类UiSettings(不做介绍,具体看官方文档),CameraUpdateFactory,CameraUpdate

对于CameraUpdateFactory,文档介绍

创建CameraUpdate 对象,用来改变地图状态。
调用 AMap.animateCamera(CameraUpdate) or AMap.moveCamera(CameraUpdate)。
  • 地图中心点
//设置地图中心点
static CameraUpdate    changeLatLng(LatLng latLng)

static CameraUpdate    newLatLng(LatLng latLng)
  • 地图缩放级别
static CameraUpdate     zoomTo(float zoom);
  • 地图中心点和缩放级别
//设置地图中心点以及缩放级别
 static CameraUpdate newLatLngZoom(LatLng latLng, float zoom)
  • 设置显示在规定屏幕范围内的地图经纬度范围
static CameraUpdate    newLatLngBounds(LatLngBounds bounds, int padding)
创建LatLngBounds对象,LatLngBounds(LatLng southwest, LatLng northeast)
使用传入的西南角坐标和东北角坐标创建一个矩形区域。

添加marker

1.相关类
  • MarkerOptions
    为marker设置属性
  • BitmapDescriptorFactory
    生成BitmapDescriptor对象,设置给marker的icon.
  • BitmapDescriptor
    给marker设置icon,MarkerOptions.icon(BitmapDescriptor)

2.相关API

第二个方法添加一组marker,地图会移动到该组marker所在区域的中心
//在地图上添一个图片标记(marker)对象。
 Marker    addMarker(MarkerOptions options)
//在地图上添一组图片标记(marker)对象,并设置是否改变地图状态以至于所有的marker对象都在当前地图可视区域范围内显示。
java.util.ArrayList<Marker>    addMarkers(java.util.ArrayList<MarkerOptions> options, boolean moveToCenter)

3.如何使用:

//MarkerOptions的具体设置看官方文档
   MarkerOptions markerOptions = new MarkerOptions();
     //设置marker坐标
        markerOptions.position(latLng);
        //marker是否可拖拽
        markerOptions.draggable(false);
        //marker图标
        markerOptions.icon(BitmapDescriptorFactory.fromBitmap(bitmap));

BitmapDescriptorFactory位于com.amap.api.maps.model包下,包含多个生成BitmapDescriptor的方法,如果一组marker的图标是一致的,建议先通过BitmapFactory生成一个bitmap,再通过BitmapDescriptorFactory.fromBitmap(bitmap)设置给marker.

如果一组marker数据量很大,不建议for循环遍历逐个添加.

MarkerOptions markerOptions = new MarkerOptions();
 Bitmap bitmap = BitmapFactory.decodeResources(drawableResId);
List<DataBean> dataBeanList = new ArraryList<>();
int size = dataBeanList .size();
  for(int x = 0;x< size; x++){
     //设置marker坐标
        markerOptions.position(latLng);
        //marker是否可拖拽
        markerOptions.draggable(false);
        //marker图标
        markerOptions.icon(BitmapDescriptorFactory.fromBitmap(bitmap));
        //添加后返回该marker
     Marker marker = mAMap.addMarker(markerOptions);
     //为marker添加信息
     marker.setObject(dataBeanList.get(x));
}

上面这种方式添加的marker数据量过大的话,marker会逐一显示在屏幕上,视觉效果不太好,建议采用下面的方法,通过addMarkers(List<MarkerOptions>)一次性全部添加.

MarkerOptions markerOptions = new MarkerOptions();
//一组marker的图标一致的话,事先生成这个图标的bitmap实例对象
 Bitmap bitmap = BitmapFactory.decodeResources(drawableResId);
List<DataBean> dataBeanList = new ArraryList<>();
ArrayList<MarkerOptions> markerOptionList = new Arrary<>();
 for(int x = 0;x< size; x++){
     //设置marker坐标
        markerOptions.position(latLng);
        //marker是否可拖拽
        markerOptions.draggable(false);
        //marker图标
        markerOptions.icon(BitmapDescriptorFactory.fromBitmap(bitmap));
        markerOptionList.add(markerOptions);
       
}
// 添加后返回一组Marker
  ArrayList<Marker>  markerList =  mAMap.addMarkers(markerOptionList);
    int index = 0;
    for(Marker marker : markerList ){
            //为marker设置信息
            marker .setObject(dataBeanList.get(index++));
    }

这种方法,可以使一组marker几乎同时出现,视觉效果更好.

4.marker的点击事件不再介绍.
5.更改已添加过的marker的属性
marker.setIcon()似乎无效果.待测

显示定位蓝点

未完待续

相关推荐