Android实现带列表的地图POI周边搜索功能_Android

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

上面是地图,下面是地理位置列表,有的只有地理位置列表(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

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

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索高德地图poi周边搜索、poisearch周边搜索、poi周边搜索 模糊检索、ios 搜索历史列表实现、高德地图 poi周边检索,以便于您获取更多的相关知识。

时间: 2024-08-30 19:40:23

Android实现带列表的地图POI周边搜索功能_Android的相关文章

Android实现带列表的地图POI周边搜索功能

先看效果图:(以公司附近的国贸为中心点) 上面是地图,下面是地理位置列表,有的只有地理位置列表(QQ动态的位置),这是个很常见的功能.它有个专门的叫法:POI周边搜索. 实现: 这个效果实现起来其实很简单,不过需要你先阅读下地图的API,这里使用的是高德地图的Android SDK,SDK的配置这里不作讲解,文末会放一些链接供学习. 思路: 1.利用地图的定位功能,获取用户当前的位置 2.根据获得的位置信息调用POI搜索,获取位置列表 3.ListView展示位置列表 4.用户拖动地图,获取地图

GIS(六)——实现js版搜狗地图周边搜索功能

       在上一篇文章<GIS(五)--完成js版搜狗地图基本交互搜索功能>中,介绍了搜狗地图的关键字搜索功能,今天就实现以下另一个重要功能吧--那就是周边搜索功能.        按照惯例,还是把官网上的示例代码给大家贴出来.飞机票在此.周边搜索的功能,跟关键字搜索其实是一样的,也是主要用到的了SearchRequest这个类,点击这里查看api文档.SearchRequest 对象规范: 属性 类型 说明 map Map 进行搜索的地图实例 renderer SearchRendere

Swift - 集成百度地图的周边雷达功能

一.周边雷达功能介绍 1,什么是周边雷达 (1)周边雷达功能,是面向移动端开发者的一套 SDK 功能接口(同步支持 Android 和 iOS 端). (2)周边雷达本质是一个连接百度 LBS 开放平台前端 SDK 产品和后端 LBS 云的中间服务. 2,使用场景 利用周边雷达功能,我们可以便捷的在自己的应用内,帮助用户实现查找周边跟"我"使用同一款 App 的人.比如: (1)查看周边都有谁跟"我"使用同一个 App,分布在哪里? (2)查看周边用户在听什么歌.看

Android及iOS版谷歌地图推出相关广告功能

谷歌(892.66,2.01,0.23%)周四在升级Android与iOS版谷歌地图时推出了 所谓的"相关广告"功能.当用户搜索某条信息时,这些广告便会出现在屏幕底部. 这类广告包含一个标题和一个 获取方位的链接.用户只需点击这条广告,或向上滑动即可看到更多信息,而一旦用户点击获取位置详情,广告主便需要按照标准的CPC(每次点击费用)交费. 当用户点击了一则广告,并获取位置详情后,便会看到地址.电话号码.照片.评价等各种信息.购买这类广告的企业可以向潜在用户提供多种服务:如果用户只是保

GIS(五)——完成js版搜狗地图基本交互搜索功能

       最近在做的有关于北京海淀智慧旅游的一个项目,既然是旅游项目,那么涉及到地图的操作也就是必然的事情了.前几篇文章,主要是分享了在地图上标记多个景点及其景点信息的技术.其实跟项目中还是有一些不一样的.项目中要求实时显示景点的信息,根据实时数据,更新Marker的颜色(绿.橙.红),以及实时更新景点Brand上的景点信息(游客流量.舒适度).这些都没有出现在文章中,文章只是从技术的角度来验证的.        今天主要要做的是地图上的一个基本功能--交互搜索.        其实官网上搜

Android 实现手机接通电话后振动提示的功能_Android

有些手机在电话接通后会有振动提示,这有个好处就是可以等到接通后再放到耳边接听,减少辐射.本文就讲讲如何在Android手机中实现这种接通电话后的振动提示功能,这里主要针对拨出的电话.        Android SDK提供的通话状态        很明显,要在电话接通的时候产生振动提示,首先需要知道电话在何时被接通.而Android SDK并没有给出直接读取这种状态的方法.下面是Android SDK的电话服务类TelephonyManager提供的三种电话状态:        CALL_ST

Android基于AudioManager、PhoneStateListener实现设置黑名单功能_Android

本文实例讲述了Android基于AudioManager.PhoneStateListener实现设置黑名单功能.分享给大家供大家参考,具体如下: 手机中一般有设置黑名单的功能.此例通过设置电话黑名单,当黑名单中的电话打来时,手机铃声为变成静音. 程序代码如下: import android.app.Activity; import android.content.Context; import android.media.AudioManager; import android.os.Bund

Android自定义View 实现闹钟唤起播放闹钟铃声功能_Android

先上图看一下闹钟唤期页面的效果 实现的功能: 1:转动的图片根据天气情况更换 2:转动时间可以设置,转动结束,闹铃声音就结束 3:光圈颜色渐变效果 直接上代码啦: package com.yuekong.sirius.extension.customview; import android.animation.Animator; import android.animation.ValueAnimator; import android.content.Context; import andro

Android 模仿iPhone列表数据View刷新动画详解_Android

因为我本人很喜欢在不同的页面之间跳转时加点好玩的动画,今天无意间看到一个动画效果感觉不错,几种效果图如下:既然好玩就写在博客中,直接说就是:该效果类似于iPhone中View的切换动画效果,今天就只介绍上面展示的效果. 废话不多说,先上效果,再看代码!! 效果一: 效果二: 效果三: 效果四:(犯错的效果): 效果五(回旋效果一): 效果六(回旋效果二): 效果看完了,就来看下上面效果实现的具体代码吧, 中间会把我自己试验的.犯的错误都以注释的形式写下来的, 大家使用的时候别出错就行了!先来看下