【高德地图】web集成百度地图点击获取位置信息,以及搜索获取位置信息案列

<script type="text/javascript" src="https://webapi.amap.com/maps?v=2.0&key=您的秘钥&plugin=AMap.ToolBar,AMap.DistrictSearch,AMap.Geocoder,AMap.DistrictLayer,AMap.AutoComplete,AMap.PlaceSearch,AMap.Walking"></script>
AMapUI.loadUI(['misc/PositionPicker'],PositionPicker => {
   var map = new AMap.Map('container', {
      resizeEnable: true,
      zoom: 10,
      center: [110.50, 38.83]
   });
   //为地图注册click事件获取鼠标点击出的经纬度坐标
   map.on('click', function(e) {
      document.getElementById('hiddenMap').value = e.lnglat;
      regeoCode();
   });
   //声明点标记
   var marker = new AMap.Marker();
   //声明Geocoder,使用getAddress()方法来获取坐标点对应的地址
   var geocoder = new AMap.Geocoder({
      city: '北京',
      radius: 1000
   })
   // 使用geocoder做地理/逆地理编码
   function regeoCode() {
      var lnglat  = document.getElementById('hiddenMap').value.split(',');
      map.add(marker);
      marker.setPosition(lnglat);
      geocoder.getAddress(lnglat, function(status, result) {
         if (status === 'complete'&&result.regeocode) {
            console.log("result.regeocode is====="+JSON.stringify(result.regeocode))
            $("#startProvince").val(result.regeocode.addressComponent.province);
            $("#startCity").val(result.regeocode.addressComponent.city);
            $("#startCountry").val(result.regeocode.addressComponent.district);
            $("#address").val(result.regeocode.formattedAddress);
            $("#stationLon").val(lnglat[0]);
            $("#stationLat").val(lnglat[1]);
            $("#stationName").val('');
         }else{
            log.error('根据经纬度查询地址失败')
         }
      });
   }
   //输入提示
   var autoOptions = {
      input: "tipinput"
   };

   AMap.plugin(['AMap.PlaceSearch','AMap.AutoComplete'], function(){
      var auto = new AMap.AutoComplete(autoOptions);
      var placeSearch = new AMap.PlaceSearch({
         map: map
      });
      //构造地点查询类
      auto.on("select", select);//注册监听,当选中某条记录时会触发
      function select(e) {
         console.log("e.poi is ====="+JSON.stringify(e.poi));
         let myDistrict = e.poi.district;
         let region = myDistrict.match(/.+?(省|市|特别行政区|自治区|自治州|县|区|岛|城)/g);
         placeSearch.setCity(e.poi.adcode);
         placeSearch.search(e.poi.name);  //关键字查询查询
         //赋值
         let regionArray = region.toString().split(',');
         $("#startProvince").val(regionArray[0]);
         $("#startCity").val(regionArray[1]);
         $("#startCountry").val(regionArray[2]);
         $("#address").val(e.poi.address);
         $("#stationName").val(e.poi.name);
         let locationArry = e.poi.location.toString().split(',');
         $("#stationLon").val(locationArry[0]);
         $("#stationLat").val(locationArry[1]);
         $("#areaCode").val(e.poi.adcode);
      }
   });
})
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

笑风尘灬

如果有用,请博主喝杯咖啡叭

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值