《微信小程序实战(4) · 地图导航功能》

📢 大家好,我是 【战神刘玉栋】,有10多年的研发经验,致力于前后端技术栈的知识沉淀和传播。 💗

🌻 CSDN入驻不久,希望大家多多支持,后续会继续提升文章质量,绝不滥竽充数,欢迎多多交流。👍

文章目录

    • 写在前面的话
    • 海报生成
      • 需求简介
      • 地图组件介绍
      • 后台位置共享
      • 足迹绘制
      • 选点绘制
      • 其他功能
    • 总结陈词

写在前面的话

本篇文章是微信小程序系列的第四篇,本着介绍地图导航小程序的核心地图功能。

相关文章
《微信小程序实战(1)· 开篇示例 》
《微信小程序实战(2) · 组件封装》
《微信小程序实战(3) · 推广海报制作》


海报生成

需求简介

要求实现微信小程序的地图功能清单如下:
1、用户可以共享位置信息,也可以看见他人的位置信息;

2、移动过程中要可以描绘足迹,同时保存后可以查看;

3、地图支持选点画线功能,同样支持保存分享;

上述三个需求点,分别对应地图的三个功能,下面一一展开。


地图组件介绍

微信小程序的地图组件是一个非常实用的功能,允许开发者在小程序中嵌入地图,展示地理位置、标记点、路线等信息。

1、地图组件基本用法

在小程序的 WXML 文件中使用 <map> 标签来创建地图组件:

<map longitude="{{longitude}}" latitude="{{latitude}}" scale="14" markers="{{markers}}" />

2、主要属性

longitude: 地图中心的经度。

latitude: 地图中心的纬度。

scale: 地图缩放级别,范围通常是 5 到 18。

markers: 地图上的标记点,通常是一个数组,包含多个标记的经纬度和其他信息。

3、标记点(Markers)

标记点是地图上显示的位置,可以通过设置 markers 属性来添加。每个标记点是一个对象,包含以下属性:

latitude: 标记点的纬度。

longitude: 标记点的经度。

title: 标记点的标题。

iconPath: 自定义标记图标的路径。

width: 图标的宽度。

height: 图标的高度。

this.setData({markers: [{id: 1,latitude: 23.099994,longitude: 113.324520,title: '标记点1',iconPath: '/images/marker.png',width: 50,height: 50}]
});

4、事件处理

地图组件支持多种事件,例如:

regionchange: 地图区域变化时触发。

markertap: 点击标记点时触发。

maptap: 点击地图时触发。

<map bindmarkertap="onMarkerTap" bindregionchange="onRegionChange" />
onMarkerTap(e) {console.log('点击了标记点', e.markerId);
},onRegionChange(e) {console.log('地图区域变化', e.type);
}

5、获取用户位置

可以使用微信小程序的 API 获取用户的地理位置,并将其设置为地图的中心:

wx.getLocation({type: 'wgs84',success: (res) => {this.setData({latitude: res.latitude,longitude: res.longitude});}
});

后台位置共享

前面介绍的都是基础用法,比较简单,可忽略,接下来开始正篇。

这个需求要拆解为两个部分:

1、共享自己的位置(上传位置信息);

2、显示所有人的位置(定时获取);

先看第一点,要共享自己的位置,同时要支持微信小程序切换至后台,仍然可以监听到位置变化。

需要借助小程序的onLocationChange支持位置变更,先看示例代码。


openLocationHandle() {let that = thiswx.getSetting({success(res) {if (res.authSetting['scope.userLocationBackground']) {that.startLocationUpdateBackground()app.globalData.hasStart = true} else {wx.authorize({scope: 'scope.userLocationBackground', success() {that.startLocationUpdateBackground()app.globalData.hasStart = true}, fail(err) {console.log('userLocationBackground失败,错误信息:', err)that.openSetting()}})}}})
},/*** 位置处理 - 开启小程序监听动作*/
startLocationUpdateBackground: function () {let that = thiswx.setStorageSync('oldLocation', -1);wx.setStorageSync('oldTime', -1);    // 开启小程序在前后台时均可接收位置消息wx.startLocationUpdateBackground({type: 'gcj02', success: function () {            // 监听实时地理位置变化事件// 需结合 wx.startLocationUpdateBackground、wx.startLocationUpdate使用wx.onLocationChange(that.onLocationChangeHandle)}, fail: function (err) {ace.msg('startLocation失败')console.log('startLocationUpdateBackground失败,错误信息:', err)that.openSetting()},})
},

首先,先授权一下scope.userLocationBackground后台监听权限,授权成功则可以调用wx.startLocationUpdateBackground打开后台位置变化监听功能,同时使用wx.onLocationChange监听微信变化,传入的回调函数里面可以将获取到的位置信息,不断上报。

要使用后台授权功能,app.json还需要添加配置如下,按需添加需要的API即可。

"requiredPrivateInfos": ["getLocation","chooseAddress","onLocationChange","startLocationUpdate","startLocationUpdateBackground"
]

核心的onLocationChangeHandle逻辑里面,可以将回传的经纬度不断上报到后端,部分代码如下。

下方代码可以通过位置变化和坐标变化幅度判断,避免频繁处理请求(还不够的话可以添加距离变化判断)。

onLocationChangeHandle: function (res) {let {latitude, longitude} = res//省略部分逻辑。。。// 获取上次保存的位置信息let oldLocation = wx.getStorageSync('oldLocation')// 获取这次获取的位置信息let nowLocation = latitude + ',' + longitude// 位置一样则退出,坐标没变化if (nowLocation === oldLocation) {return;}// 获取上次执行的时间let oldTime = wx.getStorageSync('oldTime')// 获取当前时间let currentTime = new Date().getTime()// 间隔时间小于6S退出if (!oldTime || currentTime - oldTime < 6000) {return;}// 上传位置信息,调后端逻辑。。。// 修改缓存数据wx.setStorageSync('oldLocation', nowLocation);wx.setStorageSync('oldTime', currentTime);
}

第二个点就简单多了,就写一个定时器,然后不断获取位置,利用map组件的标记功能即可。

核心代码如下:

// 定时获取所有人的实时位置
that.timeHandleGet();
shareIntervalNum = setInterval(function () {that.timeHandleGet();
}, 2000);
timeHandleGet() {let that = thislet payNo = that.data.payNo// 获取其他在线用户的位置ace.sendGet('xjStaffDict/locationShareList', function (data) {let newArr = [] //所有人的标记信息data.forEach(function (v, i) {// 非本人则渲染共享标记信息if (v.remark && v.staffId !== payNo) {let nowPositionArr = v.remark.split(',')let tempMark = that.markHandle("位置共享", nowPositionArr[1], nowPositionArr[0], v.realyName, "", i, v.staffId, v.realyImg);tempMark.payNo = v.staffIdnewArr.push(tempMark)}})that.setData({markers: newArr})}, "no");
},

足迹绘制

足迹绘制也是基于第一个需求,自身位置不断变化的过程中,把经纬度暂存下来,然后利用map组件的polyline属性,绘制路线,部分代码如下:

// 路线信息拼接
points.push({longitude: longitude, latitude: latitude})
let polyline = [{points: points, color: "#FF0000DD", width: 2, dottedLine: false
}];//更新路线和自己的坐标
that.setData({longitude: longitude, latitude: latitude
})
if (points.length > 1) {that.setData({polyline: polyline})
}
ace.msg('逻辑成功,节点数:' + points.length);//放入缓存,后续加载
wx.setStorageSync('pointsData', JSON.stringify(points));

过程示例图如下:

足迹保存后查看效果如下:

选点绘制

这项功能就更简单了,利用map组件的地图坐标点击监听方法bindtap实现。

部分代码如下:

mapClick(e) {let that = this;let pointHandleFlag = that.data.pointHandleFlag || falseif (pointHandleFlag) {//获取当前地图选点let markers = that.data.markers;let id = ace.generateUUID();let name = `选点${markers.length + 1}`let tempMark = that.markHandle('选点', e.detail.longitude, e.detail.latitude, '', name, markers.length, id);points.push(e.detail)markers.push(tempMark)if (points.length > 1) {let polyline = [{points: points, color: "rgba(5,197,95,0.87)", width: 2, dottedLine: false}];that.setData({markers, polyline})} else {that.setData({markers})}} else {console.log('当前非地图选点模式!')}
},

示例图如下:

其他功能

有了前面marker的基础,想实现打标记功能就很简单了。

制作一个表单页面,如下所示:

创建完成后,将坐标信息在地图加载出来,也可以增加坐标过滤功能,或者增加点击展示详情。


总结陈词

此篇文章是《微信小程序实战》系列的第四篇,实际代码量较大,由于篇幅所限,没有贴出全部代码,主要学习一个地图功能思想,感兴趣的可以留言交流,希望可以帮助到大家。

💗 后续会逐步分享企业实际开发中的实战经验,有需要交流的可以联系博主。

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

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

相关文章

ubuntu挂载磁盘或U盘

方法 在Ubuntu中&#xff0c;使用命令行读取U盘通常涉及到以下几个步骤&#xff1a;插入U盘、查找设备名称、挂载U盘以及访问文件。以下是详细步骤&#xff1a; 1. 插入U盘 将U盘插入计算机的USB端口。 2. 查找设备名称 你可以使用lsblk或dmesg命令来查找新插入的U盘设备名…

240924-通过服务器代理ip地址及port端口wget等下载文件

A. 如何下载 在服务器上设置了代理 IP 和端口后&#xff0c;可以使用以下命令行格式通过 wget 下载文件&#xff1a; wget -e use_proxyyes -e http_proxyhttp://代理IP:端口号 目标文件URL或者&#xff0c;如果你使用 HTTPS 协议&#xff0c;可以使用以下命令&#xff1a; …

mac 外接键盘后需要做的调整

对调win和alt键 Mac自带键盘空格键左边有control option command 三个键&#xff08;fn键属于F1-F2的扩展功能键&#xff0c;不属于&#xff09; 当外接键盘&#xff08;对应地是control win alt&#xff09;时需要将win对应option, alt对应command&#xff08;默认时反着的&…

数据结构应试-1

1. 好像是错的 2. n个元素&#xff0c;插入的可能有n1个位置&#xff0c;所以n&#xff08;n1&#xff09;/2*(n1)2/n 3. 4. 5. 6. 假设我们有一个循环队列&#xff0c;数组的长度为 n 10&#xff0c;并且当前队头指针 f 的位置是 2&#xff0c;队尾指针 r 的位置是 8。我们需…

【开源免费】基于SpringBoot+Vue.JS墙绘产品展示交易平台(JAVA毕业设计)

本文项目编号 T 049 &#xff0c;文末自助获取源码 \color{red}{T049&#xff0c;文末自助获取源码} T049&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析 六、核心代码6.1 查…

携手SelectDB,观测云实现性能与成本的双重飞跃

在刚刚落下帷幕的2024云栖大会上&#xff0c;观测云又一次迎来了全面革新。携手SelectDB&#xff0c;实现了技术的飞跃&#xff0c;这不仅彰显了观测云在监控观测领域的技术实力&#xff0c;也预示着我们可以为全球用户提供更加高效、稳定的数据监测与分析服务。这一技术升级&a…

Golang | Leetcode Golang题解之第435题无重叠区间

题目&#xff1a; 题解&#xff1a; func eraseOverlapIntervals(intervals [][]int) int {n : len(intervals)if n 0 {return 0}sort.Slice(intervals, func(i, j int) bool { return intervals[i][1] < intervals[j][1] })ans, right : 1, intervals[0][1]for _, p : ra…

【计算机视觉】YoloV8-训练与测试教程

✨ Blog’s 主页: 白乐天_ξ( ✿&#xff1e;◡❛) &#x1f308; 个人Motto&#xff1a;他强任他强&#xff0c;清风拂山冈&#xff01; &#x1f4ab; 欢迎来到我的学习笔记&#xff01; 制作数据集 Labelme 数据集 数据集选用自己标注的&#xff0c;可参考以下&#xff1a…

面经 | css

CSS CSSpositiondisplayflex: 1元素居中flexalign-itemjustify-contentabsolutemargin:auto align-item vs vertical-align CSS position static: 默认。就是自然顺序&#xff0c;从上到下&#xff0c;从左到右&#xff0c;爱着你排列&#xff1b;absolute&#xff1a;绝对。…

如何备份SqlServer数据库

第一步&#xff1a;登录你要备份的服务器数据库ssms 第二步&#xff1a;选择你要备份的数据库 此处已PZ-SJCS 数据库为例 右键该数据库-->任务-->备份 第三步&#xff1a;选择你备份的类型备份组件等&#xff0c;目标磁盘 &#xff0c;点击添加选择将你备份的文件备份那…

数据结构~二叉搜索树

文章目录 一、二叉树搜索的概念二、二叉树搜索的结构二叉树搜索的性能分析二叉树搜索的插入二叉树搜索的查找二叉树搜索的删除 三、二叉搜索树key和key/value使用场景四、二叉树搜索的练习将二叉搜索树就地转化为已排序的双向循环链表从前序与中序遍历序列构造二叉树二叉树的前…

react父子组件数据传递及相关操作

组件创建 坑1&#xff1a;组件名字的首字母记得大写 方式一&#xff1a;类组件&#xff08;老版本的方式&#xff09; Form.create() //很关键&#xff0c;不加的话父子嵌套时会报找不到某些组件的错 class Child extends React.Component { componentDidMount(){this.props…

茶思屋直播|TinyEngine+AI:聚焦主航道,在实践中探索低代码技术黑土地

低代码引擎使能开发者定制低代码平台。它是低代码平台的底座&#xff0c;提供可视化搭建页面等基础能力&#xff0c;既可以通过线上搭配组合&#xff0c;也可以通过cli创建个人工程进行二次开发&#xff0c;实时定制出自己的低代码平台。适用于多场景的低代码平台开发&#xff…

GIS开发常用的开源地图数据框架有哪些?

学完Web前端开发&#xff0c;还需要掌握哪些内容&#xff1f;本篇文章再给大家主要讲讲针对WebGIS开发的地图和可视化数据库。 Echarts ECharts是一个使用 JavaScript 实现的开源可视化库。它可以流畅的运行在 PC 和移动设备上&#xff0c;兼容当前绝大部分浏览器&#xff08;…

python 逻辑语句简记

什么语言都少不了逻辑处理语句的使用&#xff0c;python的逻辑处理语句有自身的使用特点&#xff0c;稍稍总结记录一下 一、断言 assert 条件 条件触发&#xff0c;程序执行中断 二、条件语句 if 条件&#xff1a; 执行内容 三、循环语句 while 条件&#xff1a; 循环体…

LTE SSS产生过程中z序列的介绍和MATLAB以及C语言实现

参考3GPP 36.211 6.11章节 接上期介绍完LTE SSS产生过程中加扰序列c的产生和代码实现&#xff0c;本期介绍一下LTE SSS产生过程中加扰序列z的原理和MATLAB以及C语言的实现。 SSS产生过程中用到的加扰Z1序列有两个&#xff0c;一个是 另一个是 两个序列是由一个m序列z移位而来…

.env文件详解(vite项目全局配置文件)

.env文件是一个用于存储环境变量的文件。在开发和部署应用程序时,经常需要在不同的环境中配置不同的变量,例如 API 地址、数据库连接信息、密钥等。在许多应用程序中,.env 文件通常包含一个或多个键值对,用于存储环境变量。 Vite 中的 .env 文件还可以用于配置构建时的变量…

“一屏显江山”,激光显示重构「屏中世界」

【潮汐商业评论/原创】 2024年国庆期间&#xff0c;曾感动过无数国人的舞蹈诗剧《只此青绿》改编的同名电影即将上映&#xff0c;而这一次观众们不必走进电影院&#xff0c;在家里打开官方合作的海信激光电视也能享受到同等的视听效果&#xff0c;这是激光电视在观影场景领域的…

【C++ 基础数学 】2121. 2615相同元素的间隔之和|1760

本文涉及的基础知识点 基础数学 LeetCode2121. 相同元素的间隔之和 难度分&#xff1a;1760 令2165&#xff0c;和此题几乎相等。 给你一个下标从 0 开始、由 n 个整数组成的数组 arr 。 arr 中两个元素的 间隔 定义为它们下标之间的 绝对差 。更正式地&#xff0c;arr[i] 和…

rockylinux9.4单master节点k8s1.28集群部署

kubernetes集群部署 常见的 k8s 部署方式包括&#xff1a;二进制包、kubeadm 工具、云服务提供商、或通过一些开源的工具搭建&#xff0c;例如&#xff1a;sealos、kuboard、Runcher、kubeSphere。 本文使用kubeadm的部署方式&#xff0c;部署k8s1.28版本 我本地安装资源规划…