Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> 關於Android編程 >> Android 高德地圖SDK(定位)

Android 高德地圖SDK(定位)

編輯:關於Android編程

1,高德控制台申請key網址http://lbs.amap.com/dev/
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)權限

    
    
    
    
    
    
    
    
    
    
    
    

2,布局

    
    

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;
    }
}
  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved