1. 程式人生 > >Android 高德地圖SDK(定位)

Android 高德地圖SDK(定位)

1,高德控制檯申請key網址http://lbs.amap.com/dev/#/
參考http://blog.csdn.net/mwh613245/article/details/52456300
1)SHA1是Android簽名檔案keystore獲取的,一個檔案一個SHA1(除錯版和釋出版可共用)
keytool -v -list -keystore (file)
2)在配置檔案加入以下程式碼保證執行除錯(打包)自動新增keystone

signingConfigs {
        config {
            keyAlias 'mapkeystore'
            keyPassword 'abc123'
storeFile file('/home/user/workspace/mapkeystore.keystore') storePassword 'abc123' }
} buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' signingConfig signingConfigs.config }
debug { signingConfig signingConfigs.config } }

3)包名Manifest中定義的
package=”com.example.user.mapdemo”
4)許可權

    <!--允許程式開啟網路套接字-->
    <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"/>

2,佈局

    <com.amap.api.maps2d.MapView
        android:id="@+id/map"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    </com.amap.api.maps2d.MapView>

3,需要定義的物件

private AMap aMap;
private MapView mapView;
private OnLocationChangedListener mListener;
private AMapLocationClient mlocationClient;
private AMapLocationClientOption mLocationOption;

4,實現介面 implements LocationSource, AMapLocationListener


/**
 * 定位成功後回撥函式
 */
@Override
public void onLocationChanged(AMapLocation amapLocation) {
    if (mListener != null && amapLocation != null) {
        if (amapLocation != null
                && amapLocation.getErrorCode() == 0) {
            mListener.onLocationChanged(amapLocation);// 顯示系統小藍點
        } else {
            String errText = "定位失敗," + amapLocation.getErrorCode()+ ": " + amapLocation.getErrorInfo();
            Log.e("AmapErr",errText);
        }
    }
}

/**
 * 啟用定位
 */
@Override
public void activate(OnLocationChangedListener listener) {
    mListener = listener;
    if (mlocationClient == null) {
        mlocationClient = new AMapLocationClient(this);
        mLocationOption = new AMapLocationClientOption();
        //設定定位監聽
        mlocationClient.setLocationListener(this);
        //設定為高精度定位模式
        mLocationOption.setLocationMode(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;
}

5,MapView設定

mapView.onCreate(savedInstanceState);// 此方法必須重寫
/**
 * 方法必須重寫
 */
@Override
protected void onResume() {
    super.onResume();
    mapView.onResume();
}

/**
 * 方法必須重寫
 */
@Override
protected void onPause() {
    super.onPause();
    mapView.onPause();
    deactivate();
}

/**
 * 方法必須重寫
 */
@Override
protected void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
    mapView.onSaveInstanceState(outState);
}

/**
 * 方法必須重寫
 */
@Override
protected void onDestroy() {
    super.onDestroy();
    mapView.onDestroy();
}

6, AMap

if (aMap == null) {
   aMap = mapView.getMap();
    setUpMap();
}

/**
* 設定一些amap的屬性
 */
private void setUpMap() {
    // 自定義系統定位小藍點
    MyLocationStyle myLocationStyle = new MyLocationStyle();
    myLocationStyle.myLocationIcon(BitmapDescriptorFactory
            .fromResource(R.drawable.location_marker));// 設定小藍點的圖示
    myLocationStyle.strokeColor(Color.BLACK);// 設定圓形的邊框顏色
    myLocationStyle.radiusFillColor(Color.argb(100, 0, 0, 180));// 設定圓形的填充顏色
    // myLocationStyle.anchor(int,int)//設定小藍點的錨點
    myLocationStyle.strokeWidth(1.0f);// 設定圓形的邊框粗細
    aMap.setMyLocationStyle(myLocationStyle);
    aMap.setLocationSource(this);// 設定定位監聽
    aMap.getUiSettings().setMyLocationButtonEnabled(true);// 設定預設定位按鈕是否顯示
    aMap.setMyLocationEnabled(true);// 設定為true表示顯示定位層並可觸發定位,false表示隱藏定位層並不可觸發定位,預設是false
    // aMap.setMyLocationType()
}

完整程式碼

public class MainActivity extends AppCompatActivity implements LocationSource, AMapLocationListener {
    private AMap aMap;
    private MapView mapView;
    private OnLocationChangedListener mListener;
    private AMapLocationClient mlocationClient;
    private AMapLocationClientOption mLocationOption;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mapView = (MapView) findViewById(R.id.map);
        mapView.onCreate(savedInstanceState);// 此方法必須重寫
        init();
    }

    /**
     * 初始化AMap物件
     */
    private void init() {
        if (aMap == null) {
            aMap = mapView.getMap();
            setUpMap();
        }
    }

    /**
     * 設定一些amap的屬性
     */
    private void setUpMap() {
        // 自定義系統定位小藍點
        MyLocationStyle myLocationStyle = new MyLocationStyle();
        myLocationStyle.myLocationIcon(BitmapDescriptorFactory
                .fromResource(R.drawable.location_marker));// 設定小藍點的圖示
        myLocationStyle.strokeColor(Color.BLACK);// 設定圓形的邊框顏色
        myLocationStyle.radiusFillColor(Color.argb(100, 0, 0, 180));// 設定圓形的填充顏色
        // myLocationStyle.anchor(int,int)//設定小藍點的錨點
        myLocationStyle.strokeWidth(1.0f);// 設定圓形的邊框粗細
        aMap.setMyLocationStyle(myLocationStyle);
        aMap.setLocationSource(this);// 設定定位監聽
        aMap.getUiSettings().setMyLocationButtonEnabled(true);// 設定預設定位按鈕是否顯示
        aMap.setMyLocationEnabled(true);// 設定為true表示顯示定位層並可觸發定位,false表示隱藏定位層並不可觸發定位,預設是false
        // aMap.setMyLocationType()
    }

    /**
     * 方法必須重寫
     */
    @Override
    protected void onResume() {
        super.onResume();
        mapView.onResume();
    }

    /**
     * 方法必須重寫
     */
    @Override
    protected void onPause() {
        super.onPause();
        mapView.onPause();
        deactivate();
    }

    /**
     * 方法必須重寫
     */
    @Override
    protected void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);
        mapView.onSaveInstanceState(outState);
    }

    /**
     * 方法必須重寫
     */
    @Override
    protected void onDestroy() {
        super.onDestroy();
        mapView.onDestroy();
    }

    /**
     * 定位成功後回撥函式
     */
    @Override
    public void onLocationChanged(AMapLocation amapLocation) {
        if (mListener != null && amapLocation != null) {
            if (amapLocation != null
                    && amapLocation.getErrorCode() == 0) {
                mListener.onLocationChanged(amapLocation);// 顯示系統小藍點
            } else {
                String errText = "定位失敗," + amapLocation.getErrorCode()+ ": " + amapLocation.getErrorInfo();
                Log.e("AmapErr",errText);
            }
        }
    }

    /**
     * 啟用定位
     */
    @Override
    public void activate(OnLocationChangedListener listener) {
        mListener = listener;
        if (mlocationClient == null) {
            mlocationClient = new AMapLocationClient(this);
            mLocationOption = new AMapLocationClientOption();
            //設定定位監聽
            mlocationClient.setLocationListener(this);
            //設定為高精度定位模式
            mLocationOption.setLocationMode(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;
    }
}