温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

微信小程序怎么通过API获取当前位置的经纬度

发布时间:2022-03-07 10:57:29 阅读:168 作者:iii 栏目:开发技术
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

本篇内容介绍了“微信小程序怎么通过API获取当前位置的经纬度”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

效果图:

微信小程序怎么通过API获取当前位置的经纬度

1、wxml文件

<view class="mapHeight">
  <map 
    id="map" 
    class="map"
    polyline="{{polyline}}"
    markers="{{markers}}" 
    include-points="{{markers}}"
   ></map>
</view>

2、 js文件

var coors;
Page({
  data: {
    polyline: [],
    markers: [],
  },
  onReady: function() {
    this.mapContext = wx.createMapContext("map", this);
  },
  onLoad: function(options{
    // 获取当前地图,设置经纬度,传递过来的坐标,用户下单的坐标地址。
    console.log(options);
    wx.getLocation({
      success: (res) => {
        this.setData({
          latitude: options.latitude,
          longitude: options.longitude
        });
        this.getCenterLocation(res);
        wx.request({
          url'https://apis.map.qq.com/ws/direction/v1/driving/?from=' + this.data.markers[0].latitude + ',' + this.data.markers[0].longitude + '&to=' + this.data.markers[1].latitude + ',' + this.data.markers[1].longitude + '&output=json&callback=cb&key=PD5BZ-K2VRO-CPEWZ-SOBAC-4KCDT-KAFLF',
          success: (res) => {
            coors = res.data.result.routes[0].polyline
            for (var i = 2; i < coors.length; i++) {
              coors[i] = coors[i - 2] + coors[i] / 1000000
            }
            console.log(coors)
            //划线
            var b = [];
            for (var i = 0; i < coors.length; i = i + 2) {
              b[i / 2] = {
                latitude: coors[i],
                longitude: coors[i + 1]
              };
              console.log(b[i / 2])
            }
            this.setData({
              polyline: [{
                points: b,
                color"#00ae20",
                width4,
                dottedLinefalse
              }],
            })
          }
        })
      }
    });
  },
  //  两个坐标 一个下单地址,一个工程师接单地址,然后不停的更新工程师的坐标位置。
  getCenterLocation: function(res{
    this.setData({
      markers: [{
          iconPath"/resources/center.png",
          id0,
          latitude: res.latitude,
          longitude: res.longitude,
          width30,
          height30,
          alpha0.8,
          callout: {
            content" 我的位置 ",
            color"#ffffff",
            fontSize10,
            borderRadius10,
            bgColor"#6e707c",
            padding5,
            display"ALWAYS"
          }
        },
        {
          iconPath"/resources/user.png",
          id1,
          latitude: res.latitude + 0.1,
          longitude: res.longitude + 0.1,
          width30,
          height30,
          alpha0.8,
          callout: {
            content" 工程师 ",
            color"#ffffff",
            fontSize10,
            borderRadius10,
            bgColor"#6e707c",
            padding5,
            display"ALWAYS"
          }
        }
      ],
    });
  },
});

3、wxss文件

.mapHeight {
  display: flex;
  flex-direction: column;
}
.map {
  flex1;
  height100vh;
  width100%;
}

“微信小程序怎么通过API获取当前位置的经纬度”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI

开发者交流群×