微信小程序实现导航功能

  1. 通过getLocation获得定位
     
  2. 必须要把你的地址转为实际的经纬度才能实现导航功能,因此要使用地理编码API。我这里使用的是高德地图地理编码API,请申请微信小程序,下图是申请后结果

<!--wxml-->
<!--我这里的item携带了地址哦-->
<view data-item="{{item}}" catchtap="daohang">查看定位</view>
//获得从前端传来的地址
daohang:function(e){
  var that =this;
  console.log(e.currentTarget.dataset.item)
  var name=e.currentTarget.dataset.item.name
  var address=e.currentTarget.dataset.item.address;
  that.loadGEO(address,name)

},
//地址转为经纬度
loadGEO:function(address,name){
  wx.request({
    url: 'https://restapi.amap.com/v3/geocode/geo?parameters',
    data:{
      key: '你的key',
      address:address,
      s: "rsx",
      city:cityname,
      sdkversion: "sdkversion",
      logversion: "logversion"
    },
    success(res){
      console.log(res.data)
      var address =res.data.geocodes[0].formatted_address
      //返回的是一个类似这样的"xxx.xx,xx.xxx"的字符串经纬度,所以要进行拆分把经度和纬度分开
      var arr=res.data.geocodes[0].location.split(",");
      console.log(arr)
      //要转化为数字,这里用Number()
      var latitude=Number(arr[1]);
      var longitude =Number(arr[0]);
      console.log(latitude,longitude)
      //这里会打开地图
      wx.openLocation({
          latitude: latitude,//,latitude,
          longitude:longitude ,//longitude,
          name: name,//定位名称
          address:address,//具体地址
          scale: 15
        })
    }
  })
}

最终效果如下图:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值