发布于 2016-06-30 23:38:39 | 147 次阅读 | 评论: 0 | 来源: 网友投递

这里有新鲜出炉的精品教程,程序狗速度看过来!

Android移动端操作系统

Android是一种基于Linux的自由及开放源代码的操作系统,主要使用于移动设备,如智能手机和平板电脑,由Google公司和开放手机联盟领导及开发。尚未有统一中文名称,中国大陆地区较多人使用“安卓”或“安致”。


这篇文章主要为大家详细介绍了Android实现带列表的地图POI周边搜索功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

先看效果图:(以公司附近的国贸为中心点)

上面是地图,下面是地理位置列表,有的只有地理位置列表(QQ动态的位置),这是个很常见的功能。它有个专门的叫法:POI周边搜索。

实现:

这个效果实现起来其实很简单,不过需要你先阅读下地图的API,这里使用的是高德地图的Android SDK,SDK的配置这里不作讲解,文末会放一些链接供学习。

思路:

1、利用地图的定位功能,获取用户当前的位置
2、根据获得的位置信息调用POI搜索,获取位置列表
3、ListView展示位置列表
4、用户拖动地图,获取地图中心坐标的位置信息,并执行2~3的步骤

代码:

Layout:


<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical"
  >

  <com.amap.api.maps2d.MapView
    android:id="@+id/map_local"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="2"/>

  <ListView
    android:id="@+id/map_list"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="3"
    android:divider="@color/space"
    android:dividerHeight="1dp"
    android:scrollbars="none"/>

</LinearLayout>

Activity:


public class New_LocalActivity extends Activity implements LocationSource,
    AMapLocationListener, AMap.OnCameraChangeListener, PoiSearch.OnPoiSearchListener {

  @BindView(R.id.map_local)
  MapView mapView;
  @BindView(R.id.map_list)
  ListView mapList;

  public static final String KEY_LAT = "lat";
  public static final String KEY_LNG = "lng";
  public static final String KEY_DES = "des";


  private AMapLocationClient mLocationClient;
  private LocationSource.OnLocationChangedListener mListener;
  private LatLng latlng;
  private String city;
  private AMap aMap;
  private String deepType = "";// poi搜索类型
  private PoiSearch.Query query;// Poi查询条件类
  private PoiSearch poiSearch;
  private PoiResult poiResult; // poi返回的结果
  private PoiOverlay poiOverlay;// poi图层
  private List<PoiItem> poiItems;// poi数据

  private PoiSearch_adapter adapter;


  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_new__local);
    ButterKnife.bind(this);
    mapView.onCreate(savedInstanceState);
    init();
  }

  private void init() {
    if (aMap == null) {
      aMap = mapView.getMap();
      aMap.setOnCameraChangeListener(this);
      setUpMap();
    }

    deepType = "餐饮";//这里以餐饮为例
  }

  //-------- 定位 Start ------

  private void setUpMap() {
    if (mLocationClient == null) {
      mLocationClient = new AMapLocationClient(getApplicationContext());
      AMapLocationClientOption mLocationOption = new AMapLocationClientOption();
      //设置定位监听
      mLocationClient.setLocationListener(this);
      //设置为高精度定位模式
      mLocationOption.setOnceLocation(true);
      mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);
      //设置定位参数
      mLocationClient.setLocationOption(mLocationOption);
      mLocationClient.startLocation();
    }
    // 自定义系统定位小蓝点
    MyLocationStyle myLocationStyle = new MyLocationStyle();
    myLocationStyle.myLocationIcon(BitmapDescriptorFactory
        .fromResource(R.drawable.location_marker));// 设置小蓝点的图标
    myLocationStyle.strokeColor(Color.BLACK);// 设置圆形的边框颜色
    myLocationStyle.radiusFillColor(Color.argb(100, 0, 0, 180));// 设置圆形的填充颜色
    myLocationStyle.strokeWidth(1.0f);// 设置圆形的边框粗细
    aMap.setMyLocationStyle(myLocationStyle);
    aMap.setLocationSource(this);// 设置定位监听
    aMap.getUiSettings().setMyLocationButtonEnabled(true);// 设置默认定位按钮是否显示
    aMap.setMyLocationEnabled(true);// 设置为true表示显示定位层并可触发定位,false表示隐藏定位层并不可触发定位,默认是false
  }

  /**
   * 开始进行poi搜索
   */
  protected void doSearchQuery() {
    aMap.setOnMapClickListener(null);// 进行poi搜索时清除掉地图点击事件
    int currentPage = 0;
    query = new PoiSearch.Query("", deepType, city);// 第一个参数表示搜索字符串,第二个参数表示poi搜索类型,第三个参数表示poi搜索区域(空字符串代表全国)
    query.setPageSize(20);// 设置每页最多返回多少条poiitem
    query.setPageNum(currentPage);// 设置查第一页
    LatLonPoint lp = new LatLonPoint(latlng.latitude, latlng.longitude);

    poiSearch = new PoiSearch(this, query);
    poiSearch.setOnPoiSearchListener(this);
    poiSearch.setBound(new PoiSearch.SearchBound(lp, 5000, true));
    // 设置搜索区域为以lp点为圆心,其周围2000米范围
    poiSearch.searchPOIAsyn();// 异步搜索

  }

  @Override
  public void onLocationChanged(AMapLocation aMapLocation) {
    if (mListener != null && aMapLocation != null) {
      if (aMapLocation.getErrorCode() == 0) {
        // 显示我的位置
        mListener.onLocationChanged(aMapLocation);
        //设置第一次焦点中心
        latlng = new LatLng(aMapLocation.getLatitude(), aMapLocation.getLongitude());
        aMap.animateCamera(CameraUpdateFactory.newLatLngZoom(latlng, 14), 1000, null);
        city = aMapLocation.getProvince();
        doSearchQuery();
      } else {
        String errText = "定位失败," + aMapLocation.getErrorCode() + ": " + aMapLocation.getErrorInfo();
        Log.e("AmapErr", errText);
      }
    }
  }

  @Override
  public void activate(OnLocationChangedListener listener) {
    mListener = listener;
    mLocationClient.startLocation();
  }

  @Override
  public void deactivate() {
    mListener = null;
    if (mLocationClient != null) {
      mLocationClient.stopLocation();
      mLocationClient.onDestroy();
    }
    mLocationClient = null;
  }

  @Override
  public void onCameraChange(CameraPosition cameraPosition) {
  }

  @Override
  public void onCameraChangeFinish(CameraPosition cameraPosition) {
    latlng = cameraPosition.target;
    aMap.clear();
    aMap.addMarker(new MarkerOptions().position(latlng));
    doSearchQuery();
  }

  @Override
  public void onPoiSearched(PoiResult result, int rCode) {
    if (rCode == 0) {
      if (result != null && result.getQuery() != null) {// 搜索poi的结果
        if (result.getQuery().equals(query)) {// 是否是同一条
          poiResult = result;
          poiItems = poiResult.getPois();// 取得第一页的poiitem数据,页数从数字0开始
          List<SuggestionCity> suggestionCities = poiResult
              .getSearchSuggestionCitys();
          if (poiItems != null && poiItems.size() > 0) {
            adapter = new PoiSearch_adapter(this, poiItems);
            mapList.setAdapter(adapter);
            mapList.setOnItemClickListener(new mOnItemClickListener());

           }
          }
          else {
            Logger.d("无结果");
          }
        }
      } else {
        Logger.e("无结果");
      }
    } else if (rCode == 27) {
      Logger.e("error_network");
    } else if (rCode == 32) {
      Logger.e("error_key");
    } else {
      Logger.e("error_other:" + rCode);
    }
  }

  @Override
  public void onPoiItemSearched(PoiItem poiItem, int i) {

  }

  //-------- 定位 End ------

  @Override
  protected void onResume() {
    super.onResume();
    mLocationClient.startLocation();
  }

  @Override
  protected void onPause() {
    super.onPause();
    mLocationClient.stopLocation();
  }

  @Override
  protected void onDestroy() {
    mLocationClient.onDestroy();
    super.onDestroy();
  }

  private class mOnItemClickListener implements AdapterView.OnItemClickListener {
    @Override
    public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
      Intent intent = new Intent();
      intent.putExtra(KEY_LAT, poiItems.get(position).getLatLonPoint().getLatitude());
      intent.putExtra(KEY_LNG, poiItems.get(position).getLatLonPoint().getLongitude());
      intent.putExtra(KEY_DES, poiItems.get(position).getTitle());
      setResult(RESULT_OK, intent);
      finish();
    }
  }

示例中的Activity是使用startActivityForResult方式启动的,最后点击位置之后会返回点选的位置信息。

总结:我第一次准备实现上述的效果时,也是不知所措,因为还没有对地图API有比较全面的认识,后来看了不少资料,自己便结合了一下地图的功能点,实现了设计图中的效果。

本文作者:他叫自己MR张

本文地址:http://blog.csdn.net/ys743276112/article/details/51519223

以上就是本文的全部内容,非常感谢作者的分享,希望对大家的学习有所帮助,大家共同进步。



最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务