微信运动小程序,实现经纬度信息上报与绘制运动轨迹

本文介绍了如何在微信小程序中使用`wx.startLocationUpdateBackground`解决位置信息上报的问题,通过判断位置变化和时间间隔,避免无意义的重复上报,仅在位置改变且间隔5秒后上传新的经纬度数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

微信运动小程序,实现经纬度信息上报与绘制运动轨迹。

需求:

微信小程序后台位置信息wx.onLocationChange实现间隔上报。

微信小程序中使用wx.startLocationUpdateBackground这个定位方式时,肯定要使用 wx.onLocationChange不间断的获取位置信息,但这个有两个问题:

1、位置不变化时也上报,亮屏状态每隔两秒触发onLocationChange

2、api没有提供参数控制onLocationChange的上报间隔

以下的代码可能解决以上两个问题。

实现:

wx.startLocationUpdate({
        success: (res) => {
          wx.onLocationChange((data) => {
            //获取当前时间
            var currentTime =  new Date().getTime();

            //获取上次保存的位置信息
            var oldLocation = wx.getStorageSync('oldLocation');

            //获取上次执行的时间
            var oldTime = wx.getStorageSync('oldTime');

            //将经纬度拼接
            var newLocation = data.latitude+""+data.longitude;

            //判断当前的位置是否和上次位置不一致,并且间隔时间超过5s
            if(oldLocation!=newLocation && currentTime-oldTime>5000){
              //缓存当前最新位置
              wx.setStorageSync('oldLocation',newLocation);

              //缓存当前执行的时间
              wx.setStorageSync('oldTime',currentTime);

              //将位置信息上传后台的自己的代码
              uploadLocation(data);

            }
          });

        },
        fail: (err) => {
      consoler.log(err);

        }
      })
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

mon_star°

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值