微信小程序学习--地图组件的踩坑--获取用户位置--腾讯位置服务地图选点

map地图组件

wxml使用

直接使用map即可

  <map class="map" id="map" longitude="{{longitude}}" latitude="{{latitude}}" scale="19" markers="{{markers}}" min-scale="16">
  </map>

同层渲染

直接在map里面加入就可以了,就可以实现在map上展示内容了
在这里插入图片描述

  <map class="map" id="map" longitude="{{longitude}}" latitude="{{latitude}}" scale="19" markers="{{markers}}" min-scale="16">
    <view class="add">
      <view>添加</view>
      <mp-icon type="outline" icon="add2" color="black" bindtap="showMap" size="{{35}}" />
    </view>
  </map>

但是我发现还是不能绑定点击事件。所以还是嵌套一层cover-view算了

  <map class="map" id="map" longitude="{{longitude}}" latitude="{{latitude}}" scale="19" markers="{{markers}}" min-scale="16">
    <view class="add">
      <view>添加</view>
      <cover-view>
        <mp-icon type="outline" icon="add2" color="black" size="{{35}}" bindtap="showMap">
        </mp-icon>
      </cover-view>
    </view>
  </map>

标签

markers绑定的数组代表着展示的所有的标点,如
在这里插入图片描述

 marker = [{
        id: 0,
        //标签的经纬度
        latitude: res.latitude, 
        longitude: res.longitude,
        //上面的图片
        iconPath: "/images/marker.png",
        //图片的大小
        width: 20,
        height: 20
        //气泡展示,
        callout: {
        //气泡的文字颜色等等
          content: "当前位置",
         
          color: "#333333",
          fontSize: 13,
          borderRadius: 20,
          bgColor: "#ffffff",
          textAlign: "center" ,
          padding: 10,
          display: 'ALWAYS'
        }
      }]

腾讯位置服务地图选点

授权

在这里插入图片描述

创建应用

地址

新建一个key,然后填写马赛克的地方,其他一样。
在这里插入图片描述

添加插件

插件地址

在这里插入图片描述

小程序加入插件

引入插件包:
地图选点appId: wx76a9a06e5b4e693e

// app.json
{
  "plugins": {
    "chooseLocation": {
      "version": "1.0.10",
      "provider": "wx76a9a06e5b4e693e"
    }
  }
}

设置定位授权:
地图选点插件需要小程序提供定位授权才能够正常使用定位功能:

// app.json
{
  "permission": {
    "scope.userLocation": {
      "desc": "你的位置信息将用于小程序定位"
    }
  }
}

使用插件:
插件页面调用示例:

const key = ''; //使用在腾讯位置服务申请的key
const referer = ''; //调用插件的app的名称
const location = JSON.stringify({
  latitude: 39.89631551,
  longitude: 116.323459711
});

wx.navigateTo({
  url: `plugin://chooseLocation/index?key=${key}&referer=${referer}&location=${location}`
});

获取选点

onShow () {
    const chooseLocation= chooseLocation.getLocation(); // 如果点击确认选点按钮,则返回选点结果对象,否则返回null
    console.log(chooseLocation)
  }

清除选点信息

  onUnload() {
    chooseLocation.setLocation(null);
  },

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一只小余

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

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

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

打赏作者

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

抵扣说明:

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

余额充值