`
yidongkaifa
  • 浏览: 4051639 次
文章分类
社区版块
存档分类
最新评论

百度地图SDK for Android【Demo地图图层】

 
阅读更多

百度地图SDK为开发者提供了多种地图展示形式,用户可以通过相关的设置展示不同的地图图层,在这我将为大家介绍如何加载不同地图图层及各图层之间的切换。

首先,我们要构建一个最基本的地图应用,具体介绍请参考:百度地图SDK for Android【Demo地图展示】

在这个工程的基础之上我们做一定的修改。

第一,修改布局文件,添加控制不同图层显示的button控件;具体代码如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >
    
    <!-- 放入百度地图的mapview -->
    <com.baidu.mapapi.map.MapView android:id="@+id/bmapsView"
		android:layout_width="fill_parent"
		android:layout_height="fill_parent"
		android:clickable="true"/>

    <!-- 添加button,控制地图显示 -->
    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_alignParentTop="true"
        android:text="Button" />

</RelativeLayout>

第二,在主类中初始化button对象、并设置相应的点击事件。不同图层的显示使用方法setSatellite和setTraffic来实现,具体代码如下所示:

import com.baidu.mapapi.BMapManager;
import com.baidu.mapapi.map.MapController;
import com.baidu.mapapi.map.MapView;
import com.baidu.platform.comapi.basestruct.GeoPoint;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.app.Activity;


public class MainActivity extends Activity {

	BMapManager bMapManager = null;  // 定义管理sdk的对象
	MapView mapView = null;  // 定义mapview对象

	Button button;
	int flag = 0;
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		
		// 初始化管理对象,注意要在setContentView(R.layout.activity_main)之前初始化,否则会报错
		bMapManager = new BMapManager(getApplication());
		bMapManager.init("您申请的key", null);
		
		setContentView(R.layout.activity_main);
		
		// 初始化mapview对象,并且设置显示缩放控件
		mapView = (MapView) findViewById(R.id.bmapsView);
		mapView.setBuiltInZoomControls(true);
		
		// 初始化button
		button = (Button) findViewById(R.id.button1);
		button.setText("点击进入《卫星图》");
		
		// 定义地图控件,获取mapview的控制,并把地图范围定位北京市
		MapController mapController = mapView.getController();
		GeoPoint point =new GeoPoint((int)(39.915* 1E6),(int)(116.404* 1E6));
		mapController.setCenter(point);
		mapController.setZoom(12);
		
		// 设置button的点击事件,根据点击次数的变化,分别设置显示普通地图、实时交通图和卫星图
		button.setOnClickListener(new OnClickListener() 
		{
			@Override
			public void onClick(View v) {
				// TODO Auto-generated method stub
				if(flag == 0)
				{
					flag = flag + 1;
					mapView.setSatellite(true);
					button.setText("点击进入《实时交通图》");
				}
				else if(flag == 1)
				{
					flag = flag + 1;
					mapView.setSatellite(false);
					mapView.setTraffic(true);
					button.setText("点击进入《普通地图》");
				}
				else if(flag == 2)
				{
					flag = 0;
					mapView.setTraffic(false);
					button.setText("点击进入《卫星图》");
				}
			}
		});
		
	}
	
	
	//注意在onResume、onDestroy和onPause中控制mapview和地图管理对象的状态

	@Override
	protected void onResume() {
		// TODO Auto-generated method stub
		mapView.onResume();
		if(bMapManager!=null){
			bMapManager.start();
		}
		super.onResume();
	}
	
	@Override
	protected void onDestroy() {
		// TODO Auto-generated method stub
		mapView.destroy();
		if(bMapManager!=null){
			bMapManager.destroy();
			bMapManager=null;
		}
		super.onDestroy();
	}
	
	@Override
	protected void onPause() {
		// TODO Auto-generated method stub
		mapView.onPause();
		if(bMapManager!=null){
			bMapManager.stop();
		}
		super.onPause();
	}

}

各图层的效果如下:

点击下载原工程文件!

小提示:百度地图SDK是支持地图旋转和3D特效的,双指扭转可实现地图旋转、双指下滑实现3D楼宇特效


分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics