地位地图

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


import相关类
import com.baidu.location.BDLocation ; import com.baidu.location.BDLocationListener ; import com.baidu.location.LocationClient ; import com.baidu.location.LocationClientOption ; import com.baidu.location.BDNotifyListener ; //假如用到位置提醒功能,需要import该类 import com.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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
未来社区的建设背景和需求分析指出,随着智能经济、大数据、人工智能、物联网、区块链、云计算等技术的发展,社区服务正朝着数字化、智能化转型。社区服务渠道由分散向统一融合转变,服务内容由通用庞杂向个性化、服务导向转变。未来社区将构建数字化生态,实现数据在线、组织在线、服务在线、产品智能和决策智能,赋能企业创新,同时注重人才培养和科研平台建设。 规划设计方面,未来社区将基于居民需求,打造以服务为中心的社区管理模式。通过统一的服务平台和应用,实现服务内容的整合和优化,提供灵活多样的服务方式,如推送式、订阅式、热点式等。社区将构建数据与应用的良性循环,提高服务效率,同时注重生态优美、绿色低碳、社会和谐,以实现幸福民生和产业发展。 建设运营上,未来社区强调科学规划、以人为本,创新引领、重点突破,统筹推进、整体提升。通过实施院落+社团自治工程,转变政府职能,深化社区自治法制化、信息化,解决社区治理中的重点问题。目标是培养有活力的社会组织,提高社区居民参与度和满意度,实现社区治理服务的制度机制创新。 未来社区的数字化解决方案包括信息发布系统、服务系统和管理系统。信息发布系统涵盖公共服务类和社会化服务类信息,提供政策宣传、家政服务、健康医疗咨询等功能。服务系统功能需求包括办事指南、公共服务、社区工作参与互动等,旨在提高社区服务能力。管理系统功能需求则涉及院落管理、社团管理、社工队伍管理等,以实现社区治理的现代化。 最后,未来社区建设注重整合政府、社会组织、企业等多方资源,以提高社区服务的效率和质量。通过建立社区管理服务综合信息平台,提供社区公共服务、社区社会组织管理服务和社区便民服务,实现管理精简、高效、透明,服务快速、便捷。同时,通过培育和发展社区协会、社团等组织,激发社会化组织活力,为居民提供综合性的咨询和服务,促进社区的和谐发展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值