uniapp使用腾讯地图实现商家定位

news2024/11/18 12:18:27

uniapp使用腾讯地图实现商家定位

  • 一丶申请腾讯位置服务开发者密钥
  • 二丶下载微信小程序JavaScriptSDK
  • 三丶安全域名设置
  • 四、代码编写
  • 五、实现效果

一丶申请腾讯位置服务开发者密钥

官网教程:微信小程序JavaScript SDK | 腾讯位置服务

点击申请密钥
在这里插入图片描述
创建应用,然后添加Key
在这里插入图片描述
添加key,并且勾选WebServiceApi
在这里插入图片描述

二丶下载微信小程序JavaScriptSDK

下载链接: https://mapapi.qq.com/web/miniprogram/JSSDK/qqmap-wx-jssdk1.2.zip
在这里插入图片描述

三丶安全域名设置

安全域名设置,在小程序管理后台 -> 开发 -> 开发管理 -> 开发设置 -> “服务器域名” 中设置request合法域名,添加https://apis.map.qq.com
在这里插入图片描述

四、代码编写

  1. 在项目中创建utils目录将下载好JavaScriptSDK放入其中,并在uniapp中导入。
    在这里插入图片描述
 import QQMapWX from '@/utils/qqmap-wx-jssdk.js'
  const qqmapsdk = new QQMapWX({
    //填写你申请的key
    key: '****-****-****-****-****-****'
  })

2. 编写代码

这里在使用前有两个注意事项,很重要,否则调用不成功

  1. 在调用方法之前,需要在控制台 -> 配额管理 -> 账号额度 对指定接口进行手动配额分配(免费的),否则每天就只会有一次调用接口的机会。
    在这里插入图片描述

  2. 在计算步行距离时如果调用这个方法qqmapsdk.calculateDistance是不生效的,
    官方已经不再维护,需要自己手动调用地址https://apis.map.qq.com/ws/distance/v1/matrix,
    同理该接口也需要手动进行配额分配。
    在这里插入图片描述

  import QQMapWX from '@/utils/qqmap-wx-jssdk.js'
  const qqmapsdk = new QQMapWX({
    //填写你申请的key
    key: '****-****-****-****-****-****'
  })
export default {
    data() {
      return {
        //商家列表
        markers: JSON.parse(uni.getStorageSync("markers")||'[]'),
        //自身经纬度
        from: {},
        //页码值
        page_index: 1,
        //每页显示多少条数据
        page_size: 10,
        //分页总条数
        total: 100,
      }
    },
    methods: {
      chooseLocation(){
        let that = this
      	uni.chooseLocation({
      		success: (data)=> {
      			that.from.latitude = data.latitude
      			that.from.longitude = data.longitude
            that.getViennaList()
      		},
          fail:(e)=>{
            uni.showToast({
              title: '无法获取当前位置!',
              icon: 'error',
              duration: 1500
            });
          }
      	})
      },
      chooseStore() {
        //获取当前地理位置
        let that = this
        uni.getLocation({
          type: 'gcj02',
          success(res) {
            console.log('---getLocation---', res)
            that.from.latitude = res.latitude
            that.from.longitude = res.longitude
            that.getViennaList()
          },
          fail: (err) => {
            console.log('---errgetLocation---', err)
            uni.showToast({
              title: '无法获取当前位置!',
              icon: 'error',
              duration: 1500
            });
          }
        })
      },
      getViennaList() {
        //获取商家位置
        let that = this
        console.log(that.from)
        qqmapsdk.search({
          //关键字改成所需商家名称
          keyword: "奈雪的茶",
          //自身经纬度对象
          location: that.from,
          //分页(可忽略)
          page_index: that.page_index,
          page_size: that.page_size,
          success: (res) => {
            var mks = []
            for (var i = 0; i < res.data.length; i++) {
              mks.push({ // 获取返回结果,放到mks数组中
                title: res.data[i].title,
                id: res.data[i].id,
                latitude: res.data[i].location.lat,
                longitude: res.data[i].location.lng,
                address: res.data[i].address,
                distance: ''
              })
            }
            that.changeWidth(mks);
          },
          fail: (err) => {
            console.log('--qqmapsdk.search err---', err)
            uni.showToast({
              title: '无法获取商店位置!',
              icon: 'error',
              duration: 1500
            });
          }
        })
      },
      //计算距离
      changeWidth(mks) {
        let _this = this
        let fromAddress = `${_this.from.latitude},${_this.from.longitude}`
        console.log(fromAddress)
        let toAddress = '';
        for (let i = 0; i < mks.length; i++) {
          toAddress += `${mks[i].latitude},${mks[i].longitude}`
          if (i != mks.length - 1) {
            toAddress += ';'
          }
        }
         uni.request({
           url: 'https://apis.map.qq.com/ws/distance/v1/matrix',
           method: 'POST',
           data: {
             mode: 'walking',
             from: fromAddress,
             to: toAddress,
             //填写你申请的key 
             key: 'xxx-xxxx-xxxx-xxxx-xxxx-xxxx'
           },
           success: (res) => {
             console.log(res)
                for (let i = 0; i < res.data.result.rows[0].elements.length; i++) {
                  let hw = res.data.result.rows[0].elements[i].distance
                  if (hw && hw !== -1) {
                    if (hw < 1000) {
                      hw = hw + 'm';
                    } else {
                      hw = (hw / 2 / 500).toFixed(2) + 'km'
                    }
                  } else {
                    hw = "距离太近或请刷新重试"
                  }
                  mks[i].distance = hw
                }
                _this.markers = mks
                console.log(_this.markers)
                uni.setStorageSync("markers",_this.markers)
           }
         }) 
      }
    }

  }
**```
3. 调用方法并展示**

```javascript
<template>
  <view class="container" >
    <view class="row b-b">
    	<text class="tit">请选择地址: </text>
    	<input @click="chooseLocation" class="addressInput "  placeholder="请选择地址进行搜索">
    	</input>
    	<text class="yticon icon-shouhuodizhi"></text>
    </view>
  </view>
</template>  
  1. 小程序增加对chooseLocation、getLocation调用权限
    .在manifest.json中加入如下代码,否则获取地址时会出现权限不足
/* 小程序特有相关 */
      "permission" : {
      		    "scope.userLocation" : {
      		        "desc" : "你的位置信息将用于小程序位置接口的效果展示"
      		    }
      		},
       "requiredPrivateInfos" : [ "chooseLocation", "getLocation" ],

在这里插入图片描述

五、实现效果

在这里插入图片描述
最后简单写了一下样式,展示效果如下:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1614254.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Hive 中常用的函数以及数据类型

数据类型 1.基本数据类型: 数据类型大小范围示例TINYINT1byte-128 ~ 127100YSMALLINT2byte-32768 ~ 32767100SINT4byte-2^32~ 2^32-1100BIGINT8byte-2^64~ 2^64-1100LFLOAT4byte单精度浮点数5.21DOUBLE8byte双精度浮点数5.21DECIMAL-高精度浮点数DECIMAL(9,8)BOOLEAN-布尔型tr…

Windows系统下安装paddle

开始使用_飞桨-源于产业实践的开源深度学习平台 (paddlepaddle.org.cn) 命令行下&#xff1a; python -m pip install --upgrade pip --user python -m pip install paddlepaddle2.6.1 -i https://pypi.tuna.tsinghua.edu.cn/simple 报异常 ERROR: Could not install packa…

力扣HOT100 - 24. 两两交换链表中的节点

解题思路&#xff1a; 递归 class Solution {public ListNode swapPairs(ListNode head) {if (head null || head.next null) {return head;}ListNode newHead head.next;head.next swapPairs(newHead.next);newHead.next head;return newHead;} }

nvm版本控制nvm list available报错

# 配置node镜像&#xff1a; node_mirror: https://npmmirror.com/mirrors/node/ # 配置npm镜像&#xff1a; npm_mirror: https://npmmirror.com/mirrors/npm/ 2024.4.22换域名了&#xff0c;改成这个才能用别的不行

护眼灯真的可以保护眼睛吗?揭秘护眼台灯五大骗局!

护眼台灯作为书房中必不可少的工具之一&#xff0c;基本家家户户都有&#xff0c;但是&#xff0c;随着需求的增加&#xff0c;越来越多不专业的台灯品牌进入市场&#xff0c;这种品牌下的产品不仅质量差&#xff0c;而且使用久了还会出现近视加深、散光等风险&#xff0c;导致…

Linux-缓冲区(简单理解)

1. 缓冲区是什么 缓冲区就是一段内存空间。 2. 为什么要有缓冲区 IO写入有两种&#xff1a; 写透模式&#xff08;WT&#xff09; 成本高&#xff0c;效率低写回模式&#xff08;WB&#xff09; 成本低&#xff0c;效率高 写透模式&#xff1a;每次的文件写入都要立即刷新…

绿联搭建rustdesk服务器

绿联搭建rustdesk服务器&#xff0c;不再使用向日葵 注意&#xff1a;本服务器需要有动态公网IP以及自己的域名&#xff0c;ipv6未测试。 1. 拉取镜像 rustdesk/rustdesk-server-s6:latest 注意是这个-s6的镜像。 2. 部署镜像 2.1 内存配置 本服务器比较省内存&#xff0…

基于Springboot+Vue的Java项目-在线文档管理系统开发实战(附演示视频+源码+LW)

大家好&#xff01;我是程序员一帆&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;Java毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计 &am…

Unity 对APK签名

关键代码 PS D:\UnityProject\YueJie> jarsigner -verbose -keystore D:\UnityProject\YueJie\user.keystore -signedjar D:\UnityProject\YueJie\meizuemptyapk-release-signed.apk D:\UnityProject\YueJie\MeizuEmpty-release-unsigned.apk 1 示例 # jarsigner的命令格…

免费升级网站http改为https

目录 首先带大家一起先了解一下http的定义、历史、优势以及缺陷。 简述HTTPS的原理和加密逻辑&#xff1a; 免费且不花钱就能实现网站的https访问方式&#xff1a; 很多人可能都发现了&#xff0c;在浏览网页时&#xff0c;最常见的是http访问&#xff0c;但是也有一部分网站…

YashanDB连获多项权威认证

近期&#xff0c;YashanDB产品能力再获认可&#xff0c;顺利通过多项权威测试认证&#xff0c;包括通过《数据库政府采购需求标准(2023年版)》测评&#xff1b;通过国密检测机构测试&#xff0c;产品支持GB/T38636-2020《信息安全技术传输层密码协议(TLCP)》国标协议&#xff1…

Centos7.9安装rabbitmq

1. 概述 AMQP&#xff0c;即 Advanced Message Queuing Protocol&#xff08;高级消息队列协议&#xff09;&#xff0c;是一个网络协议&#xff0c;是应用层协议的一个开放标准&#xff0c;为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息&#xff0c;并不…

Jackson知识点记录

文章目录 一.Jackson模块说明 二.ObjectMapper基本功能使用ObjectMapper的一些核心方法&#xff1a;示例代码1. 序列化示例2. 反序列化示例3. JsonNode 处理示例 高级配置 三.各种Node1. ObjectNode2. ArrayNode3. ValueNode4. MissingNode示例 一.Jackson Jackson 库主要分为…

安泰电子 :高压功率放大器设计方案有哪些

高压功率放大器是现代通信和电子设备中不可或缺的关键组件。它能够将低功率信号放大到足够的功率水平&#xff0c;以便在各种应用中实现远距离传输和覆盖范围。下面西安安泰电子将介绍高压功率放大器的设计方案&#xff0c;包括电路拓扑、元件选择、功率损耗和失真控制等方面的…

vue3的getCurrentInstance获取当前组件实例

vue3的setup中没有this时需要使用getCurrentInstance()来获取。 在 Vue 3 中&#xff0c;getCurrentInstance 方法可以在组合式 API&#xff08;Composition API&#xff09;中获取当前组件实例。这个方法返回一个包含了组件实例的对象&#xff0c;你可以用它来访问组件的 pro…

Apache POI报表统计

Apache POl是一个处理Miscrosoft Office各种文件格式的开源项目。简单来说就是&#xff0c;我们可以使用 POl 在 Java 程N序中对Miscrosoft Office各种文件进行读写操作。一般情况下&#xff0c;POI都是用于操作 Excel 文件。 导入Maven坐标&#xff1a; <dependency>&l…

文件I/O基础-I.MX6U嵌入式Linux C应用编程学习笔记基于正点原子阿尔法开发板

本章将介绍Linux应用编程中最基础的知识&#xff0c;即文件I/O&#xff08;Input/Output&#xff09;。文件I/O指的是对文件进行读写操作&#xff0c;在Linux系统中一切皆文件&#xff0c;这是Linux系统设计的核心理念&#xff0c;因此文件I/O操作既是基础又是最重要的部分。本…

剑指offer剪绳子;leetcode:LCR 131. 砍竹子 I

现需要将一根长为正整数 bamboo_len 的竹子砍为若干段&#xff0c;每段长度均为正整数。请返回每段竹子长度的最大乘积是多少。 示例 1&#xff1a; 输入: bamboo_len 12 输出: 81提示&#xff1a; 2 < bamboo_len < 58 注意&#xff1a;本题与主站 343 题相同&#…

硬件中断错误HardFault_Handle如何解决

一、在硬件中断处点击断点 二、打开Call Stack Window 三、打开Disassembly Window 四、右击空白处&#xff0c;输入遇到硬件中断前地址&#xff0c;即可知道错误原因 程序就会自动跳转硬件中断错误处 ​​​​​​

Python中列表数据的保存与读取:以txt文件为例

目录 引言 一、列表数据的保存 二、列表数据的读取 三、进阶用法与注意事项 1. 处理嵌套列表 2. 处理大量数据 3. 注意事项 四、总结 引言 在Python编程中&#xff0c;我们经常需要处理各种类型的数据&#xff0c;包括列表。列表是一种非常灵活的数据结构&#xff0c;…