如何百度地图自定义图层地图图层

iOS 地图SDK | 高德地图API
功能解决方案
您现在的位置: >
> 地图图层
高德地图 iOS SDK 提供多种类型的地图图层,地图效果丰富和有意义,与此同时,您还可以附加您自己的图层,在地图上显示个性化定制数据。
说明:以下示例代码都基于“”中初始化并添加到Subview中的_mapView对象。
高德地图iOS SDK为3D矢量地图SDK提供三种地图类型MAMapTypeStandard、MAMapTypeSatellite和MAMapTypeStandardNight;为2D栅格地图SDK提供两种地图类型MAMapTypeStandard和MAMapTypeSatellite。其中:MAMapTypeStandard为标准地图,MAMapTypeSatellite为卫星地图,MAMapTypeStandardNight为夜景地图。
地图默认显示标准地图,从标准地图切换成卫星地图的方法如下:
//显示卫星地图
_mapView.mapType = MAMapTypeS
运行程序效果如下:
说明:地图类型切换只需将地图类型设置成相应的类型(MAMapTypeStandard/MAMapTypeSatellite/MAMapTypeStandardNight)。
实时交通图层
高德地图 iOS SDK提供北京,上海,广州,深圳,武汉,沈阳,南京,宁波,重庆,杭州,青岛,成都,天津,大连,无锡,西安,石家庄,太原,常州,厦门,长春,福州,珠海,东莞,长沙,苏州,金华,佛山,济南,泉州,西宁,乌鲁木齐,嘉兴,香港,鄂尔多斯,南通,中山,惠州,镇江,郑州,合肥,昆明,德州,朝阳,抚顺,大同,荆州,温州,台州,绍兴,莆田,南平,漳州,宁德,三明,龙岩,烟台,阳江,江门,保定,临沂61个城市及城际间的实时交通路况。
显示实时交通路况的代码如下:
_mapView.showTraffic= YES;
运行后效果如下:
热力图图层
热力图图层是以颜色变化展现分布情况的图层。高德地图iOS SDK自V2.6.0版本提供了热力图图层的绘制功能,开发者可利用自有数据(入学热力图、人流热力图等等),创建可用于指导您决策的热力图。
在地图上添加热力图的步骤如下:
1.构造MAHeatMapTileOverlay 对象。
2.配置热力图图层的参数。
&&&&a) data——数据数组,数组中是 MAHeatMapNode 对象(包含:点坐标和权重值)。
&&&&b) radius——半径,默认值为 12ps。
&&&&c) opacity——透明度,默认值为 0.6。
&&&&d) gradient——渐变色对象。
3.将MAHeatMapTileOverlay添加到MAMapView中。
4.实现MAMapViewDelegate的mapView:viewForOverlay:函数,在地图上显示热力图图层。
我们提前将数据将存放在locations.json文件中。在地图上添加热力图的示例代码如下:
//构造热力图图层对象
MAHeatMapTileOverlay
*heatMapTileOverlay = [[MAHeatMapTileOverlay alloc] init];
//构造热力图数据,从locations.json中读取经纬度
NSMutableArray* data = [NSMutableArray array];
NSData *jsdata = [NSData dataWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"locations" ofType:@"json"]];
@autoreleasepool {
if (jsdata)
NSArray *dicArray = [NSJSONSerialization JSONObjectWithData:jsdata options:NSJSONReadingAllowFragments error:nil];
for (NSDictionary *dic in dicArray)
MAHeatMapNode *node = [[MAHeatMapNode alloc] init];
CLLocationCoordinate2D
coordinate.latitude = [dic[@"lat"] doubleValue];
coordinate.longitude = [dic[@"lng"] doubleValue];
node.coordinate =
node.intensity = 1;//设置权重
[data addObject:node];
heatMapTileOverlay.data =
//构造渐变色对象
MAHeatMapGradient *gradient = [[MAHeatMapGradient alloc] initWithColor:@[[UIColor blueColor],[UIColor greenColor], [UIColor redColor]] andWithStartPoints:@[@(0.2),@(0.5),@(0.9)]];
heatMapTileOverlay.gradient =
//将热力图添加到地图上
[_mapView addOverlay: heatMapTileOverlay];
实现MAMapViewDelegate的mapView:viewForOverlay:函数,在热力图显示在地图View上。示例代码如下:
- (MAOverlayView *)mapView:(MAMapView *)mapView viewForOverlay:(id )overlay
if ([overlay isKindOfClass:[MATileOverlay class]])
MATileOverlayView *tileOverlayView = [[MATileOverlayView alloc] initWithTileOverlay:overlay];
return tileOverlayV
运行效果如下所示:
自定义图层
通过自定义图层可对基础底层地图添加额外的特性,如:某个商场的室内信息、某个景区的详情等等。自定义图层类是MATileOverlay,它定义了能添加到基础底层地图的图片集合。
添加自定义图层的前提是使用球面墨卡托投影生成了相应的瓦片,并按照生成的格式部署在服务器上。在地图上显示自定义图层的步骤如下:
根据URL模版(即指向相关图层图片的URL)创建MATileOverlay对象。
设置MATileOverlay的可见最大/最小Zoom值。
设定MATileOverlay的可渲染区域。
将MATileOverlay对象添加到MAMapView中。
我们提前准备了西单大悦城的1-3层楼的瓦片,并部署到了服务器上。在地图上显示朝阳大悦城2层瓦片的示例代码如下:
(1) 修改ViewController.m文件,在viewDidLoad方法中构造2层的对应的MATileOverlay对象,并添加到地图上。
#define TileOverlayViewControllerCoordinate CLLocationCoordinate2DMake(39.6.372830)
- (MATileOverlay *)constructTileOverlayWithFloor:(NSInteger)floor
/* 构建tileOverlay的URL模版. */
NSString *URLTemplate = [NSString stringWithFormat: @":8080/tileserver/Tile?x={x}&y={y}&z={z}&f=%ld", (long)floor];
MATileOverlay *tileOverlay = [[MATileOverlay alloc] initWithURLTemplate:URLTemplate];
tileOverlay.minimumZ = 18; //设置可见最小Zoom值
tileOverlay.maximumZ = 20; //设置可见最大Zoom值
tileOverlay.boundingMapRect = MAMapRectForCoordinateRegion(MACoordinateRegionMakeWithDistance(TileOverlayViewControllerCoordinate, 200, 200)); //设置可渲染区域
return tileO
- (void)viewDidLoad
[super viewDidLoad];
self.mapView.centerCoordinate
= TileOverlayViewControllerC
self.mapView.zoomLevel
[self.mapView addOverlay: [self constructTileOverlayWithFloor:2]];
(2) 实现MAMapViewDelegate的mapView:viewForOverlay:函数,在瓦片显示在地图View上。示例代码如下:
- (MAOverlayView *)mapView:(MAMapView *)mapView viewForOverlay:(id )overlay
if ([overlay isKindOfClass:[MATileOverlay class]])
MATileOverlayView *tileOverlayView = [[MATileOverlayView alloc] initWithTileOverlay:overlay];
return tileOverlayV
运行效果如下图所示:
该文档对您是否有帮助?
您的点滴建议,将有助于开发文档的快速完善。
感谢您的建议!
本文档由 酸奶小妹,欢仔 共同提出改进建议。
(C) 2002- 版权所有 | 京ICP证070711号Android应用中使用百度地图API定位自己的位置(二) - 推酷
Android应用中使用百度地图API定位自己的位置(二)
官方文档:
百度地图SDK为开发者们提供了如下类型的地图覆盖物:
我的位置图层(MyLocationOverlay):用于显示用户当前位置的图层(支持自定义位置图标);
Poi搜索结果图层(PoiOverlay):用于显示兴趣点搜索结果的图层;
路线图层(RouteOverlay):公交、步行和驾车线路图层,将公交、步行和驾车出行方案的路线及关键点显示在地图上(起、终点图标用户可自定义);
公交换乘图层(TransitOverlay):公交换乘线路图层,将某一特定地区的公交出行方案的路线及换乘位置显示在地图上(起、终点图标用户可自定义);
自定义图层(ItemizedOverlay):可将一个或多个兴趣点绘制到地图上,且支持自定义图标(支持动态更新Item位置、图标);
弹出窗图层(PopupOverlay):在地图上显示一个弹出窗口;
几何图形绘制图层(GraphicsOverlay):用于绘制点、折线段、弧线、圆、矩形、多边形等几何图形的图层;
文字绘制图层(TextOverlay):用于绘制文字的图层。
图片图层(GroundOverlay):用于展示用户传入图片的图层。
全景图图层(PanoramaOverlay):在全景图内标绘兴趣点,支持自定义图标样式。
注:除弹出窗图层外,其他各个图层均已实现多实例。全景图图层是针对全景图所使用的特殊图层。
MapView使用一个List管理覆盖物,通过向MapView.getOverlays() add或remove上述类或其基类的实例即可向地图添加或删除覆盖物。在更新地图覆盖物后,需调用MapView.refresh() 使更新生效。
使用百度Android定位SDK必须注册GPS和网络使用权限。定位SDK采用GPS、基站、Wi-Fi信号进行定位。当应用程序向定位SDK发起定位请求时,定位SDK会根据应用的定位因素(GPS、基站、Wi-Fi信号)的实际情况(如是否开启GPS、是否连接网络、是否有信号等)来生成相应定位依据进行定位。
用户可以设置满足自身需求的定位依据:
若用户设置GPS优先,则优先使用GPS进行定位,如果GPS定位未打开或者没有可用位置信息,且网络连接正常,定位SDK则会返回网络定位(即Wi-Fi与基站)的最优结果。为了使获得的网络定位结果更加精确,请打开手机的Wi-Fi开关。
下面我们将利用 &
MyLocationOverlay
PopupOverlay&
一 . 导入库文件
在使用百度定位SDKv4.0之前,我们要下载最新的库文件,下载地址:
,将liblocSDK4.so文件拷贝到libs/armeabi目录下。将locSDK4.0.jar文件拷贝到工程的libs目录下
目录结构如下:
&库文件下载地址:
二 . 布局文件,一个百度地图控件,加一个手动点击实现定位的按钮
&?xml version=&1.0& encoding=&utf-8&?&
&RelativeLayout xmlns:android=&/apk/res/android&
android:layout_width=&fill_parent&
android:layout_height=&fill_parent&
&com.baidu.mapapi.map.MapView
android:id=&@+id/bmapView&
android:layout_width=&fill_parent&
android:layout_height=&fill_parent&
android:clickable=&true&
android:id=&@+id/request&
android:layout_width=&wrap_content&
android:layout_height=&wrap_content&
android:layout_alignParentRight=&true&
android:layout_alignParentTop=&true&
android:layout_marginRight=&10dp&
android:layout_marginTop=&10dip&
android:background=&@drawable/mylocation&
&/RelativeLayout&
然后是主 Activity
package com.majianjie.
import android.app.A
import android.graphics.B
import android.graphics.drawable.D
import android.os.B
import android.view.LayoutI
import android.view.M
import android.view.MenuI
import android.view.V
import android.view.View.MeasureS
import android.widget.B
import android.widget.TextV
import android.widget.T
import com.baidu.location.BDL
import com.baidu.location.BDLocationL
import com.baidu.location.LocationC
import com.baidu.location.LocationClientO
import com.baidu.mapapi.BMapM
import com.baidu.mapapi.MKGeneralL
import com.baidu.mapapi.map.LocationD
import com.baidu.mapapi.map.MKE
import com.baidu.mapapi.map.MKMapViewL
import com.baidu.mapapi.map.MapC
import com.baidu.mapapi.map.MapP
import com.baidu.mapapi.map.MapV
import com.baidu.mapapi.map.MyLocationO
import com.baidu.mapapi.map.PopupClickL
import com.baidu.mapapi.map.PopupO
import com.api.basestruct.GeoP
import com.example.baidumap.R;
public class MainActivity extends Activity {
//声明控件
private Toast mToast=
private BMapManager mBMapManager=
private MapView mMapView =
//MapView 是地图主控件
private MapController mMapController =//用MapController完成地图控制
private LocationClient mLocC
public LocationData mLocData =
private LocationOverlay myLocationOverlay =//定位图层
private boolean isRequest =//是否手动触发请求定位
private boolean isFirstLoc =//是否首次定位
private PopupOverlay mPopupOverlay
=//弹出泡泡图层,浏览节点时使用
private View viewCache=
public BDLocation location = new BDLocation();
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//**使用地图sdk前需先初始化BMapManager,这个必须在setContentView()先初始化
mBMapManager = new BMapManager(this);
//第一个参数是API key,
第二个参数是常用事件监听,用来处理通常的网络错误,授权验证错误等,你也可以不添加这个回调接口
mBMapManager.init(&LDtH1sVwr7kygaF0aTqaVwWU&, new MKGeneralListener() {
//授权错误的时候调用的回调函数
public void onGetPermissionState(int iError) {
if (iError ==
MKEvent.ERROR_PERMISSION_DENIED) {
showToast(&API KEY错误, 请检查!&);
//一些网络状态的错误处理回调函数
public void onGetNetworkState(int iError) {
if (iError == MKEvent.ERROR_NETWORK_CONNECT) {
Toast.makeText(getApplication(), &您的网络出错啦!&, Toast.LENGTH_LONG).show();
//单击事件
//* 显示Toast消息
private void showToast(String msg){
if(mToast == null){
mToast = Toast.makeText(this, msg, Toast.LENGTH_SHORT);
mToast.setText(msg);
mToast.setDuration(Toast.LENGTH_SHORT);
mToast.show();
private void click() {
request.setOnClickListener(new View.OnClickListener() {
public void onClick(View arg0) {
requestLocation();
protected void onResume() {
//MapView的生命周期与Activity同步,当activity挂起时需调用MapView.onPause()
mMapView.onResume();
mBMapManager.start();//重新启动
super.onResume();
protected void onPause() {
//MapView的生命周期与Activity同步,当activity挂起时需调用MapView.onPause()
mMapView.onPause();
super.onPause();
private void init() {
//使用自定义的title,注意顺序
setContentView(R.layout.activity_main);
//activity的布局
//这里是添加自己定义的titlebtn.xml
//通过id找到他们
mMapView = (com.baidu.mapapi.map.MapView) findViewById(R.id.bmapView);
mMapController=mMapView.getController(); //获取地图控制器
mMapController.enableClick(true);
//设置地图是否响应点击事件
request=(Button)findViewById(R.id.request);
viewCache = LayoutInflater.from(this).inflate(R.layout.pop_layout, null);
mPopupOverlay= new PopupOverlay(mMapView, new PopupClickListener() {// * 点击弹出窗口图层回调的方法
public void onClickedPopup(int arg0) {
//隐藏弹出窗口图层
mPopupOverlay.hidePop();
mMapController.enableClick(true);
设置地图是否响应点击事件
mMapController.setZoom(12);
// * 设置地图缩放级别
mMapView.setBuiltInZoomControls(true);
// * 显示内置缩放控件
mMapView.setTraffic(true);
mLocData = new LocationData();
mLocClient = new LocationClient(getApplicationContext());
* 定位SDK的核心类
//实例化定位服务,LocationClient类必须在主线程中声明
mLocClient.registerLocationListener(new BDLocationListenerImpl());//注册定位监听接口
* 设置定位参数
LocationClientOption option = new LocationClientOption();
option.setOpenGps(true); //打开GPRS
option.setAddrType(&all&);//返回的定位结果包含地址信息
option.setCoorType(&bd09ll&);//返回的定位结果是百度经纬度,默认值gcj02
option.setScanSpan(5000); //设置发起定位请求的间隔时间为5000ms
option.disableCache(false);//禁止启用缓存定位
option.setPoiNumber(5);
//最多返回POI个数
option.setPoiDistance(1000); //poi查询距离
option.setPoiExtraInfo(true);
//是否需要POI的电话和地址等详细信息
mLocClient.setLocOption(option);
mLocClient.start();
// 调用此方法开始定位
myLocationOverlay = new LocationOverlay(mMapView);//定位图层初始化
//将定位数据设置到定位图层里
myLocationOverlay.setMarker(getResources().getDrawable(R.drawable.set));
//添加定位图层
mMapView.getOverlays().add(myLocationOverlay);
myLocationOverlay.enableCompass();
//更新图层数据执行刷新后生效
mMapView.refresh();
//准备要添加的Overlay
double mLat1 = 39.910159;
double mLon1 = 119.544697;
// 用给定的经纬度构造GeoPoint,单位是微度 (度 * 1E6)
GeoPoint p1 = new GeoPoint((int) (mLat1 * 1E6), (int) (mLon1 * 1E6));
//准备overlay图像数据,根据实情情况修复
Drawable mark= getResources().getDrawable(R.drawable.set);
//用OverlayItem准备Overlay数据
OverlayItem item1 = new OverlayItem(p1,&item1&,&item1&);
//使用setMarker()方法设置overlay图片,如果不设置则使用构建ItemizedOverlay时的默认设置
//创建IteminizedOverlay
CustomItemizedOverlay itemOverlay = new CustomItemizedOverlay(mark, mMapView);
//将IteminizedOverlay添加到MapView中
mMapView.getOverlays().clear();
mMapView.getOverlays().add(itemOverlay);
//现在所有准备工作已准备好,使用以下方法管理overlay.
//添加overlay, 当批量添加Overlay时使用addItem(List&OverlayItem&)效率更高
itemOverlay.addItem(item1);
//删除overlay .
//itemOverlay.removeItem(itemOverlay.getItem(0));
//mMapView.refresh();
//清除overlay
// itemOverlay.removeAll();
// mMapView.refresh();
mMapView.refresh();
// mMapController.setCenter(p1);
mMapView.regMapViewListener(mBMapManager, new MKMapViewListener() {
// * 地图移动完成时会回调此接口 方法
public void onMapMoveFinish() {
showToast(&地图移动完毕!&);
//* 地图加载完毕回调此接口方法
public void onMapLoadFinish() {
showToast(&地图载入完毕!&);
地图完成带动画的操作(如: animationTo())后,此回调被触发
public void onMapAnimationFinish() {
//当调用过 mMapView.getCurrentMap()后,此回调会被触发
可在此保存截图至存储设备
public void onGetCurrentMap(Bitmap arg0) {
//* 点击地图上被标记的点回调此方法
public void onClickMapPoi(MapPoi arg0) {
if (arg0 != null){
showToast(arg0.strText);
public boolean onCreateOptionsMenu(Menu menu) {
super.onCreateOptionsMenu(menu);
CreateMenu(menu);
private void CreateMenu(Menu menu){
MenuItem mnu1 =menu.add(0,0,0,&显示卫星地图&);
mnu1.setAlphabeticShortcut('a');//设置快捷键
//mnu1.serIcon(R.drawable.icon);//设置图片
MenuItem mnu2 =menu.add(0,1,1,&显示街道地图&);
mnu2.setAlphabeticShortcut('b');//设置快捷键
//mnu1.serIcon(R.drawable.icon);//设置图片
MenuItem mnu3 =menu.add(0,2,2,&3D地图&);
mnu3.setAlphabeticShortcut('c');//设置快捷键
//mnu1.serIcon(R.drawable.icon);//设置图片
public boolean onOptionsItemSelected(MenuItem item) {
if(item.getItemId() == 0){
mMapView.setSatellite(true);
//设置显示为卫星地图:
mMapView.setTraffic(false);
}else if(item.getItemId() == 1){
mMapView.setTraffic(true);
//显示街道地图
mMapView.setSatellite(false);
}else if(item.getItemId() == 2){
//mMapView.se
public class BDLocationListenerImpl implements BDLocationListener {
* 接收异步返回的定位结果,参数是BDLocation类型参数
public void onReceiveLocation(BDLocation location) {
if (location == null) {
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());
if (location.getLocType() == BDLocation.TypeGpsLocation){
sb.append(&\nspeed : &);
sb.append(location.getSpeed());
sb.append(&\nsatellite : &);
sb.append(location.getSatelliteNumber());
} else if (location.getLocType() == BDLocation.TypeNetWorkLocation){
sb.append(&\naddr : &);
sb.append(location.getAddrStr());
MainActivity.this.location =
mLocData.latitude = location.getLatitude();
mLocData.longitude = location.getLongitude();
//如果不显示定位精度圈,将accuracy赋值为0即可
mLocData.accuracy = location.getRadius();
mLocData.direction = location.getDerect();
//将定位数据设置到定位图层里
myLocationOverlay.setData(mLocData);
//更新图层数据执行刷新后生效
mMapView.refresh();
if(isFirstLoc || isRequest){
//将给定的位置点以动画形式移动至地图中心
mMapController.animateTo(new GeoPoint(
(int) (location.getLatitude() * 1e6), (int) (location.getLongitude() * 1e6)));
showPopupOverlay(location);
//载入时候就弹出
isRequest =
isFirstLoc =
// 接收异步返回的POI查询结果,参数是BDLocation类型参数
public void onReceivePoi(BDLocation poiLocation) {
private void requestLocation() {
isRequest =
if(mLocClient != null && mLocClient.isStarted()){
showToast(&正在定位......&);
mLocClient.requestLocation();
//继承MyLocationOverlay重写dispatchTap方法
private class LocationOverlay extends MyLocationOverlay{
public LocationOverlay(MapView arg0) {
super(arg0);
* 在“我的位置”坐标上处理点击事件。
protected boolean dispatchTap() {
//点击我的位置显示PopupOverlay
showPopupOverlay(location);
return super.dispatchTap();
public void setMarker(Drawable arg0) {
super.setMarker(arg0);
protected void onDestroy() {
//MapView的生命周期与Activity同步,当activity销毁时需调用MapView.destroy()
mMapView.destroy();
//退出应用调用BMapManager的destroy()方法
if(mBMapManager != null){
mBMapManager.destroy();
mBMapManager =
//退出时销毁定位
if (mLocClient != null){
mLocClient.stop();
super.onDestroy();
//* 显示弹出窗口图层PopupOverlay
private void showPopupOverlay(BDLocation location){
TextView popText = ((TextView)viewCache.findViewById(R.id.location_tips));
popText.setText(&[我的位置]\n& + location.getAddrStr());
mPopupOverlay.showPopup(getBitmapFromView(popText),
new GeoPoint((int)(location.getLatitude()*1e6), (int)(location.getLongitude()*1e6)),
// * 将View转换成Bitmap的方法
public static Bitmap getBitmapFromView(View view) {
view.measure(MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED), MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
view.layout(0, 0, view.getMeasuredWidth(), view.getMeasuredHeight());
view.buildDrawingCache();
Bitmap bitmap = view.getDrawingCache();
大家注意:这里我把上一次的添加marker的代码注释了,原因是当我这两个同时弄的时候会无法给当前位置添加标记。。。这个问题稍后会得到解决。
LocationClient&
定位SDK的核心类,LocationClient类必须在主线程中声明。需要Context类型的参数。Context需要时全进程有效的context,推荐用getApplicationConext获取全进程有效的context,我们调用registerLocationListener(BDLocationListener)方法来注册定位监听接口,
BDLocationListener里面有两个方法,onReceiveLocation()(接收异步返回的定位结果),onReceivePoi()(接收异步返回的POI查询结果,
POI是“Point of Interest”的缩写,可以翻译成“信息点”,每个POI包含四方面信息,名称、类别、经度、纬度、附近的酒店、饭店,商铺等信息。我们可以叫它为“导航地图信息”,导航地图数据是整个导航产业的基石
),我们这里只需要重写
onReceiveLocation就行了
BDLocation&
封装了定位SDK的定位结果,在BDLocationListener的onReceive方法中获取。通过该类用户可以获取error code,位置的坐标,精度半径,地址等信息,对于其getLocType ()方法获取的error code一些情况
61 : GPS定位结果
62 : 扫描整合定位依据失败。此时定位结果无效。
63 : 网络异常,没有成功向服务器发起请求。此时定位结果无效。
65 : 定位缓存的结果。
66 : 离线定位结果。通过requestOfflineLocaiton调用时对应的返回结果
67 : 离线定位失败。通过requestOfflineLocaiton调用时对应的返回结果
68 : 网络连接失败时,查找本地离线定位时对应的返回结果
161: 表示网络定位结果
162~167: 服务端定位失败
LocationClientOption 用来设置定位SDK的定位方式,比如设置打开GPS,设置是否需要地址信息,设置发起定位请求的间隔时间等等,参数设置完后调用
LocationClient 的setLocOption方法
LocationOverlay &
MyLocationOverlay的子类,重写里面的
dispatchTap()方法,
显示弹出窗口图层PopupOverlay,调用
mMapView.getOverlays().add(myLocationOverlay)就将我的位置图层添加到地图里面
PopupOverlay 弹出图层,这个类还是比较简单,里面只有三个方法,
hidePop() (隐藏弹出图层)
showPopup(Bitmap pop, GeoPoint point, int yOffset) (显示弹出图层)和
showPopup显示多张图片的重载方法,由于
showPopup方法只接受Bitmap对象,所以我们必须将我们的弹出图层View对象转换成Bitmap对象,我们调用
getBitmapFromView方法就实现这一转换
BDLocationListener接口的
onReceiveLocation(BDLocation location) 方法我还要重点讲解下,我们会发现
onReceiveLocation方法会反复执行,他执行的间隔跟
LocationClientOption类的
setScanSpan()方法设定的值有关,我们设定的是5000毫秒,则
onReceiveLocation方法每隔5秒执行一次,注意,当我们设定的值大于1000(ms),
定位SDK内部使用定时定位模式。调用requestLocation( )后,每隔设定的时间,定位SDK就会进行一次定位。如果定位SDK根据定位依据发现位置没有发生变化,就不会发起网络请求,返回上一次定位的结果;如果发现位置改变,就进行网络请求进行定位,得到新的定位结果。如果你只需要定位一次的话,这个设置小于1000,或者不用设置就可以了,定时定位时,调用一次requestLocation,会定时监听到定位结果
四 . 在运行程序之前,我们还必须在AndroidManifest.xml进行相关配置和权限的声明
&span style=&color:#ff6666;&& &/span&&span style=&color:#333333;&&
&uses-permission android:name=&android.permission.ACCESS_COARSE_LOCATION& /&
&uses-permission android:name=&android.permission.ACCESS_FINE_LOCATION& /&
&uses-permission android:name=&android.permission.ACCESS_WIFI_STATE& /&
&uses-permission android:name=&android.permission.ACCESS_NETWORK_STATE&/&
&uses-permission android:name=&android.permission.CHANGE_WIFI_STATE& /&
&uses-permission android:name=&android.permission.READ_PHONE_STATE& /&
&uses-permission android:name=&android.permission.WRITE_EXTERNAL_STORAGE& /&
&uses-permission android:name=&android.permission.INTERNET& /&
&uses-permission android:name=&android.permission.MOUNT_UNMOUNT_FILESYSTEMS& /&
&uses-permission android:name=&android.permission.READ_LOGS& /&&/span&
还有很重要的一点就是在
AndroidManifest.xml中
添加下面的内容
&service &
& & & & & & android:name=&com.baidu.location.f& &
& & & & & & android:enabled=&true& &
& & & & & & android:process=&:remote& & &
& & & & &/service&&
& & & & &meta-data
& & & & & & android:name=&com.baidu.lbsapi.API_KEY&
& & & & & & android:value=&6KOX4mXHeBRzgriV6OP1T2Hw&&
& & & & & & /&
& & & & &!-- 致命的一句 --&
其中的meta-data问题:网上这样说,大家记住就得了。。。。
因为单独的定位sdk需要一个key值,而定位sdk的值又不像mapManager中可以直接赋值
所以就需要在注册表单中注册
运行图示:
部分内容摘自百度官方文档。部分来自博客:
定位自己的位置基本就这些内容,出现的问题随后会补充上。。今天就这样吧。。吃饭去了。。
已发表评论数()
&&登&&&录&&
已收藏到推刊!
请填写推刊名
描述不能大于100个字符!
权限设置: 公开
仅自己可见

我要回帖

更多关于 天正给排水自定义图层 的文章

 

随机推荐