微信小程序地图显示路径问题

正在做一个项目,要用微信小程序上传自己的实时位置,然后再地图界面显示一条路径,思路是点击按钮开始上传,再点击一下按钮停止上传。位置用api获取后存到一个数组里,然后再把数组定时赋给markers,在地图上渲染出来。
wxml代码:

 <view class="container">

  <view >
    <view >
      <map
        style="width: 100%; height: 300px;"
        latitude="{{latitude}}"
        longitude="{{longitude}}"
        markers="{{markers}}"
        polyline="{{poliline}}"
        >
      </map>
    </view>
    <button catchtap="path">{{path}}</button> 
    <button bindtap="location">上传位置</button>
  </view>


</view> 

js中按钮点击事件代码:

path: function () {
    var that = this
    if (this.data.path == "上传路径") {
      this.setData({
        path: "停止上传"
      })
      var i = 0,
      interval = setInterval(function () {  
        i = i + 0.001,    
        wx.getLocation({
          type: 'wgs84',

          success: function (res) {
            var latitude = res.latitude
            var longitude = res.longitude
            var speed = res.speed
            var accuracy = res.accuracy
            path.push({ latitude: latitude, longitude: longitude + i, iconPath:'../../images/location.png'})
            that.setData({
              markers:path
            });
          },

          fail: function (res) {
            console.log(res)
          }
        })
        i=i+0.0001;
      }, 5000) //循环时间 这里是5秒 
    } else {
      this.setData({
        path: "上传路径"
      })
      clearInterval(interval)

    }
  },

这里用i每次增加0.001来模拟人走路。
发现小程序的IDE有个BUG,路径的小标记物不能显示,但是在真机上可以。
界面:
markers的初始值可以完美显示
点击上传路径后的效果图:
这里写图片描述

最后一个没有解决的问题,困扰了我很久,为什么取消interval总是不成功呢,点击后还是一直更新路径!

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值