高德地图定位、添加定位图标、连线(一)
2016-06-16 09:40
961 查看
一、定位
若只要定位功能而不需要显示出地图,只需添加AMap_Location_V2.4.1_20160414.jar一个jar包即可;
1、AndroidMainfests.xml文件
1)添加服务
2)添加权限
3)添加key
高德地图获取key的过程需要SHA1和程序的包名,包名在AndroidMainfests.xml文件中就可以获取;但是SHA1的获取就不是那么简单了,对于eclipse来说可以直接查看,但是android studio就不可以了,可以查看高德地图的获取SHA1 文档:高德地图获取SHA1或者直接查看我的博客studio获取SHA1
2、定位
1)声明
2)初始化
3)设置定位监听
4)实现AMapLocationListener监听方法
5)设置定位参数
6)停止定位
7)销毁定位客户端
完整代码:
若只要定位功能而不需要显示出地图,只需添加AMap_Location_V2.4.1_20160414.jar一个jar包即可;
1、AndroidMainfests.xml文件
1)添加服务
<service android:name="com.amap.api.location.APSService" />
2)添加权限
<!-- 用于进行网络定位 --> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <!-- 用于访问GPS定位 --> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> <!-- 获取运营商信息,用于支持提供运营商信息相关的接口 --> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <!-- 用于访问wifi网络信息,wifi信息会用于进行网络定位 --> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <!-- 这个权限用于获取wifi的获取权限,wifi信息会用来进行网络定位 --> <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /> <!-- 用于访问网络,网络定位需要上网 --> <uses-permission android:name="android.permission.INTERNET" /> <!-- 用于读取手机当前的状态 --> <uses-permission android:name="android.permission.READ_PHONE_STATE" /> <!-- 写入扩展存储,向扩展卡写入数据,用于写入缓存定位数据 --> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
3)添加key
<!-- key修改为自己的key --> <meta-data android:name="com.amap.api.v2.apikey" android:value="37c2a41b3b209d90c4a0e8f17c5965a6" />
高德地图获取key的过程需要SHA1和程序的包名,包名在AndroidMainfests.xml文件中就可以获取;但是SHA1的获取就不是那么简单了,对于eclipse来说可以直接查看,但是android studio就不可以了,可以查看高德地图的获取SHA1 文档:高德地图获取SHA1或者直接查看我的博客studio获取SHA1
2、定位
1)声明
//声明AMapLocationClient类对象 public AMapLocationClient mLocationClient = null; //声明定位回调监听器 public AMapLocationListener mLocationListener = null; //声明mLocationOption对象 public AMapLocationClientOption mLocationOption = null;
2)初始化
//初始化定位 mLocationClient = new AMapLocationClient(getApplicationContext()); //初始化定位回调监听 mLocationListener = new AMapLocationListener() {……(看4))} //初始化定位参数mLocationOption对象 mLocationOption = new AMapLocationClientOption();
3)设置定位监听
mLocationClient.setLocationListener(mLocationListener);
4)实现AMapLocationListener监听方法
@Override public void onLocationChanged(AMapLocation aMapLocation) { if (aMapLocation != null) { if (aMapLocation.getErrorCode() == 0) { //定位成功回调信息,设置相关消息 aMapLocation.getLocationType();//获取当前定位结果来源,如网络定位结果,详见定位类型表 aMapLocation.getLatitude();//获取纬度 aMapLocation.getLongitude();//获取经度 aMapLocation.getAccuracy();//获取精度信息 SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); Date date = new Date(aMapLocation.getTime()); df.format(date);//定位时间 aMapLocation.getAddress();//地址,如果option中设置isNeedAddress为false,则没有此结果,网络定位结果中会有地址信息,GPS定位不返回地址信息。 aMapLocation.getCountry();//国家信息 aMapLocation.getProvince();//省信息 aMapLocation.getCity();//城市信息 aMapLocation.getDistrict();//城区信息 aMapLocation.getStreet();//街道信息 aMapLocation.getStreetNum();//街道门牌号信息 aMapLocation.getCityCode();//城市编码 aMapLocation.getAdCode();//地区编码 aMapLocation.getAoiName();//获取当前定位点的AOI信息 Log.e("--------->","城市"+aMapLocation.getCity()); } else { //显示错误信息ErrCode是错误码,errInfo是错误信息,详见错误码表。 Log.e("AmapError", "location Error, ErrCode:" + aMapLocation.getErrorCode() + ", errInfo:" + aMapLocation.getErrorInfo()); } } }
5)设置定位参数
//初始化定位参数 mLocationOption = new AMapLocationClientOption(); //设置定位模式为高精度模式,Battery_Saving为低功耗模式,Device_Sensors是仅设备模式 mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy); //设置是否返回地址信息(默认返回地址信息) mLocationOption.setNeedAddress(true); //设置是否只定位一次,默认为false mLocationOption.setOnceLocation(false); //设置是否强制刷新WIFI,默认为强制刷新 mLocationOption.setWifiActiveScan(true); //设置是否允许模拟位置,默认为false,不允许模拟位置 mLocationOption.setMockEnable(false); //设置定位间隔,单位毫秒,默认为2000ms mLocationOption.setInterval(2000); //给定位客户端对象设置定位参数 mLocationClient.setLocationOption(mLocationOption); //启动定位 mLocationClient.startLocation();
6)停止定位
@Override protected void onStop() { super.onStop(); mLocationClient.stopLocation();//停止定位 }
7)销毁定位客户端
@Override protected void onDestroy() { super.onDestroy(); mLocationClient.onDestroy();//销毁定位客户端。 }
完整代码:
public class MapActivity extends AppCompatActivity {
//声明AMapLocationClient类对象
public AMapLocationClient mLocationClient = null;
//声明定位回调监听器
public AMapLocationListener mLocationListener = null;
//声明mLocationOption对象
public AMapLocationClientOption mLocationOption = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_map);
//初始化定位
mLocationClient = new AMapLocationClient(getApplicationContext());
mLocationListener = new AMapLocationListener() {
@Override
public void onLocationChanged(AMapLocation aMapLocation) {
if (aMapLocation != null) {
if (aMapLocation.getErrorCode() == 0) {
//定位成功回调信息,设置相关消息
aMapLocation.getLocationType();//获取当前定位结果来源,如网络定位结果,详见定位类型表
aMapLocation.getLatitude();//获取纬度
aMapLocation.getLongitude();//获取经度
aMapLocation.getAccuracy();//获取精度信息
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date date = new Date(aMapLocation.getTime());
df.format(date);//定位时间
aMapLocation.getAddress();//地址,如果option中设置isNeedAddress为false,则没有此结果,网络定位结果中会有地址信息,GPS定位不返回地址信息。
aMapLocation.getCountry();//国家信息
aMapLocation.getProvince();//省信息
aMapLocation.getCity();//城市信息
aMapLocation.getDistrict();//城区信息
aMapLocation.getStreet();//街道信息
aMapLocation.getStreetNum();//街道门牌号信息
aMapLocation.getCityCode();//城市编码
aMapLocation.getAdCode();//地区编码
aMapLocation.getAoiName();//获取当前定位点的AOI信息
Log.e("--------->","aMapLocation.getCity();"+aMapLocation.getCity());
} else {
//显示错误信息ErrCode是错误码,errInfo是错误信息,详见错误码表。
Log.e("AmapError", "location Error, ErrCode:"
+ aMapLocation.getErrorCode() + ", errInfo:"
+ aMapLocation.getErrorInfo());
}
}
}
};
//设置定位回调监听
mLocationClient.setLocationListener(mLocationListener);
//初始化定位参数
mLocationOption = new AMapLocationClientOption();
//设置定位模式为高精度模式,Battery_Saving为低功耗模式,Device_Sensors是仅设备模式
mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);
//设置是否返回地址信息(默认返回地址信息)
mLocationOption.setNeedAddress(true);
//设置是否只定位一次,默认为false
mLocationOption.setOnceLocation(false);
//设置是否强制刷新WIFI,默认为强制刷新
mLocationOption.setWifiActiveScan(true);
//设置是否允许模拟位置,默认为false,不允许模拟位置
mLocationOption.setMockEnable(false);
//设置定位间隔,单位毫秒,默认为2000ms
mLocationOption.setInterval(2000);
//给定位客户端对象设置定位参数
mLocationClient.setLocationOption(mLocationOption);
//启动定位
mLocationClient.startLocation();
}
@Override protected void onStop() { super.onStop(); mLocationClient.stopLocation();//停止定位 }
@Override protected void onDestroy() { super.onDestroy(); mLocationClient.onDestroy();//销毁定位客户端。 }
}
相关文章推荐
- 从sap xi生产wsdl文件,客户端怎么做webservice?
- android 代码片段整理
- swiper的使用(一)
- Android 之 activity切换动画
- Linux统计某文件夹下文件、文件夹的个数
- 详解ABP框架中Session功能的使用方法
- 随机森林(Random Forest)
- svchost.exe占用cpu过高的问题(适合和我一样的电脑小白)
- Linux进程地址管理之mm_struct
- add & foreach (remove)
- SQL Server中变量的声明和使用方法
- php 访问对象的属性(当属性的键名称为数字时)的方法 {}
- 和lock一起学beego 博客系统开发为例(三)
- Android Studio编译程序出现finished with non-zero exit value 2错误
- Spark join和cogroup算子
- Ubuntu Server 14.04.1 LTS安装JDK
- 记录iptables
- Wpf 弹出窗口
- android的图片的如何进行比较
- Java新手如何学习Spring、Struts、Hibernate三大框架?