所有叠加或覆盖到地图的内容,我们统称为地图覆盖物。如标注、矢量图形元素(包括:折线、多边形和圆)、定位图标等。覆盖物拥有自己的地理坐标,当您拖动或缩放地图时,它们会相应的移动。

百度地图SDK为开发者们提供了如下类型的地图覆盖物:

  • 我的位置图层(MyLocationOverlay):用于显示用户当前位置的图层;
  • Poi搜索结果图层(PoiOverlay):用于显示兴趣点搜索结果的图层;
  • 路线图层(RouteOverlay):公交、步行和驾车线路图层,将公交、步行和驾车出行方案的路线及关键点显示在地图上;
  • 公交换乘图层(TransitOverlay):公交换乘线路图层,将某一特定地区的公交出行方案的路线及换乘位置显示在地图上;
  • 自定义图层(ItemizedOverlay):可将一个或多个兴趣点绘制到地图上,且支持自定义图标;
  • 弹出窗图层(PopupOverlay):在地图上显示一个弹出窗口。(以上内容来自百度地图SDK点击打开链接 )
    我们挨个来看看这些地图覆盖物。
    1、我的位置图层(MyLocationOverlay)
    将MyLocationOverlay添加到覆盖物中,能够实现在地图上显示当前位置的图标以及指南针。具体activity中代码如下:
package com.boy.mybaidumap;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.widget.Toast;

import com.baidu.mapapi.BMapManager;
import com.baidu.mapapi.MKGeneralListener;
import com.baidu.mapapi.map.LocationData;
import com.baidu.mapapi.map.MapController;
import com.baidu.mapapi.map.MapView;
import com.baidu.mapapi.map.MyLocationOverlay;
import com.baidu.platform.comapi.basestruct.GeoPoint;

public class MyMapActivity extends Activity{
	
	//地图引擎管理类 加载地图引擎
	private BMapManager bMapManager = null ;
	private MapView     mapView  = null ;
	
	//添加百度地图的key 此处需替换为开发中自己申请的key
	private String keyString = "D298C0EFB220685DC5C6CA195FB2082264B0635F";
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		
		super.onCreate(savedInstanceState);
		
		bMapManager=new BMapManager(getApplication());
		
		//加载必要的申请的key  MKGeneralListener 监听授权的key 是否合法
		bMapManager.init(keyString, new MKGeneralListener() {
			
			@Override
			public void onGetPermissionState(int arg0) {
				
				if (arg0 == 300) {
					
					Toast.makeText(MyMapActivity.this, "输入的key有错,请核实!", 1);
				}
				
			}
			
			@Override
			public void onGetNetworkState(int arg0) {
				// TODO Auto-generated method stub
				
			}
		});  
		
		
		//注意:请在试用setContentView前初始化BMapManager对象,否则会报错
		setContentView(R.layout.activity_main);
		mapView=(MapView)findViewById(R.id.bmapsView);
		mapView.setBuiltInZoomControls(true);// 表示可以设置缩放功能
		
		//	设置启用内置的缩放控件
		MapController mMapController = mapView.getController();
		
		// 	定义一个经纬度 北京天安门 
		//	 用给定的经纬度构造一个GeoPoint,单位是微度 (度 * 1E6)
		GeoPoint point =new GeoPoint((int)(39.915* 1E6),(int)(116.404* 1E6));
		
		//	设置地图中心点
		mMapController.setCenter(point);
		
		//设置地图zoom级别
		mMapController.setZoom(12);
		
		//双击地图放大
		mapView.setDoubleClickZooming(true);
		
		//显示卫星地图
		//mapView.setSatellite(true);
		
		//显示交通地图
		//mapView.setTraffic(true);
		
		//在地图上显示我的位置
		// MyLocationOverlay  一个显示用户当前位置的Overlay。
		// MyLocationOverlay 是一个覆盖物,它绘制用户当前在地图上的位置(精准度),和/或一个嵌入的指南针。
		// 子类可通过覆盖方法dispatchTap()处理当前位置的点击事件
		// MyLocationOverlay 不绑定位置数据来源,可通过 setData()方法设置位置信息
		MyLocationOverlay myLocationOverlay = new MyLocationOverlay(mapView);
		LocationData locData = new LocationData();
		
		//手动将位置源置为天安门
		locData.latitude = 39.915; //百度纬度坐标
		locData.longitude = 116.404; //百度经度坐标
		locData.direction = 2.0f; // GPS定位时方向角度
		myLocationOverlay.enableCompass();//打开指南针
		myLocationOverlay.setData(locData);
		
		mapView.getOverlays().add(myLocationOverlay);
		mapView.refresh();
		mapView.getController().animateTo(new GeoPoint((int)(locData.latitude*1e6),	(int)(locData.longitude* 1e6)));
	}
	
	//重写以下方法。管理API
	
	@Override
	protected void onDestroy(){
		
	        mapView.destroy();
	        
	        if(bMapManager!=null){
	        	
	        	bMapManager.destroy();
	        	bMapManager=null;
	        }
	        
	        super.onDestroy();
	}
	
	@Override
	protected void onPause(){
		
	        mapView.onPause();
	        
	        if(bMapManager!=null){
	        	
	        	bMapManager.stop();
	        }
	        
	        super.onPause();
	}
	@Override
	protected void onResume(){
		
	        mapView.onResume();
	        
	        if(bMapManager!=null){
	        	
	        	bMapManager.start();
	        }
	        
	        super.onResume();
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		
		getMenuInflater().inflate(R.menu.main, menu);
		
		return true;
	}
}
  • 至此,在地图上显示我的位置(手动添加),就算完成了。效果图如下:

overlay2目录如何清理 overlay map_地图