百度地圖SDK為開發人員提供了便捷的檢索服務。今天我將為大家介紹Poi檢索相關的內容。
首先,我們要構建一個最基本的地圖應用,具體介紹請參考:Android sdk
在這個工程的基礎之上我們做一定的修改。
第一步,修改布局檔案,添加關鍵字輸入框和用於執行搜尋操作的按鈕。代碼如下:
<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"/>
<!-- 使用者輸入關鍵字的文字框 -->
<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:hint="請輸入搜尋索引鍵"
android:ems="50" >
<requestFocus />
</EditText>
<!-- 執行Poi搜尋的按鈕 -->
<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="《搜尋Poi》" />
</RelativeLayout>
第二步,在主類中定義EditText和Button對象,並初始化。代碼如下:
// 初始化關鍵詞輸入框和按鈕控制項
editText = (EditText) findViewById(R.id.editText1);
button = (Button) findViewById(R.id.button1);
第三步,定義並初始化搜尋監聽對象(這裡我們只對poi搜尋做了監聽,如果開發人員在使用其他檢索時,只需修改對應的監聽方法即可)。代碼如下:
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
// 首先判斷是否搜尋到結果
if(arg2 != 0 || arg0 == null)
{
Toast.makeText(MainActivity.this, "沒有找到結果!", Toast.LENGTH_SHORT).show();
return;
}
// 將結果繪製到地圖上
if(arg0.getCurrentNumPois() > 0)
{
PoiOverlay poiOverlay = new PoiOverlay(MainActivity.this, mapView);
poiOverlay.setData(arg0.getAllPoi());
mapView.getOverlays().clear();
mapView.getOverlays().add(poiOverlay);
mapView.refresh();
//當arg1為2(公交線路)或4(地鐵線路)時, poi座標為空白
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
}
@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
}
};
第四步,定義Poi檢索對象並初始化。代碼如下:
// 初始化Poi搜尋對象
mkSearch = new MKSearch();
mkSearch.init(bMapManager, mkSearchListener);
第五步,設定button的點擊事件,實現Poi搜尋。代碼如下:
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
{
// 這裡Poi搜尋以城市內Poi檢索為例,開發人員可根據自己的實際需求,靈活使用
mkSearch.poiSearchInCity("北京", key);
}
}
});
第六步,完成!結果如所示:
注意:本樣本只給出了最基本的核心代碼,需要查看全部代碼的開發人員請下載原工程檔案。
此外,這個簡單的例子旨在說明Poi的最基本使用方法及執行邏輯,百度地圖SDK為開發人員提供了豐富的檢索服務,您可以實現城市檢索、周邊檢索、範圍檢索等等。