root:build.gradle中添加依赖
apply plugin: 'com.android.application'
...
android {
defaultConfig {
ndk {
//设置支持的SO库架构(开发者可以根据需要,选择一个或多个平台的so)
abiFilters "armeabi", "armeabi-v7a", "arm64-v8a", "x86", "arm64-v8a", "x86_64"
}
}
}
dependencies {
...
compile 'com.amap.api:3dmap:latest.integration' //3D地图
compile 'com.amap.api:map2d:latest.integration' //2D地图
compile 'com.amap.api:navi-3dmap:latest.integration' //导航
compile 'com.amap.api:search:latest.integration' //搜索
compile 'com.amap.api:location:latest.integration' //定位
}
AndroidManifest
添加权限
//地图SDK(包含其搜索功能)需要的基础权限
<!-- 允许程序打开网络套接字 -->
<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" />
//定位包、导航包需要的额外权限(注:基础权限也需要)
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" />
<uses-permission android:name="android.permission.ACCESS_MOCK_LOCATION" />
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
申请高德 Key 并且配置到项目中
<application
...>
<meta-data
android:name="com.amap.api.v2.apikey"
android:value="申请的key"></meta-data>
...
</application>
申请key时候,需要SHA1
Windows电脑,在运行中输入cd .android回车
输入: keytool -list -v -keystore debug.keystore回车
提示输入密钥库口令:如果没有设置过,回车即可
即可获得到SHA1
地图界面布局的编写
<com.amap.api.maps.MapView
android:id="@+id/map"
android:layout_width="match_parent"
android:layout_height="match_parent"
/>
地图界面代码的编写
简单的地图显示
MapView mMapView;
AMap aMap;//初始化地图控制器对象
onCreat(){
mMapView.onCreate(savedInstanceState);
//初始化地图控制器对象
if (aMap == null) {
aMap = mMapView.getMap();
}
}
@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);
}
定位蓝点的显示
//实现定位蓝点
myLocationStyle = new MyLocationStyle();
// myLocationStyle.myLocationType(MyLocationStyle.LOCATION_TYPE_LOCATION_ROTATE);
//初始化定位蓝点样式类myLocationStyle.myLocationType(MyLocationStyle.LOCATION_TYPE_LOCATION_ROTATE);
// 连续定位、且将视角移动到地图中心点,定位点依照设备方向旋转,并且会跟随设备移动。(1秒1次定位)如果不设置myLocationType,
// 默认也会执行此种模式。
myLocationStyle.interval(2000);
//设置连续定位模式下的定位间隔,只在连续定位模式下生效,单次定位模式下不会生效。单位为毫秒。
aMap.setMyLocationStyle(myLocationStyle);//设置定位蓝点的Style
//aMap.getUiSettings().setMyLocationButtonEnabled(true);设置默认定位按钮是否显示,非必需设置。
aMap.setMyLocationEnabled(true);// 设置为true表示启动显示定位蓝点,false表示隐藏定位蓝点并不进行定位,默认是false。
// myLocationStyle.showMyLocation(true);
//获取经纬度
定位 获取经纬度
public AMapLocationClient mLocationClient = null;
//声明mLocationOption对象
public AMapLocationClientOption mLocationOption = null;
//初始化定位参数
mLocationClient = new AMapLocationClient(this);
mLocationOption = new AMapLocationClientOption();
//设置定位模式为高精度模式,Battery_Saving为低功耗模式,Device_Sensors是仅设备模式
mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);
//设置是否返回地址信息(默认返回地址信息)
mLocationOption.setNeedAddress(true);
//设置是否只定位一次,默认为false
mLocationOption.setOnceLocation(true);
if (mLocationOption.isOnceLocationLatest()) {
mLocationOption.setOnceLocationLatest(true);
//设置setOnceLocationLatest(boolean b)接口为true,启动定位时SDK会返回最近3s内精度最高的一次定位结果。
//如果设置其为true,setOnceLocation(boolean b)接口也会被设置为true,反之不会。
}
//设置是否强制刷新WIFI,默认为强制刷新
mLocationOption.setWifiActiveScan(true);
//设置是否允许模拟位置,默认为false,不允许模拟位置
mLocationOption.setMockEnable(false);
//设置定位间隔,单位毫秒,默认为2000ms
mLocationOption.setInterval(2000);
//给定位客户端对象设置定位参数
mLocationClient.setLocationOption(mLocationOption);
//启动定位
mLocationClient.startLocation();
//设置定位回调监听
mLocationClient.setLocationListener(new AMapLocationListener() {
@Override
public void onLocationChanged(AMapLocation aMapLocation) {
if (aMapLocation != null) {
if (aMapLocation.getErrorCode() == 0) {
aMapLocation.getLatitude();//获取纬度
aMapLocation.getLongitude();//获取经度
aMapLocation.getCity();//获取城市
Log.e("====", aMapLocation.getCity());
mainTextView.setText("纬度:" + aMapLocation.getLatitude() + " 经度:" + aMapLocation.getLongitude() + " 城市:" + aMapLocation.getCity());
}
}
}
});
设置多描点
LatLng latLng;
Marker marker;
latLng = new LatLng(latitude, longitude);//纬度 经度
marker = aMap.addMarker(new MarkerOptions().position(latLng).title(name).snippet("" + id));
//title设置的是点击描点显示的名称
//snippet设置的是点击描点,显示的简单介绍
搜索功能
//1、继承 InputtipsListener 监听。
//2、构造 InputtipsQuery 对象
InputtipsQuery inputquery = new InputtipsQuery(输入的要搜索的内容, "城市名称");
inputquery.setCityLimit(true);//限制在当前城市
//3、构造 Inputtips 对象,并设置监听。
Inputtips inputTips = new Inputtips(Main2Activity.this, inputquery);
inputTips.setInputtipsListener(this);
//4、调用 PoiSearch 的 requestInputtipsAsyn() 方法发送请求。
inputTips.requestInputtipsAsyn();
@Override
public void onGetInputtips(List<Tip> list, int i) {
ListViewAdapter listViewAdapter = new ListViewAdapter(MainActivity.this, list);
mainLv.setAdapter(listViewAdapter);
}