Android学习笔记之百度地图Overlay

移动开发 Android
百度地图API是为开发者免费提供的一套基于百度地图服务的应用接口,包括JavaScript API、Web服务API、Android SDK、iOS SDK、定位SDK、车联网API、LBS云等多种开发工具与服务,提供基本地图展现、搜索、定位、逆/地理编码、路线规划、LBS云存储与检索等功能,适用于PC端、移动端、服务器等多种设备,多操作系统下的地图应用开发。

地图覆盖物概述

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

地图API提供了如下几种覆盖物:

  • Overlay:覆盖物的抽象基类,所有的覆盖物均继承此类的方法,实现用户自定义图层显示。
  • MyLocationOverlay:一个负责显示用户当前位置的Overlay。
  • ItemizedOverlay<Item extends OverlayItem>:Overlay的一个基类,包含了一个OverlayItem列表,相当于一组分条的Overlay,通过继承此类,将一组兴趣点显示在地图上。

  • PoiOverlay:本地搜索图层,提供某一特定地区的位置搜索服务,比如在北京市搜索“公园”,通过此图层将公园显示在地图上。

  • RouteOverlay:步行、驾车导航线路图层,将步行、驾车出行方案的路线及关键点显示在地图上。

  • TransitOverlay:公交换乘线路图层,将某一特定地区的公交出行方案的路线及换乘位置显示在地图上。

覆盖物的抽象基类:Overlay

一般来说,在MapView中添加一个Overlay需要经过以下步骤:

  • 自定义类继承Overlay,并Override其draw()方法,如果需要点击、按键、触摸等交互操作,还需Override onTap()等方法。
  1. package xiaosi.baiduMap; 
  2.  
  3. import android.graphics.Canvas; 
  4. import android.graphics.Paint; 
  5. import android.graphics.Point; 
  6. import android.os.Bundle; 
  7. import android.view.View; 
  8. import android.view.View.OnClickListener; 
  9. import android.widget.Button; 
  10.  
  11. import com.baidu.mapapi.BMapManager; 
  12. import com.baidu.mapapi.GeoPoint; 
  13. import com.baidu.mapapi.MapActivity; 
  14. import com.baidu.mapapi.MapController; 
  15. import com.baidu.mapapi.MapView; 
  16. import com.baidu.mapapi.Overlay; 
  17.  
  18. public class BaiduMapActivity extends MapActivity 
  19.     /** Called when the activity is first created. */ 
  20.     private BMapManager mapManager = null
  21.     private String key = "1B79478DA01F7800AEA8602517A6D89B38151105"
  22.     private MapView mapView = null
  23.  
  24.     @Override 
  25.     public void onCreate(Bundle savedInstanceState) 
  26.     { 
  27.         super.onCreate(savedInstanceState); 
  28.         setContentView(R.layout.main); 
  29.         mapManager = new BMapManager(getApplication()); 
  30.         mapManager.init(key, null); 
  31.         super.initMapActivity(mapManager); 
  32.         mapView = (MapView) findViewById(R.id.mapsView); 
  33.         mapView.setBuiltInZoomControls(true); // 设置启用内置的缩放控件 
  34.         MapController mapController = mapView.getController(); // 得到mMapView的控制权,可以用它控制和驱动平移和缩放 
  35. //      GeoPoint point = new GeoPoint((int) (39.915 * 1E6), 
  36. //              (int) (116.404 * 1E6)); // 用给定的经纬度构造一个GeoPoint,单位是微度 (度 * 1E6) 
  37. //      mapController.setCenter(point); // 设置地图中心点 
  38.         mapController.setZoom(12); // 设置地图zoom级别 
  39.         mapView.getOverlays().add(new MyOverlay());  ///++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 
  40.     } 
  41.  
  42.     @Override 
  43.     protected boolean isRouteDisplayed() 
  44.     { 
  45.         return false
  46.     } 
  47.  
  48.     @Override 
  49.     protected void onDestroy() 
  50.     { 
  51.         if (mapManager != null
  52.         { 
  53.             mapManager.destroy(); 
  54.             mapManager = null
  55.         } 
  56.         super.onDestroy(); 
  57.     } 
  58.  
  59.     @Override 
  60.     protected void onPause() 
  61.     { 
  62.         if (mapManager != null
  63.         { 
  64.             mapManager.stop(); 
  65.         } 
  66.         super.onPause(); 
  67.     } 
  68.  
  69.     @Override 
  70.     protected void onResume() 
  71.     { 
  72.         if (mapManager != null
  73.         { 
  74.             mapManager.start(); 
  75.         } 
  76.         super.onResume(); 
  77.     } 
  78.  
  79.     public class MyOverlay extends Overlay 
  80.     { 
  81.         GeoPoint geoPoint = new GeoPoint((int) (39.915 * 1E6), 
  82.                 (int) (116.404 * 1E6)); 
  83.         Paint paint = new Paint(); 
  84.  
  85.         @Override 
  86.         public void draw(Canvas canvas, MapView mapView, boolean shadow) 
  87.         { 
  88.             // 在天安门的位置绘制一个String 
  89.             Point point = mapView.getProjection().toPixels(geoPoint, null); 
  90.             canvas.drawText("★这里是天安门", point.x, point.y, paint); 
  91.         } 
  92.     } 
  93. }


原文链接:http://blog.csdn.net/sjf0115/article/details/7320709

责任编辑:闫佳明 来源: oschina
相关推荐

2013-04-08 14:46:42

Android学习笔记百度地图

2011-09-26 10:05:19

百度地图API

2011-10-09 11:07:40

百度地图API

2011-09-16 14:39:02

百度地图API

2011-10-24 14:01:29

API

2011-09-29 11:00:54

百度地图API

2011-05-25 14:36:17

2011-09-16 10:37:42

地图API

2011-10-21 09:28:25

百度地图API

2021-06-15 14:33:00

高德百度腾讯

2011-10-21 10:16:25

百度地图API

2012-02-03 14:01:15

地图

2020-12-11 22:02:00

百度地图Apollo

2013-08-22 17:08:50

2014-07-25 17:12:39

数据库WOT2014MongoDB

2020-11-26 15:09:49

数据安全百度地图机器学习

2012-02-01 09:33:36

百度地图API

2015-05-27 09:51:45

百度深度学习人工智能

2018-03-09 22:56:52

PaddlePaddl

2012-05-28 22:51:53

百度
点赞
收藏

51CTO技术栈公众号