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

系统 1904 0

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详情页】
第八步,点击Poi点,即可跳转至Place详情展示页面,如下图所示:

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


点击下载原工程文件。



更多详细信息请登录百度地图API官方网站: http://developer.baidu.com/map/
百度地图API论坛: http://bbs.lbsyun.baidu.com/

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


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论