2021-07-23 前端vue引入高德地图js-sdk踩坑记

2021-07-23  本文已影响0人  gdlooker

百度地图引入js-sdk的做拖拽地图的时候,获取拖拽结束后的经纬度,有自己的监听,而在做高德地图sdk接入的时候,使用拖拽的时候要引入一个ui的 PositionPicker库,首先在vue工程的public目录下引入js跟ui库

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
  <link rel="icon" href="<%= BASE_URL %>favicon.ico">
  <!-- 百度地图定位 -->
  <script type="text/javascript" id="baiduMapAddress"
    src="//api.map.baidu.com/api?v=1.0&type=webgl&ak=WZp3MbqSXW5YUgDSYIMaqLQHd0tKZeKq"></script>
  <!-- 高德地图定位sdk -->
  <script type="text/javascript" src="//webapi.amap.com/maps?v=1.4.3&key=你公司的key&&plugin=AMap.Driving"></script>
  <script src="//webapi.amap.com/ui/1.0/main.js?v=1.0.11"></script>
  <title>
    <%= webpackConfig.name %>
  </title>
</head>

<body>
  <noscript>
    <strong>We're sorry but <%= webpackConfig.name %> doesn't work properly without JavaScript enabled. Please enable it
        to continue.</strong>
  </noscript>
  <div id="app"></div>
  <!-- built files will be auto injected -->
</body>

</html>

接下来引入如下代码:

//初始化高德定位
    initGdData() {
      const that = this;
      const stationHighSeasPool = that.$store.state.stationHighSeasPool;
      const { outItem } = stationHighSeasPool;
      const { base, cityName, provinceName, townName } = outItem;
      const { longitude, latitude } = base;
      //第一步  拿到 上个页面点击的经纬度 跟城市之类的
      that.point = [longitude, latitude];

      AMapUI.loadUI(
        ["misc/PositionPicker", "misc/PoiPicker"],
        function (PositionPicker) {
          const mapObj = new AMap.Map("content-row-map", {
            resizeEnable: true,
            center: that.point,
            zooms: [4, 18], //设置地图级别范围
            zoom: 13,
          });
          const center = mapObj.getCenter();
          console.log("获取地图中心", center);
          mapObj.plugin(
            ["AMap.Geolocation", "AMap.Weather", "AMap.Scale", "AMap.ToolBar"],
            function () {
              //定位实例
              const geolocation = new AMap.Geolocation({
                enableHighAccuracy: true, // 是否使用高精度定位,默认:true
                timeout: 10000, // 超过10秒后停止定位,默认:无穷大
                maximumAge: 0, // 定位结果缓存0毫秒,默认:0
                convert: true, // 自动偏移坐标,偏移后的坐标为高德坐标,默认:true
                showButton: true, // 显示定位按钮,默认:true
                buttonPosition: "LB", // 定位按钮停靠位置,默认:'LB',左下角
                buttonOffset: new AMap.Pixel(10, 20), // 定位按钮与设置的停靠位置的偏移量,默认:Pixel(10, 20)
                showMarker: true, // 定位成功后在定位到的位置显示点标记,默认:true
                showCircle: true, // 定位成功后用圆圈表示定位精度范围,默认:true
                panToLocation: true, // 定位成功后将定位到的位置作为地图中心点,默认:true
                zoomToAccuracy: true, // 定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false
              });

              const weather = new AMap.Weather();
              //执行实时天气信息查询
              weather.getLive("深圳市", function (err, data) {
                console.log(err, data);
              });
              mapObj.addControl(weather);
              mapObj.addControl(new AMap.Scale()); // 在图面添加比例尺控件,展示地图在当前层级和纬度下的比例尺
              mapObj.addControl(new AMap.ToolBar()); // 在图面添加工具条控件,工具条控件集成了缩放、平移、定位等功能按钮在内的组合控件
              mapObj.addControl(geolocation);
              geolocation.getCurrentPosition();
              AMap.event.addListener(geolocation, "complete", that.onComplete); // 返回定位信息
              AMap.event.addListener(geolocation, "error", that.onError); // 返回定位出错信息
            }
          );
          const positionPicker = new PositionPicker({
            //默认拖拽地图
            mode: "dragMap",
            map: mapObj,
          });
          console.log("拖拽对象", positionPicker);
          positionPicker.on("success", function (positionResult) {
            console.log("拖拽结果", positionResult);
          });
          positionPicker.on("fail", function (positionResult) {
            console.log("拖拽失败", positionResult);
          });
          positionPicker.start();
        }
      );
    },
    onComplete(val) {
      console.log("complete_val", val);
    },
    onError(val) {
      console.log("error_val", val);
    },
上一篇 下一篇

猜你喜欢

热点阅读