3. 定位并添加Marker


效果图

这里写图片描述

1. 配置AndroidManifest.xml

1.1 声明Service组件

拥有自己单独的定位service。

<service android:name="com.amap.api.location.APSService"></service>

1.2 声明权限

<!--用于进行网络定位-->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"></uses-permission>
<!--用于访问GPS定位-->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
<!--用于获取运营商信息,用于支持提供运营商信息相关的接口-->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
<!--用于访问wifi网络信息,wifi信息会用于进行网络定位-->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
<!--用于获取wifi的获取权限,wifi信息会用来进行网络定位-->
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission>
<!--用于访问网络,网络定位需要上网-->
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<!--用于读取手机当前的状态-->
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
<!--用于写入缓存数据到扩展存储卡-->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<!--用于申请调用A-GPS模块-->
<uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS"></uses-permission>
<!--用于申请获取蓝牙信息进行室内定位-->
<uses-permission android:name="android.permission.BLUETOOTH"></uses-permission>
<uses-permission android:name="android.permission.BLUETOOTH_ADMIN"></uses-permission>

2. 初始化定位

mLocationClient = new AMapLocationClient(getApplicationContext());

mLocationClient.setLocationListener(this);//设置定位回调监听,实现AMapLocationListener接口

3. 配置参数并启动定位

AMapLocationClientOption对象用来设置发起定位的模式和相关参数。

/**
  *  配置参数并启动定位
  */
 AMapLocationClientOption mLocationOption = new AMapLocationClientOption();
 //SDK默认采用连续定位模式,时间间隔2000ms。如果您需要自定义调用间隔:
 mLocationOption.setInterval(2000);
 //设置是否返回地址信息(默认返回地址信息)
 mLocationOption.setNeedAddress(true);
 //设置为高精度定位模式  mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);

//获取一次定位结果:
//该方法默认为false。
//  mLocationOption.setOnceLocation(true);

//获取最近3s内精度最高的一次定位结果:
//设置setOnceLocationLatest(boolean b)接口为true,启动定位时SDK会返回最近3s内精度最高的一次定位结果。如果设置其为true,setOnceLocation(boolean b)接口也会被设置为true,反之不会,默认为false。
//  mLocationOption.setOnceLocationLatest(true);

//单位是毫秒,默认30000毫秒,建议超时时间不要低于8000毫秒。
mLocationOption.setHttpTimeOut(20000);

//关闭缓存机制
mLocationOption.setLocationCacheEnable(false);

//设置定位参数
mLocationClient.setLocationOption(mLocationOption);

mLocationClient.startLocation();//启动定位

4. 获取定位结果

实现AMapLocationListener接口

@Override
public void onLocationChanged(AMapLocation amapLocation) {

}

5. 停止定位

mLocationClient.stopLocation();//停止定位后,本地定位服务并不会被销毁

销毁定位客户端(放在Activity的onDestroy方法中)

    @Override
    protected void onDestroy() {
        super.onDestroy();
        //在activity执行onDestroy时执行mMapView.onDestroy(),销毁地图
        mMapView.onDestroy();

        if (mLocationClient != null) {
            mLocationClient.onDestroy();//销毁定位客户端,同时销毁本地定位服务。
        }
    }

6. 添加Marker, 显示自己当前的位置

MarkerOptions 是设置 Marker 参数变量的类

Marker 常用属性

名称 说明
position 在地图上标记位置的经纬度值。必填参数
title 点标记的标题
snippet 点标记的内容
draggable 点标记是否可拖拽
visible 点标记是否可见
anchor 点标记的锚点
alpha 点的透明度

public void addMarker(LatLng latlng) {
     MarkerOptions options = new MarkerOptions();
     options.icon(BitmapDescriptorFactory.fromBitmap(BitmapFactory.decodeResource(this.getResources(),
             R.mipmap.gps_point)));

     options.anchor(0.5f, 0.5f);
     options.position(latlng);
     mLocMarker = aMap.addMarker(options);//添加到地图上
 }

在定位的回调中添加Marker

  /**
     * 获取定位结果
     *
     * @param aMapLocation
     */
    @Override
    public void onLocationChanged(AMapLocation aMapLocation) {
        if (aMapLocation != null && aMapLocation.getErrorCode() == 0) {//可在其中解析amapLocation获取相应内容。

            LatLng location = new LatLng(aMapLocation.getLatitude(), aMapLocation.getLongitude());

            if (!mFirstFix) {
                mFirstFix = true;
                addMarker(location);//添加定位图标
                aMap.animateCamera(CameraUpdateFactory.newLatLngZoom(location, 16f));//AMap类中提供,带有移动过程的动画
            } else {
                mLocMarker.setPosition(location);
                aMap.animateCamera(CameraUpdateFactory.changeLatLng(location));
            }
            mLocationClient.stopLocation();//停止定位后,本地定位服务并不会被销毁

        } else {//定位失败时,可通过ErrCode(错误码)信息来确定失败的原因,errInfo是错误信息,详见错误码表。
            Log.e("AmapError", "location Error, ErrCode:"
                    + aMapLocation.getErrorCode() + ", errInfo:"
                    + aMapLocation.getErrorInfo());
        }
    }

源码

https://github.com/qiwei0727/MapDemo/tree/master

说明:

1. Android 6.0及以上系统需要动态申请权限
2. 改变地图的中心点
CameraUpdateFactory.newLatLngZoom(location, 16f)
3. AMap类中提供,带有移动过程的动画
animateCamera(CameraUpdate cameraupdate,long duration,AMap.CancelableCallback cancelablecallback);

转载自:https://blog.csdn.net/bruce_qiwei/article/details/77337594

You may also like...