http://blog.csdn.net/baidulbs/article/details/8610300
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;
- }
- }
第七步,执行程序,输入关键词点击搜索即可得到如下图所示的结果展示界面:
第八步,点击Poi点,即可跳转至Place详情展示页面,如下图所示:
更多详细信息请登录百度地图API官方网站:http://developer.baidu.com/map/
百度地图API论坛:http://bbs.lbsyun.baidu.com/