手把手安卓教學集成高德地圖

前言

在開發當中,我們會常常用到地圖,我們就能很快的想到集成高德或者百度地圖的sdk,選擇高德地圖還是百度地圖呢?根據個人愛好吧。這裏就演示以下如何集成高德地圖的sdk

這裏寫圖片描述

這裏演示的只是一個簡單的頁面

那就可是集成吧。

第一步
到高德地圖開放平臺官網 http://lbs.amap.com/註冊用戶 並且創建應用
註冊就不講了。
現在從創建應用開始
****
這裏寫圖片描述

這裏寫圖片描述

這裏寫圖片描述

這一步很重要的,debug 版 的 SHA1 和 relase 版的 不一樣 。如果你只用了debug 版的 SHA1 的話 ,當應用發佈的時候是獲取不到地址的
這裏寫圖片描述
現在就講一下 debug 和 release 版本的SHA1 是如何獲取的

  1. 打開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) {

    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章