百度地图SDK for Android【Demo Place详情页】

        Place详情展示页面可以帮助开发者便捷的展示Poi详情信息,此外通过详情展示页面您还可以实现电话的拨打等功能。今天将向大家介绍Place详情页的具体使用方法。

        第一步,创建工程,并放置基础地图mapview控件(详细介绍请参考: 百度地图SDK for Android【Demo地图展示】 )。布局文件代码及主程序中的代码如下:

    <!-- 放入百度地图的mapview -->
    <com.baidu.mapapi.map.MapView android:id="@+id/bmapsView"
		android:layout_width="fill_parent"
		android:layout_height="fill_parent"
		android:clickable="true"/>
		// 初始化管理对象,注意要在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);
		
		// 定义地图控件,获取mapview的控制,并把地图范围定位北京市
		MapController mapController = mapView.getController();
		GeoPoint point =new GeoPoint((int)(39.915* 1E6),(int)(116.404* 1E6));
		mapController.setCenter(point);
		mapController.setZoom(12);
		mapController.enableClick(true);  // 注意添加可点击属性,用于随后的place页面展示入口

        第二步,在布局文件中添加输入框及用于搜索的按钮。代码如下:

    <EditText
        android:id="@+id/editText1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_toLeftOf="@+id/button1"
        android:text="餐厅"
        android:ems="50" >
    </EditText>

    <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="《点击搜索》" />

        第三步,在主程序中对应的建立控件变量,用于控制所添加的控件。代码如下:

		editText = (EditText) findViewById(R.id.editText1);
		button = (Button) findViewById(R.id.button1);
		button.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View v) {
				// TODO Auto-generated method stub
				String key = editText.getText().toString();
				if(key.equals(""))
				{
					Toast.makeText(MainActivity.this, "检索关键词不能为空!", Toast.LENGTH_SHORT).show();
				}
				else 
				{
					mkSearch.poiSearchInCity("北京", key);
				}
			}
		});

        第四步,定义并初始化检索变量和监听接口。代码如下:

	MKSearchListener mkSearchListener = new MKSearchListener() {
		
		@Override
		public void onGetWalkingRouteResult(MKWalkingRouteResult arg0, int arg1) {
			// TODO Auto-generated method stub
			
		}
		
		@Override
		public void onGetTransitRouteResult(MKTransitRouteResult arg0, int arg1) {
			// TODO Auto-generated method stub
			
		}
		
		@Override
		public void onGetSuggestionResult(MKSuggestionResult arg0, int arg1) {
			// TODO Auto-generated method stub
			
		}
		
		@Override
		public void onGetPoiResult(MKPoiResult arg0, int arg1, int arg2) {
			// TODO Auto-generated method stub
			// 错误号可参考MKEvent中的定义
            if (arg2 != 0 || arg0 == null) {
                Toast.makeText(MainActivity.this, "抱歉,未找到结果", Toast.LENGTH_LONG).show();
                return;
            }
            // 将地图移动到第一个POI中心点
            if (arg0.getCurrentNumPois() > 0) {
                // 将poi结果显示到地图上
                PlacePoiOverlay poiOverlay = new PlacePoiOverlay(MainActivity.this, mapView, mkSearch);
                poiOverlay.setData(arg0.getAllPoi());
                mapView.getOverlays().clear();
                mapView.getOverlays().add(poiOverlay);
                mapView.refresh();
                
                for( MKPoiInfo info : arg0.getAllPoi() ){
                	if ( info.pt != null ){
                		mapView.getController().animateTo(info.pt);
                		break;
                	}
                }
            }
            
		}
		
		@Override
		public void onGetPoiDetailSearchResult(int arg0, int arg1) {
			// TODO Auto-generated method stub
			if (arg1 != 0) {
                Toast.makeText(MainActivity.this, "抱歉,未找到结果", Toast.LENGTH_SHORT).show();
            }
            else {
                Toast.makeText(MainActivity.this, "成功,查看详情页面", Toast.LENGTH_SHORT).show();
            }
		}
		
		@Override
		public void onGetDrivingRouteResult(MKDrivingRouteResult arg0, int arg1) {
			// TODO Auto-generated method stub
			
		}
		
		@Override
		public void onGetBusDetailResult(MKBusLineResult arg0, int arg1) {
			// TODO Auto-generated method stub
			
		}
		
		@Override
		public void onGetAddrResult(MKAddrInfo arg0, int arg1) {
			// TODO Auto-generated method stub
			
		}
	};
		mkSearch = new MKSearch();
		mkSearch.init(bMapManager, mkSearchListener);

        第五步,定义并初始化地图点击事件的监听,并注册此监听。代码如下:

	MKMapViewListener mapListener = new MKMapViewListener() {
		
		@Override
		public void onMapMoveFinish() {
			// TODO Auto-generated method stub
			
		}
		
		@Override
		public void onClickMapPoi(MapPoi arg0) {
			// TODO Auto-generated method stub
			String title = "";
			if (arg0 != null){
				title = arg0.strText;
				Toast.makeText(MainActivity.this,title,Toast.LENGTH_SHORT).show();
			}
		}
	};
		mapView.regMapViewListener(bMapManager, mapListener);

        第六步,定义继承自PoiOverlay的类,用于显示Place详情页。代码如下:

public class PlacePoiOverlay extends PoiOverlay {

	MKSearch mSearch;

    public PlacePoiOverlay(Activity activity, MapView mapView, MKSearch search) {
        super(activity, mapView);
        mSearch = search;
    }

    @Override
    protected boolean onTap(int i) {
        super.onTap(i);
        MKPoiInfo info = getPoi(i);
        if (info.hasCaterDetails) {
            mSearch.poiDetailSearch(info.uid);
        }
        return true;
    }
}

        第七步,执行程序,输入关键词点击搜索即可得到如下图所示的结果展示界面:

百度地图SDK for Android【Demo Place详情页】_第1张图片
        第八步,点击Poi点,即可跳转至Place详情展示页面,如下图所示:

百度地图SDK for Android【Demo Place详情页】_第2张图片


        点击下载原工程文件。


作者:BaiduLBS 发表于2013-2-25 17:33:07 原文链接
阅读:94 评论:0 查看评论

你可能感兴趣的:(android,sdk,百度地图)