地位地图

来源:互联网 发布:淘宝网上工作 编辑:程序博客网 时间:2024/04/30 07:11
Android定位SDK
目前国内主要有以下三种坐标系:
1. WGS84:为一种大地坐标系,也是目前广泛使用的GPS全球卫星定位系统使用的坐标系;
2. GCJ02:表示经过国测局加密的坐标;
3. BD09:为百度坐标系,其中bd09ll表示百度经纬度坐标,bd09mc表示百度墨卡托米制坐标;
Android定位SDK产品,支持全球定位,能够精准的获取经纬度信息。根据开发者的设置,在国内获得的坐标系类型可以是:国测局坐标、百度墨卡托坐标 和 百度经纬度坐标。在海外地区,只能获得WGS84坐标。请开发者在使用过程中注意坐标选择。


import相关类
importcom.baidu.location.BDLocation;importcom.baidu.location.BDLocationListener;importcom.baidu.location.LocationClient;importcom.baidu.location.LocationClientOption;importcom.baidu.location.BDNotifyListener;//假如用到位置提醒功能,需要import该类importcom.baidu.location.Poi;
1.创建应用
//获取开发版 :
双击SigningReport 得到开发版SHAl的

//获取发布版 :
Build ---> Generate SSingened AK -->
点击Create new....
key store path :工程所放的位置
Password,Confirm 都是密码统一的
Alias ,First and Last Name :起名

之后点击Next 即可
在Terminal 中进行获取
keytool -v -list -keystore yn.jks
输入密钥库口令:123456(Password,Confirm 和这里的一样)
获取到发布版的SHAl

提交之后得到Key值

就开始在代码中实现咯~~~~~~~
第一步:创建并配置工程(具体方法参见工程配置部分的介绍);
第二步:在AndroidManifest中添加开发密钥、所需权限等信息;
设置AndroidManifest.xml
在Application标签中声明SERVICE组件,每个APP拥有自己单独的定位SERVICE
(1)在application中添加开发密钥
<application><meta-data android:name="com.baidu.lbsapi.API_KEY" android:value="开发者 key"/></application>

<service android:name="com.baidu.location.f" android:enabled="true" android:process=":remote"></service>

2)添加所需权限
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/><uses-permission android:name="android.permission.INTERNET"/><uses-permission android:name="com.android.launcher.permission.READ_SETTINGS"/><uses-permission android:name="android.permission.WAKE_LOCK"/><uses-permission android:name="android.permission.CHANGE_WIFI_STATE"/><uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/><uses-permission android:name="android.permission.GET_TASKS"/><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/><uses-permission android:name="android.permission.WRITE_SETTINGS"/>


libs放个jar包

BaiduLBS_Android.jar





public class LocationActivity extends Activity {

private MapView mapView;
private TextView tv_location;
public LocationClient mLocationClient = null;
public BDLocationListener myListener = new MyLocationListener();
private BaiduMap baiduMap;
private boolean isFirstLoc = true;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//在使用SDK各组件之前初始化context信息,传入ApplicationContext
//注意该方法要再setContentView方法之前实现
SDKInitializer.initialize(getApplicationContext());
setContentView(R.layout.activity_location);
//找控件
mapView = (MapView) findViewById(R.id.mapview);
//获取地图
baiduMap = mapView.getMap();
//开启定位图层
baiduMap.setMyLocationEnabled(true);
tv_location = (TextView) findViewById(R.id.tv_location);
//初始化定位对象 声明LocationClient类
mLocationClient = new LocationClient(getApplicationContext());

//注册监听函数
mLocationClient.registerLocationListener(myListener);

initLocation();
mLocationClient.start();


}

private void initLocation() {
LocationClientOption option = new LocationClientOption();
option.setLocationMode(LocationClientOption.LocationMode.Hight_Accuracy);
//可选,默认高精度,设置定位模式,高精度,低功耗,仅设备

option.setCoorType("bd09ll");
//可选,默认gcj02,设置返回的定位结果坐标系

int span = 1000;
option.setScanSpan(span);
//可选,默认0,即仅定位一次,设置发起定位请求的间隔需要大于等于1000ms才是有效的

option.setIsNeedAddress(true);
//可选,设置是否需要地址信息,默认不需要

option.setOpenGps(true);
//可选,默认false,设置是否使用gps

option.setLocationNotify(true);
//可选,默认false,设置是否当GPS有效时按照1S/1次频率输出GPS结果

option.setIsNeedLocationDescribe(true);
//可选,默认false,设置是否需要位置语义化结果,可以在BDLocation.getLocationDescribe里得到,结果类似于“在北京天安门附近”

option.setIsNeedLocationPoiList(true);
//可选,默认false,设置是否需要POI结果,可以在BDLocation.getPoiList里得到

option.setIgnoreKillProcess(false);
//可选,默认true,定位SDK内部是一个SERVICE,并放到了独立进程,设置是否在stop的时候杀死这个进程,默认不杀死

option.SetIgnoreCacheException(false);
//可选,默认false,设置是否收集CRASH信息,默认收集

option.setEnableSimulateGps(false);
//可选,默认false,设置是否需要过滤GPS仿真结果,默认需要

mLocationClient.setLocOption(option);

}

public class MyLocationListener implements BDLocationListener {

@Override
public void onReceiveLocation(BDLocation location) {

//获取定位结果
StringBuffer sb = new StringBuffer(256);

sb.append("time : ");
sb.append(location.getTime()); //获取定位时间

sb.append("\nerror code : ");
sb.append(location.getLocType()); //获取类型类型

sb.append("\nlatitude : ");
sb.append(location.getLatitude()); //获取纬度信息

sb.append("\nlontitude : ");
sb.append(location.getLongitude()); //获取经度信息

sb.append("\nradius : ");
sb.append(location.getRadius()); //获取定位精准度
//---------------------将地图跟定位关联起来----------------------------------------
MyLocationData locData = new MyLocationData.Builder()
.accuracy(location.getRadius())
// 此处设置开发者获取到的方向信息,顺时针0-360
.direction(100).latitude(location.getLatitude())
.longitude(location.getLongitude()).build();
// 设置定位数据
baiduMap.setMyLocationData(locData);

if (isFirstLoc) {
isFirstLoc = false;
LatLng ll = new LatLng(location.getLatitude(),
location.getLongitude());
MapStatus.Builder builder = new MapStatus.Builder();
builder.target(ll).zoom(18.0f);
baiduMap.animateMapStatus(MapStatusUpdateFactory.newMapStatus(builder.build()));
}
//---------------------将地图跟定位关联起来----------------------------------------

if (location.getLocType() == BDLocation.TypeGpsLocation) {

// GPS定位结果
sb.append("\nspeed : ");
sb.append(location.getSpeed()); // 单位:公里每小时

sb.append("\nsatellite : ");
sb.append(location.getSatelliteNumber()); //获取卫星数

sb.append("\nheight : ");
sb.append(location.getAltitude()); //获取海拔高度信息,单位米

sb.append("\ndirection : ");
sb.append(location.getDirection()); //获取方向信息,单位度

sb.append("\naddr : ");
sb.append(location.getAddrStr()); //获取地址信息

sb.append("\ndescribe : ");
sb.append("gps定位成功");

} else if (location.getLocType() == BDLocation.TypeNetWorkLocation) {

// 网络定位结果
sb.append("\naddr : ");
sb.append(location.getAddrStr()); //获取地址信息

sb.append("\noperationers : ");
sb.append(location.getOperators()); //获取运营商信息

sb.append("\ndescribe : ");
sb.append("网络定位成功");

} else if (location.getLocType() == BDLocation.TypeOffLineLocation) {

// 离线定位结果
sb.append("\ndescribe : ");
sb.append("离线定位成功,离线定位结果也是有效的");

} else if (location.getLocType() == BDLocation.TypeServerError) {

sb.append("\ndescribe : ");
sb.append("服务端网络定位失败,可以反馈IMEI号和大体定位时间到loc-bugs@baidu.com,会有人追查原因");

} else if (location.getLocType() == BDLocation.TypeNetWorkException) {

sb.append("\ndescribe : ");
sb.append("网络不同导致定位失败,请检查网络是否通畅");

} else if (location.getLocType() == BDLocation.TypeCriteriaException) {

sb.append("\ndescribe : ");
sb.append("无法获取有效定位依据导致定位失败,一般是由于手机的原因,处于飞行模式下一般会造成这种结果,可以试着重启手机");

}

sb.append("\nlocationdescribe : ");
sb.append(location.getLocationDescribe()); //位置语义化信息

final List<Poi> list = location.getPoiList(); // POI数据
if (list != null) {
sb.append("\npoilist size = : ");
sb.append(list.size());
for (Poi p : list) {
sb.append("\npoi= : ");
sb.append(p.getId() + " " + p.getName() + " " + p.getRank());
}

}
//此方法运行在子线程
runOnUiThread(new Runnable() {
@Override
public void run() {
tv_location.setText(list.get(2).getName());
}
});
Log.i("BaiduLocationApiDem", sb.toString() + ",目前位置:" + list.get(2).getName());
}

@Override
public void onConnectHotSpotMessage(String s, int i) {

}
}

}

0 0