微信小程序|基于小程序实现打卡功能

news/2024/5/21 10:07:44/文章来源:https://blog.csdn.net/weixin_42794881/article/details/127270238

文章目录

    • 一、文章前言
    • 二、开发流程及准备
    • 三、开发步骤

一、文章前言

此文主要在小程序内实现打卡功能,可根据用户位置与公司设定的打卡范围实时判断打卡场景。

二、开发流程及准备

2.1、注册微信公众平台账号。
2.2、准备腾讯地图用户Key。

三、开发步骤

3.1、访问腾讯位置服务,申请腾讯地图用户Key,因为在后面我们需要将用户的经纬度解析成地址,所以这个步骤是必不可少的。
在这里插入图片描述
3.2、点击右上角的登陆,选择注册或绑定现有账号。
在这里插入图片描述
3.3、绑定完毕后,选择创建API Key。
在这里插入图片描述
3.4、将表单信息填写完成后,点击确定将所创建的API Key保存下来。
在这里插入图片描述

3.5、账号跟Key准备好后,我们就可以开始小程序的开发了,打开微信开发者工具,新建项目,选择不使用模板、不使用云服务。

在这里插入图片描述
3.6、在pages文件夹下面创建一个文件夹并新建对应的page文件。
在这里插入图片描述
3.7、在index.js中引入utils文件夹下面的引入腾讯地图SDK核心类。
在这里插入图片描述

const util = require("../../utils/util.js");
const app = getApp();
// 引入腾讯地图SDK核心类
var QQMapWX = require('../../utils/map/qqmap-wx-jssdk.js');
var qqmapsdk;

3.8、在onLoad事件中我们将其进行实例化,这时就要用到我们所申请的key了。

    qqmapsdk = new QQMapWX({key: '刚刚所申请的key填到这里'});

3.9、准备工作做好后,我们尝试一下这个SDK是否有效。将公司设定的打卡地址作为参数进行解析,然后将结果进行输出。

qqmapsdk.geocoder({address: '广东省深圳市南山区粤海街道深圳湾科技生态园9栋B座',success: function(res) {//成功后的回调console.log(res);}
});

3.10、可以看到,我们所需要的经纬度等信息都顺利的解析出来了。
在这里插入图片描述
3.11、公司地址解析出来后,我们就需要获取用户实时地址信息了,这里需要调用wx.getLocation函数将结果进行打印输出。

  wx.getLocation({type: 'wgs84',success (res) {console.log(res);}});

3.12、longitude和latitude就是我们所需要的用户经纬度字段了,现在我们需要将用户经纬度逆转析为省市区地址将其显示在界面上。
在这里插入图片描述

 //将用户经纬度转换为地址
qqmapsdk.reverseGeocoder({//地址解析location: {longitude: userlng,latitude: userlat,},success: function (res) {console.log(res);}
});

在这里插入图片描述

  that.setData({userAddress:res.result.address});
<text class="addressText">{{userAddress}}</text>

在这里插入图片描述

3.13、接下来封装两个函数,用于获取两个经纬度之间的距离。

function rad(d) {return d * Math.PI / 180.0;
}
function distanceOf(p1, p2) {var radLng1 = rad(p1.x);var radLng2 = rad(p2.x);var mdifference = radLng1 - radLng2;//	两点纬度之差var difference = rad(p1.y) - rad(p2.y);//	经度之差//	计算两点距离的公式var distance = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(difference / 2), 2)+ Math.cos(radLng1) * Math.cos(radLng2) * Math.pow(Math.sin(mdifference / 2), 2)));//	弧长等于弧度乘地球半径(半径为米)distance = distance * 6378.137;//	精确距离的数值distance = Math.abs(Math.round(distance * 10000) / 10);return distance;
}

3.14、将公司地址所解析的经纬度以及用户的经纬度进行拼接作为参数传递给我们所封装的函数。这个dis就是两个经纬度之间的距离,单位是米。

//var dis = distanceOf({"x":113.954791,"y":22.531843},{"x":113.952385,"y":22.53091});
//comoanylng:公司经度,comoanylat:公司纬度,userlng:用户经度,userlat:用户纬度var dis = distanceOf({"x":comoanylng,"y":comoanylat},{"x":userlng,"y":userlat});

3.15、js任务完成后需要实现对应的wxml及css样式。

<view class="userInfo"><view><image src="../../../images/cat.jpg"></image></view><view class="name"><view class="uName">摔跤猫子</view><view><text style="color:#7D8082;">考勤</text><text style="color:#207CD0;">(查看规则)</text></view></view>
</view>
<view class="content1"><view class="contentBox1"><view class="time"><view class="uptime">上班09:00</view><view class="cu-item cuitemText"><text class="cuIcon-roundcheckfill lg text-blue"></text><text style="color:#74787E;margin-left:10rpx;">08:52已打卡</text></view><view class="iconText">外勤</view></view><view class="time"><view class="uptime">下班18:30</view><view class="cu-item cuitemText"><text class="cuIcon-roundclosefill lg text-red"></text><text style="color:#74787E;margin-left:10rpx;">暂未打卡</text></view></view></view><view class='cu-load load-modal' style="box-shadow: 0 0 0 0 white;"><view class="cu-item"><text class="cuIcon-locationfill lg  {{normal?'text-green':'text-red'}}"></text></view><view class='gray-text'>{{normal?'正常打卡':'外勤打卡'}}</view>
</view>
<view class="cu-item cuitemAddress"><text class="cuIcon-location lg text-blue"></text><text class="addressText">{{userAddress}}</text>
</view>
</view>
/* pages/basics/load/load.wxss */
page {background: #F4F5F7;
}.userInfo {width: 702rpx;height: 120rpx;margin-left: 24rpx;margin-top: 24rpx;background: white;border-radius: 25rpx;display: flex;
}.userInfo image {width: 90rpx;height: 90rpx;margin-top: 15rpx;margin-left: 24rpx;border-radius: 15rpx;
}.name {margin-left: 20rpx;height: 90rpx;margin-top: 15rpx;
}.uName {font-size: 40rpx;
}.content1 {height: 1000rpx;background: white;margin-top: 24rpx;width: 702rpx;margin-left: 24rpx;border-radius: 25rpx;
}.contentBox1 {width: 702rpx;border: 1rpx solid white;display: flex;
}.time {background: #F4F5F7;width: 315rpx;height: 120rpx;margin-top: 24rpx;margin-left: 24rpx;border-radius: 20rpx;
}.uptime {margin-top: 15rpx;font-size: 35rpx;margin-left: 20rpx;
}.cuitemText {font-size: 30rpx;margin-top: 10rpx;margin-left: 20rpx;
}.cuitemAddress {margin-top: 270rpx;text-align: center;
}.addressText {color: #74787E;margin-left: 10rpx;
}.iconText {position: absolute;margin-top: -105rpx;margin-left: 235rpx;width: 80rpx;background: green;color: white;border-top-right-radius: 20rpx;border-bottom-left-radius: 20rpx;text-align: center;
}

3.16、我们在调用计算距离的函数时定义一个变量用于判断当前用户所处位置是否在公司规定的打卡范围内。假设公司规定的打卡范围是200米,那么当距离超出时便给false,页面上也根据对应的值赋予不同的class样式。

  that.setData({normal:dis<=200?true:false});
 <view class="cu-item"><text class="cuIcon-locationfill lg  {{normal?'text-green':'text-red'}}"></text></view><view class='gray-text'>{{normal?'正常打卡':'外勤打卡'}}</view>

3.17、为了优化用户体验可以在事件中加上setInterval事件,设置时间间隔,每隔多久请求一次用户地址,因为用户在打卡的时候可能正在往公司路上赶,是一个高速移动的过程。

setInterval(function () {
//每隔一秒请求一次,中间放需要请求的函数
}, 1000);

这里采用的一个比较简单的方式实现的小程序打卡定位功能,围绕公司考勤或其他业务场景设计,有兴趣的小伙伴可以往里面补充进其他的想法,让它变得更齐全好用。

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

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

相关文章

【面试题常考!!!】JZ39 数组中出现次数超过一半的数字【五种方法解决】

欢迎观看我的博客&#xff0c;如有问题交流&#xff0c;欢迎评论区留言&#xff0c;一定尽快回复&#xff01;&#xff08;大家可以去看我的专栏&#xff0c;是所有文章的目录&#xff09; 字体风格&#xff1a; 红色文字表示&#xff1a;重难点 蓝色文字表示&#xff1a;思路以…

神经网络模型数据处理,神经网络模型参数辨识

1、有哪些深度神经网络模型&#xff1f; 目前经常使用的深度神经网络模型主要有卷积神经网络(CNN) 、递归神经网络(RNN)、深信度网络(DBN) 、深度自动编码器(AutoEncoder) 和生成对抗网络(GAN) 等。 递归神经网络实际.上包含了两种神经网络。一种是循环神经网络(Recurrent Neu…

STM32F4单片机读取AT24c02

​STM32F4是由ST&#xff08;意法半导体&#xff09;开发的一种高性能微控制器系列。其采用了90nm的NVM工艺和ART技术&#xff08;自适应实时存储加速器&#xff0c;Adaptive Real-Time MemoryAccelerator™&#xff09; AT24C02是Atmel公司出品的一个2K位串行CMOS E2PROM&…

【k8s】五、Pod生命周期(一)

目录 前言 Pod生命周期 Pod 相位 状态值 挂起&#xff08;Pending&#xff09; 运行中&#xff08;Running&#xff09; 成功&#xff08;Succeeded&#xff09; 失败&#xff08;Failed&#xff09; 未知&#xff08;Unknown&#xff09; Init Containers Init Cont…

pc端引擎颠覆电脑兼容性

张小龙曾在讲座上阐述小程序理念的精髓&#xff0c;小程序承载着张小龙及微信团队对未来程序形态的一种见解&#xff0c;总结为五个字&#xff1a;所见即所得。原文如下&#xff1a; 它是一种真正的所见即所得的形态&#xff0c;我说的所见即所得不同于在PC时代&#xff0c;我…

组合模式+桥接模式

目录 组合模式 定义&#xff1a; 业务实现例子&#xff1a; 桥接模式 JDBC中的桥接模式 组合模式 定义&#xff1a; 将对象组合通过树形结构进行展示&#xff0c;使得用户——>不管对单个对象or组合对象的使用具有一致性 可以理解为部分-整体模式——>简单来说就…

深度学习环境搭建

(1) 安装 Anaconda :建立 Python 应用环境 安装成功界面如下:(2) Visual Studio Code: 建立代码编辑环境 1.安装Python扩展2.选择合适的Python解释器 3.安装下列应用扩展:codeRunner : 快速运行程序 Jupyter : 交互式运行程序 Pylance : 高效代码提示 安装完成如图所示:4.创…

Linux基础组件之muduo日志库分析

muduo日志库分析异步日志机制双缓存机制前台日志写入栈后台日志(落盘)写入栈使用示例总结后言异步日志机制 #mermaid-svg-nrIugWYiOaAGFTWH {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-nrIugWYiOaAGFTWH .error-…

如何做架构规划

文章目录架构师的职责WhyWhatHow架构活动生命周期环境搭建目标确认可行性探索架构规划统一语义需求确认任务边界划分确认规划完整性项目启动阶段性价值交付复盘经历过的典型案例参考架构师的职责 Why 互联网架构活动的挑战较多&#xff0c;如&#xff1a; 反射式的研发行为。…

Scratch软件编程等级考试四级——20200913

Scratch软件编程等级考试四级——20200913理论单选题判断题实操奇偶之和创意画图数字之和用逗号分隔列表数字反转理论 单选题 1、执行下面程序&#xff0c;输入4和7后&#xff0c;角色说出的内容是&#xff1f;&#xff08;&#xff09; A、4&#xff0c;7 B、7,7 C、7,4 D、…

为什么会发生云中断?如何防范?

IT 越依赖云服务&#xff0c;用户就越有可能因云中断而遭受停机和收入损失。由于云中断事件的发生&#xff0c;超过 60% 的使用公共云的组织在 2022 年报告了损失&#xff0c;因此云中断并不是公司不太可能面临的异常事件。 但是中断是否足以成为永远离开云的理由?还是应该坚持…

《安富莱嵌入式周报》第286期:8bit浮点数规范,VxWorks火星探测器故障原因修复,Matter V1.0智能家居规范,Wireshark 4.0发布

往期周报汇总地址&#xff1a;嵌入式周报 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬汉嵌入式论坛 - Powered by Discuz! 目录 视频版&#xff1a; 1、SIA全球半导体行业协会统计显示全球芯片市场增长放缓&#xff0c;中国市场下跌10% …

程序员如何高效准备简历和面试03:诊断:简历为什么被忽视?

你好&#xff0c;欢迎学习课时3&#xff0c;我是你的职场导师吴文娟。 这节课主要为后面教你写简历做个铺垫&#xff0c;学习内容只有2个字&#xff1a;挑错。一个大家比较喜欢的事。我们来敲黑板看一些反面典型&#xff0c;案例都是我截取之前诊断过的简历&#xff0c;讲一讲为…

Mac电脑图片后期处理Lightroom Classic 2022(lrc2022)

Lightroom Classic 2022具有非常强大的图像处理功能&#xff0c;甚至对照片的一些修饰也可以完成&#xff0c;例如去除不要的物体、校正照片和增强照片颜色等。Lightroom Classic 2022 Mac版为用户提供了各种满足优秀摄影效果所需的编辑工具。让您能够轻松提亮颜色、使灰暗的摄…

C++ Builder XE TChart动态添加N个线条TLineSeries变化

// LARGE_INTEGER litmp; LONGLONG QPart1,QPart2; double dfMinus, dfFreq, dfTim; QueryPerformanceFrequency(&litmp); dfFreq (double)litmp.QuadPart;// 获得计数器的时钟频率 QueryPerformanceCounter(&litmp)…

STM32:外部中断控制旋转编码器并计次

1.主函数(main.c)代码部分&#xff1a; #include "stm32f10x.h" // Device header #include "Delay.h" #include "OLED.h" #include "Encoder.h" int16_t Num; int main(void) { OLED_Init(); OLED_Sh…

第十四届蓝桥杯备赛模板题——蓝桥部队 (带权并查集)

目录1.蓝桥部队1. 问题描述2.输入格式3.输入样例4.样例答案5.原题连接2.解题思路3.Ac_code1.蓝桥部队 1. 问题描述 小明是蓝桥部队的长官&#xff0c;他的班上有 NNN 名军人和 111 名军师。 这天&#xff0c;NNN 名军人在操场上站成一排&#xff0c;起初编号为 iii 的军人站…

JPA EntityManager 获取关联对象

今天尝试了几种方式&#xff0c;来获取关联对象。 关联对象&#xff0c;使用的 OneToMany(fetchFetchType.EAGER) 下面给一下总结&#xff1a; 一 Example 毫无疑问&#xff0c;很有信心&#xff0c;Example可以关联到对象。 事实也是这样。 但是Example好像只有and关系…

公众号网课题库系统-轻易获取查题接口

公众号网课题库系统-轻易获取查题接口 本平台优点&#xff1a; 多题库查题、独立后台、响应速度快、全网平台可查、功能最全&#xff01; 1.想要给自己的公众号获得查题接口&#xff0c;只需要两步&#xff01; 2.题库&#xff1a; 题库&#xff1a;题库后台&#xff08;点击…

Mindquantum实现变分量子奇异值分解

论文题目&#xff1a;Variational Quantum Singular Value Deposition(VQSVD) 项目介绍 复现过程 案例1&#xff1a;分解随机生成的8*8复数矩阵 先引入需要使用的包&#xff1a; import os os.environ[OMP_NUM_THREADS] 1​ import mindspore as ms from mindquantum impo…