前言
在開發當中,我們會常常用到地圖,我們就能很快的想到集成高德或者百度地圖的sdk,選擇高德地圖還是百度地圖呢?根據個人愛好吧。這裏就演示以下如何集成高德地圖的sdk
這裏演示的只是一個簡單的頁面
那就可是集成吧。
第一步
到高德地圖開放平臺官網 http://lbs.amap.com/註冊用戶 並且創建應用
註冊就不講了。
現在從創建應用開始
這一步很重要的,debug 版 的 SHA1 和 relase 版的 不一樣 。如果你只用了debug 版的 SHA1 的話 ,當應用發佈的時候是獲取不到地址的
現在就講一下 debug 和 release 版本的SHA1 是如何獲取的
- 打開cmd doc 窗口
獲取release版本的 SHA1 找到自己的密鑰地址 本人的在F盤 命令爲keytool -list -v -keystore 加上你的密鑰的名稱 然後輸入密鑰的密碼就能獲取了
獲取debug 版本的SHA1 就很簡單了
看圖 ,密鑰默認密碼是android
接着就是下載高德地圖sdk 了
下載地址http://lbs.amap.com/api/android-sdk/download
把下載好的文件解壓 後導入到Androidstudio 中
添加依賴
引用so庫
在manifest中添加權限
//地圖包、搜索包需要的基礎權限
<!--允許程序打開網絡套接字-->
<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" />
添加服務
<service android:name="com.amap.api.location.APSService"/>
並 在application節點 添加 你的key
這個key 是你在高德地圖中的key
填寫完成後就能使用了哦
地圖控件 mapview
<com.amap.api.maps2d.MapView
android:id="@+id/mapView"
android:layout_width="match_parent"
android:layout_height="170sp"
/>
package cn.iaapp.app.sixman.controller.activity;
import android.graphics.Color;
import android.location.Location;
import android.os.Bundle;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.util.Log;
import android.view.View;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
import com.amap.api.location.AMapLocation;
import com.amap.api.location.AMapLocationClient;
import com.amap.api.location.AMapLocationClientOption;
import com.amap.api.location.AMapLocationListener;
import com.amap.api.maps2d.AMap;
import com.amap.api.maps2d.CameraUpdate;
import com.amap.api.maps2d.CameraUpdateFactory;
import com.amap.api.maps2d.LocationSource;
import com.amap.api.maps2d.MapView;
import com.amap.api.maps2d.UiSettings;
import com.amap.api.maps2d.model.BitmapDescriptorFactory;
import com.amap.api.maps2d.model.CameraPosition;
import com.amap.api.maps2d.model.MyLocationStyle;
import com.amap.api.services.core.AMapException;
import com.amap.api.services.core.LatLonPoint;
import com.amap.api.services.core.PoiItem;
import com.amap.api.services.poisearch.PoiResult;
import com.amap.api.services.poisearch.PoiSearch;
import java.util.ArrayList;
import java.util.List;
import butterknife.BindView;
import cn.iaapp.app.sixman.R;
import cn.iaapp.app.sixman.controller.adapter.LocationAdapter;
/**
* Created by 樑想想 on 2018/3/28.
*/
public class LocationActivity extends BaseActivity implements LocationSource,AMapLocationListener ,PoiSearch.OnPoiSearchListener {
@BindView(R.id.iv_back)
ImageView ivBack;
@BindView(R.id.iv_search)
ImageButton ivSearch;
@BindView(R.id.tv_currentLocation)
TextView tvCurrentLocation;
// @BindView(R.id.my_location)
// TextView myLocation;
@BindView(R.id.mapView)
MapView mapView;
@BindView(R.id.recyclerview)
RecyclerView recyclerview;
private Bundle savedInstanceState ;
private AMap aMap ; //地圖對象
OnLocationChangedListener mListener;
AMapLocationClient mlocationClient;
AMapLocationClientOption mLocationOption;
private UiSettings uiSettings ;
private String address;
private int currentPage = 0;
private PoiSearch.Query query;
private PoiSearch poiSearch;
private PoiResult poiResult;
private ArrayList<PoiItem> poiItems;
private List<String> mTitles ; //店面名稱
private List<String> mSnippet ; //店面詳細地址
private LocationAdapter locationAdapter;
@Override
protected int getViewId(Bundle savedInstanceState) {
this.savedInstanceState = savedInstanceState ;
return R.layout.activity_location;
}
@Override
protected void initView() {
//在activity執行onCreate時執行mMapView.onCreate(savedInstanceState),實現地圖生命週期管理
mapView.onCreate(savedInstanceState);
mTitles = new ArrayList<>();
mSnippet = new ArrayList<>();
//初始化地圖控制器對象
if (aMap == null) {
aMap = mapView.getMap();
}
setUpMap();
//1.判斷是否有網 有就自動獲取當前地址 沒有就提示用戶網絡斷了
//2.自動獲取當前地址
}
/**
* 設置一些amap的屬性
*/
private void setUpMap() {
// 自定義系統定位小藍點
MyLocationStyle myLocationStyle = new MyLocationStyle();
myLocationStyle.myLocationIcon(BitmapDescriptorFactory
.fromResource(R.mipmap.location_point));// 設置小藍點的圖標
myLocationStyle.strokeColor(Color.BLACK);// 設置圓形的邊框顏色
myLocationStyle.radiusFillColor(Color.argb(100, 0, 0, 180));// 設置圓形的填充顏色
// myLocationStyle.anchor(int,int)//設置小藍點的錨點
myLocationStyle.strokeWidth(1.0f);// 設置圓形的邊框粗細
aMap.setMyLocationStyle(myLocationStyle);
// 設置定位的類型爲定位模式,有定位、跟隨或地圖根據面向方向旋轉幾種
// aMap.setMyLocationType(AMap.LOCATION_TYPE_LOCATE);
//// aMap.setMyLocationType(AMap.MAP_TYPE_NORMAL);
// aMap.showIndoorMap(true);
// aMap.showBuildings(true);
aMap.moveCamera(CameraUpdateFactory.zoomTo(17));
aMap.setLocationSource(this);// 設置定位監聽
uiSettings = aMap.getUiSettings();
uiSettings.setZoomControlsEnabled(false); //改變大小的圖標爲不可見
aMap.getUiSettings().setMyLocationButtonEnabled(true);// 設置默認定位按鈕是否顯示
aMap.setMyLocationEnabled(true);// 設置爲true表示顯示定位層並可觸發定位,false表示隱藏定位層並不可觸發定位,默認是false
// aMap.setMyLocationType()
}
/**
* 激活定位
*/
@Override
public void activate(OnLocationChangedListener listener) {
mListener = listener;
if (mlocationClient == null) {
//初始化定位
mlocationClient = new AMapLocationClient(this);
//初始化定位參數
mLocationOption = new AMapLocationClientOption();
//設置定位回調監聽
mlocationClient.setLocationListener(this);
//設置爲高精度定位模式
mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);
//設置定位參數
mlocationClient.setLocationOption(mLocationOption);
// 此方法爲每隔固定時間會發起一次定位請求,爲了減少電量消耗或網絡流量消耗,
// 注意設置合適的定位時間的間隔(最小間隔支持爲2000ms),並且在合適時間調用stopLocation()方法來取消定位請求
// 在定位結束後,在合適的生命週期調用onDestroy()方法
// 在單次定位情況下,定位無論成功與否,都無需調用stopLocation()方法移除請求,定位sdk內部會移除
mlocationClient.startLocation();//啓動定位
}
}
/**
* 停止定位
*/
@Override
public void deactivate() {
mListener = null;
if (mlocationClient != null) {
mlocationClient.stopLocation();
mlocationClient.onDestroy();
}
mlocationClient = null;
}
/**
* 定位成功後回調函數
*/
@Override
public void onLocationChanged(AMapLocation amapLocation) {
if (mListener != null&&amapLocation != null) {
if (amapLocation != null
&&amapLocation.getErrorCode() == 0) {
mListener.onLocationChanged(amapLocation);// 顯示系統小藍點
address = amapLocation.getProvince() + amapLocation.getCity() + amapLocation.getDistrict()
+ amapLocation.getStreet() + amapLocation.getStreetNum() ;
doSearchQuery(amapLocation);
deactivate(); //定位一次停止定位
tvCurrentLocation.setText(address);
} else {
String errText = "定位失敗," + amapLocation.getErrorCode()+ ": " + amapLocation.getErrorInfo();
Log.e("AmapErr",errText);
}
}
}
protected void doSearchQuery(AMapLocation amapLocation) {
currentPage = 0;
query = new PoiSearch.Query("", "", amapLocation.getCity());// 第一個參數表示搜索字符串,第二個參數表示poi搜索類型,第三個參數表示poi搜索區域(空字符串代表全國)
query.setPageSize(20);// 設置每頁最多返回多少條poiitem
query.setPageNum(currentPage);// 設置查第一頁
LatLonPoint lp = new LatLonPoint(amapLocation.getLatitude(), amapLocation.getLongitude());
if (lp != null) {
poiSearch = new PoiSearch(this, query);
poiSearch.setOnPoiSearchListener(this);
poiSearch.setBound(new PoiSearch.SearchBound(lp, 1000, true));//
// 設置搜索區域爲以lp點爲圓心,其周圍1000米範圍
poiSearch.searchPOIAsyn();// 異步搜索
}
}
@Override
protected void initData() {
}
@Override
protected void initListener() {
ivBack.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
finish();
}
});
}
@Override
protected void onResume() {
super.onResume();
mapView.onResume();
}
@Override
protected void onDestroy() {
super.onDestroy();
mapView.onDestroy();
if(null != mlocationClient){
mlocationClient.onDestroy();
}
}
@Override
public void onPoiSearched(PoiResult result, int rcode) {
if (rcode == AMapException.CODE_AMAP_SUCCESS) {
if (result != null && result.getQuery() != null) {// 搜索poi的結果
if (result.getQuery().equals(query)) {// 是否是同一條
poiResult = result;
poiItems = poiResult.getPois();// 取得第一頁的poiitem數據,頁數從數字0開始
if (poiItems != null && poiItems.size() > 0) {
//獲取周邊數據成功
for (int i = 0 ; i< poiItems.size() ; i ++)
{
mTitles.add(poiItems.get(i).getTitle());
mSnippet.add(poiItems.get(i).getSnippet()) ;
recyclerview.setLayoutManager(
new LinearLayoutManager(LocationActivity.this,LinearLayoutManager.VERTICAL,false));
locationAdapter = new LocationAdapter(mTitles, mSnippet);
recyclerview.setAdapter(locationAdapter);
}
}
}
}
}
}
@Override
public void onPoiItemSearched(PoiItem poiItem, int i) {
}
}