首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 移动开发 > 移动开发 >

百度map之UI控制

2013-09-06 
百度地图之UI控制在本文中主要介绍百度地图UI控制功能,即控制地图是否有缩放、平移、双击放大、旋转、俯视的功

百度地图之UI控制

在本文中主要介绍百度地图UI控制功能,即控制地图是否有缩放、平移、双击放大、旋转、俯视的功能以及控制是否显示内置缩放组件、指南针位置等。在文中采用标签监听使每个控制功能的方法见名知义,代码原型来源百度demo,代码如下:

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;/** * 演示地图UI控制功能 */public class UISettingActivity 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.uisetting_main);mMapView = (MapView) findViewById(R.id.bmapView);/** * 获取地图控制器 */mMapController = mMapView.getController();/** * 设置地图是否响应点击事件 */mMapController.enableClick(true);/** * 设置地图缩放级别 */mMapController.setZoom(12);/** * 设置地图俯角 */mMapController.setOverlooking(-30);/** * 将地图移动至天安门 * 使用百度经纬度坐标,可以通过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 v */public void setZoomEnable(View v) {mMapController.setZoomGesturesEnabled(((CheckBox) v).isChecked());}/** * 是否启用平移手势 *  * @param v */public void setScrollEnable(View v) {mMapController.setScrollGesturesEnabled(((CheckBox) v).isChecked());}/** * 是否启用双击放大 *  * @param v */public void setDoubleClickEnable(View v) {mMapView.setDoubleClickZooming(((CheckBox) v).isChecked());}/** * 是否启用旋转手势 *  * @param v */public void setRotateEnable(View v) {mMapController.setRotationGesturesEnabled(((CheckBox) v).isChecked());}/** * 是否启用俯视手势 *  * @param v */public void setOverlookEnable(View v) {mMapController.setOverlookingGesturesEnabled(((CheckBox) v).isChecked());}/** * 是否显示内置绽放控件 *  * @param v */public void setBuiltInZoomControllEnable(View v) {mMapView.setBuiltInZoomControls(((CheckBox) v).isChecked());}/** * 设置指南针位置,指南针在3D模式下自动显现 *  * @param view */public void setCompassLocation(View view) {boolean checked = ((RadioButton) view).isChecked();switch (view.getId()) {case R.id.lefttop:if (checked)// 设置指南针显示在左上角mMapController.setCompassMargin(100, 100);break;case R.id.righttop:if (checked)mMapController.setCompassMargin(mMapView.getWidth() - 100, 100);break;}}@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="50dip"        android:orientation="horizontal" >        <CheckBox            android:id="@+id/zoom"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:checked="true"            android:onClick="setZoomEnable"            android:text="缩放" />        <CheckBox            android:id="@+id/scroll"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:checked="true"            android:onClick="setScrollEnable"            android:text="平移" />        <CheckBox            android:id="@+id/doubleClick"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:checked="true"            android:onClick="setDoubleClickEnable"            android:text="双击放大" />    </LinearLayout>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="50dip"        android:orientation="horizontal" >        <CheckBox            android:id="@+id/rotate"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:checked="true"            android:onClick="setRotateEnable"            android:text="旋转" />        <CheckBox            android:id="@+id/overlook"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:checked="true"            android:onClick="setOverlookEnable"            android:text="俯视" />        <CheckBox            android:id="@+id/zoomControl"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:checked="false"            android:onClick="setBuiltInZoomControllEnable"            android:text="缩放控件" />    </LinearLayout>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="50dip"        android:orientation="horizontal" >        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:paddingTop="10dip"            android:text="指南针位置" />        <RadioGroup            android:id="@+id/RadioGroup"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_weight="1"            android:orientation="horizontal"            android:text="指南针位置" >            <RadioButton                android:id="@+id/lefttop"                android:layout_width="wrap_content"                android:layout_height="wrap_content"                android:checked="true"                android:onClick="setCompassLocation"                android:text="左上角" />            <RadioButton                android:id="@+id/righttop"                android:layout_width="wrap_content"                android:layout_height="wrap_content"                android:onClick="setCompassLocation"                android:text="右上角" />        </RadioGroup>    </LinearLayout>    <com.baidu.mapapi.map.MapView        android:id="@+id/bmapView"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:clickable="true" /></LinearLayout>

Application类和Manifest同前文。
附上图片效果:

百度map之UI控制

热点排行