TastefuL847 2023-02-22 00:45 采纳率: 89.4%
浏览 23
已结题

高德地图api使用,获取标记信息

通过如下代码获取城市地标


// 获取城市定位
      AMap.plugin("AMap.CitySearch", function() {
        var citySearch = new AMap.CitySearch();
        citySearch.getLocalCity(function(status, result) {
          if (status === "complete" && result.info === "OK") {
            // 查询成功,result即为当前所在城市信息
            // 关键字搜索
            AMap.plugin(["AMap.PlaceSearch"], function() {
              //构造地点查询类
              var placeSearch = new AMap.PlaceSearch({
                pageSize: 5, // 单页显示结果条数
                pageIndex: 1, // 页码
                city: result.city, // 兴趣点城市
                citylimit: true, //是否强制限制在设置的城市内搜索
                map: map, // 展现结果的地图实例
                panel: "panel", // 结果列表将在此容器中进行展示。
                autoFitView: true // 是否自动调整地图视野使绘制的 Marker点都处于视口的可见范围
              });
              //关键字查询
              placeSearch.search("医院");
            });
          }
        });
      });

结果如下

img

现在想通过点击地图上的标记或者旁边的结果列表获取医院名称和地址

  • 写回答

2条回答 默认 最新

  • GISer Liu 2023-02-22 01:49
    关注

    以下答案引用自GPT-3大模型,请合理使用:

    AMap.plugin(["AMap.PlaceSearch"],function(){
      //实例化地点搜索类
       var placeSearch= new AMap.PlaceSearch({
         pageSize:5,//单页显示结果条数
         pageIndex:1,//页码
         city: result.city, // 兴趣点城市
         citylimit:true, //是否强制限制在设置的城市内搜索
         map: map, // 展现结果的地图实例
         panel:"panel", // 结果列表将在此容器中进行展示。
         autoFitView:true // 是否自动调整地图视野使绘制的 Marker点都处于视口的可见范围
       });
    
    //监听Marker的点击事件  
       AMap.event.addListener(marker, 'click', function() {  
    //通过点击marker来获取相应信息,可以得到医院名称和地址
        var lnglat = marker.getPosition();
        placeSearch.getDetails(lnglat, function(status, result) {
          if (status === 'complete' && result.info === 'OK') {
            console.log(result);
          }
        });
      });
      
    //监听List的点击事件
      AMap.event.addListener(placeSearch, 'listpreselect', function(e) {
    //通过点击list来获取相应信息,可以得到医院名称和地址
        placeSearch.getDetails(e.poi.id, function(status, result) {
          if (status === 'complete' && result.info === 'OK') {
            console.log(result);
          }
        });
      });
    });
    

    如果我的回答解决了您的问题,请采纳我的回答

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 2月23日
  • 已采纳回答 2月23日
  • 创建了问题 2月22日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵