百度地图之图层展示
来源:互联网 发布:大学宿舍网络怎么样 编辑:程序博客网 时间:2024/04/30 11:48
本文中主要摘录图层展示控制功能,即对普通图、卫星图及交通流量图展示的控制,方法非常简单,关键点就2个方法:setMapMode(控制普通图和卫星图的显示)、setTraffic(控制交通图的显示)代码如下:
Activity:
package com.home;import android.app.Activity;import android.os.Bundle;import android.view.View;import android.widget.CheckBox;import android.widget.RadioButton;import com.baidu.mapapi.BMapManager;import com.baidu.mapapi.map.MapController;import com.baidu.mapapi.map.MapView;import com.baidu.platform.comapi.basestruct.GeoPoint;/** * 演示地图图层显示的控制方法 */public class LayersShowActivity extends Activity {/** * MapView 是地图主控件 */private MapView mMapView = null;/** * 用MapController完成地图控制 */private MapController mMapController = null;@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);/** * 使用地图sdk前需先初始化BMapManager. BMapManager是全局的,可为多个MapView共用,它需要地图模块创建前创建, * 并在地图地图模块销毁后销毁,只要还有地图模块在使用,BMapManager就不应该销毁 */DemoApplication app = (DemoApplication) this.getApplication();if (app.mBMapManager == null) {app.mBMapManager = new BMapManager(this);/** * 如果BMapManager没有初始化则初始化BMapManager */app.mBMapManager.init(DemoApplication.strKey,new DemoApplication.MyGeneralListener());}/** * 由于MapView在setContentView()中初始化,所以它需要在BMapManager初始化之后 */setContentView(R.layout.activity_layers);mMapView = (MapView) findViewById(R.id.bmapView);/** * 获取地图控制器 */mMapController = mMapView.getController();/** * 设置地图是否响应点击事件 . */mMapController.enableClick(true);/** * 设置地图缩放级别 */mMapController.setZoom(12);/** * 显示内置缩放控件 */mMapView.setBuiltInZoomControls(true);/** * 将地图移动至天安门 * 使用百度经纬度坐标,可以通过http://api.map.baidu.com/lbsapi/getpoint/index * .html查询地理坐标 如果需要在百度地图上显示使用其他坐标系统的位置,请发邮件至mapapi@baidu.com申请坐标转换接口 */double cLat = 39.945;double cLon = 116.404;GeoPoint p = new GeoPoint((int) (cLat * 1E6), (int) (cLon * 1E6));mMapController.setCenter(p);}/** * 设置底图显示模式 * * @param view */public void setMapMode(View view) {boolean checked = ((RadioButton) view).isChecked();switch (view.getId()) {case R.id.normal:if (checked)mMapView.setSatellite(false);break;case R.id.statellite:if (checked)mMapView.setSatellite(true);break;}}/** * 设置是否显示交通图 * * @param view */public void setTraffic(View view) {mMapView.setTraffic(((CheckBox) view).isChecked());}@Overrideprotected void onPause() {/** * MapView的生命周期与Activity同步,当activity挂起时需调用MapView.onPause() */mMapView.onPause();super.onPause();}@Overrideprotected void onResume() {/** * MapView的生命周期与Activity同步,当activity恢复时需调用MapView.onResume() */mMapView.onResume();super.onResume();}@Overrideprotected void onDestroy() {/** * MapView的生命周期与Activity同步,当activity销毁时需调用MapView.destroy() */mMapView.destroy();super.onDestroy();}@Overrideprotected void onSaveInstanceState(Bundle outState) {super.onSaveInstanceState(outState);mMapView.onSaveInstanceState(outState);}@Overrideprotected void onRestoreInstanceState(Bundle savedInstanceState) {super.onRestoreInstanceState(savedInstanceState);mMapView.onRestoreInstanceState(savedInstanceState);}}
布局XML:
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" > <RadioGroup android:id="@+id/RadioGroup" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="2" android:orientation="horizontal" > <RadioButton android:id="@+id/normal" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="1" android:checked="true" android:onClick="setMapMode" android:text="普通图" /> <RadioButton android:id="@+id/statellite" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="1" android:onClick="setMapMode" android:text="卫星图" /> </RadioGroup> <CheckBox android:id="@+id/traffice" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="1" android:checked="false" android:onClick="setTraffic" android:text="交通图" /> </LinearLayout> <com.baidu.mapapi.map.MapView android:id="@+id/bmapView" android:layout_width="match_parent" android:layout_height="match_parent" android:clickable="true" /></LinearLayout>
Application类和Manifest同之前的文章。
附上图片效果:
- 百度地图之图层展示
- 百度地图之图层
- BaiduMap---百度地图官方Demo之图层展示(展示普通图,卫星图,交通流量图及百度城市热力图)
- 百度地图之3D图层
- Android 百度地图 SDK v3.3.0 (二)--- 地图定位和图层展示
- BaiduMap---百度地图官方Demo之定位图层展示(介绍定位图层的基本用法)
- 百度地图开发之不同图层及覆盖物
- 百度地图页面展示
- 百度地图之定位图层
- Android百度地图之定位图层
- android笔记之百度地图详情页展示
- 小白做百度地图的图层
- 百度地图查看不到标签图层
- 百度地图添加自定义图层
- 百度地图 Android SDK - 图层顺序
- 百度地图自定义图层如何实现
- 221.map3-百度地图图层
- 百度地图叠加自定义图层示例
- 创建一个链表,可以插入学生信息、删除学生信息
- 深入掌握JMS(四):实战Queue
- 把C++类成员方法直接作为线程回调函数
- java项目中遇到的问题及解决办法001
- Flash页游用TextField实现图文混排(内含个人构思的一个页游资源加载策略)
- 百度地图之图层展示
- 数据库系统——B+树索引
- 深入掌握JMS(五):实战Topic
- 设置开机自动运行
- 如果“上帝”是个程序员
- 深入掌握JMS(六):消息头
- poj1751-最小生成树
- 快速排序
- Linux之V4L2基础编程