【项目管理】微信小程序使用Beacon设备实现签到功能

news/2024/10/18 2:40:58/

【项目管理】微信小程序使用Beacon设备实现签到功能

  • 1.项目介绍
  • 2.流程设计
  • 3.原型设计
  • 4.关键代码
  • 5.开源地址

在这里插入图片描述 在这里插入图片描述

WeChatDevTools : WeChatDevTools Stable 1.06.2303220

WeChat : 8.0.35

调试基础库 : 2.32.0

1.项目介绍

iCheckIn 为微信小程序项目,通过调用手机蓝牙功能搜索 Beacon 设备,实现课程签到的功能,该项目我只完成了微信小程序端的实现,流程设计和原型设计都是参考我们小组组长给的样例,重新设计的。这里是他的GitHub主页链接,有兴趣大家可以去点下关注

2.流程设计

在这里插入图片描述

3.原型设计

墨刀原型设计链接

下面是原型设计截图
在这里插入图片描述

4.关键代码

这里使用 wx.startBeaconDiscovery 方法查找附近的 Beacon 设备,uuids 为筛选列表,我们只需要查询对应这些 uuid 的 Beacon 设备,查找成功后我们就可以调用该 Beacon 设备信息进行签到处理了

  //开始寻找信标设备startFindDevices: function () {let that = this;timer = setTimeout(function () {that.stopFindDevices('false', "搜索设备超时")}, 10000) //搜索超时 停止扫描设备wx.startBeaconDiscovery({//设置ibeacons的参数//000FFFF-0000-1000-8000-00805F9B34FB,这是一个通用的 UUID,可以用于扫描大多数 Beacon 设备uuids: ['0000FFFF-0000-1000-8000-00805F9B34FB', 'FDA50693-A4E2-4FB1-AFCF-C6EB07647801', 'FDA50693-A4E2-4FB1-AFCF-C6EB07647802', 'FDA50693-A4E2-4FB1-AFCF-C6EB07647803', 'FDA50693-A4E2-4FB1-AFCF-C6EB07647804', 'FDA50693-A4E2-4FB1-AFCF-C6EB07647805', 'FDA50693-A4E2-4FB1-AFCF-C6EB07647806'],//连接成功success: function () {that.doSignIn();},fail: function (res) {console.log(res);if(res.errCode == '11003'){that.doSignIn();//如果已经打开了扫描设备,则直接进行签到} else {that.stopFindDevices('false', res.errMsg); //停止扫描设备,返回结果}},})},

这里通过将查到的 Beacon 设备的 UUID 和用户的学号,传到后台进行签到处理

//进行签到doSignIn: function () {let that = this;//监听iBeacon设备的更新事件wx.onBeaconUpdate(function (res) {wx.getBeacons({success: (result) => {if (res.beacons) {let count = res.beacons.length;if (count >= 1) { //显示正在签到clearTimeout(timer); //扫描信标成功后,清除定时器if (!hasSignIn) { //如果没有签到,则进行签到hasSignIn = true; //标识已签到that.setData({promptInfo: '正在签到......'});let selectIndex = 0;for (let i = 0; i < count; i++) {if (Math.abs(res.beacons[i].RSSI) < Math.abs(res.beacons[selectIndex].RSSI)) {selectIndex = i; //如果RSSI绝对值更小,取更小的这个beacon}}let ibeacon1 = res.beacons[selectIndex]let uuid = ibeacon1.uuid; //uuidlet rssi = Math.abs(ibeacon1.rssi); //rssilet stu_name = wx.getStorageSync('stu_name'); //姓名let stu_number = wx.getStorageSync('stu_number'); //学号let postHeader = {'content-type': 'application/json',};let postData = {"studentNo": stu_number,"studentName": stu_name,"beacons": [{"beaconName": uuid,"rssi": rssi}]};let result = '';let message = '';wx.request({url: 'https://sjtu.yangzezhi.com/api/checkin',header: postHeader,method: 'POST',data: JSON.stringify(postData),success(res) {if (res.data.success) {result = res.data.success;message = res.data.data.classroom;} else {if (res.data.message) {result = res.success;message = res.data.message;} else {result = false;message = res.data.status + " " + res.data.error;}}},fail(res) {result = false;message = res.errMsg;},complete() {that.stopFindDevices(result, message);}})}}}},})})},

5.开源地址

Gitee:https://gitee.com/lijinjiang01/iCheckIn
Github:https://github.com/lijinjiang01/iCheckIn


http://www.ppmy.cn/news/299357.html

相关文章

【C++】C++的类型转换

文章目录 1、C语言中的类型转换2、为什么C需要四种类型转换3、C强制类型转换&#xff08;重点&#xff09;3-1、static_cast3-2、reinterpret_cast3-3、const_cast3-4、dynamic_cast 4、RTTI&#xff08;了解&#xff09;5、常见面试题6、总结 1、C语言中的类型转换 在C语言中&…

怎样用计算机打出Abc,快捷安装ABC输入法在win7电脑中的方法

电脑中自带的输入就是英文的输入法的&#xff0c;一般都是需要打开不同的方式类似实现我们电脑中的问题的&#xff0c;有win7电脑中安装了其他的输入法的ABC输入法的&#xff0c;打开系统中的设置不同的问题&#xff0c;对于奥了的问题需要安装的不知道步骤的今天小编就来跟大家…

N年前的笔记-智能ABC输入法

翻翻原来的笔记感慨万千啊&#xff0c;记过很多幼稚的操作系统小技巧&#xff0c;就为了跟同学显摆&#xff0c;哈哈哈哈 在智能ABC输入法的状态下依次输入V、向上的方向键、Delete、空格&#xff0c;接着就会连同你的编辑软件一起崩溃。

java小应用程序没有输入法_java swing的编辑框如果用智能ABC输入法输入中文会整个应用程序崩掉 | 学步园...

java swing的编辑框如果用智能ABC输入法输入中文会整个应用程序崩掉 然后后台出现&#xff1a; # An unexpected error has been detected by Java Runtime Environment: # # EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc0x76303e44, pid240, tid2056 # # Java VM: Java Ho…

特瑞仕 | 常见传感器基础知识归纳

​传感器是将物理量转换为电信号的装置&#xff0c;广泛应用于各种领域&#xff0c;如物联网、工业自动化、医疗健康等。传感器技术的发展和应用越来越广泛&#xff0c;其基础知识也日益重要。本文将介绍常见传感器的基础知识&#xff0c;包括传感器的种类、工作原理、应用领域…

Phonetic是智能ABC输入法在系统中的进程

原来Phonetic是智能ABC输入法在系统中的进程&#xff0c;该进程捆绑在EXPlorer.exe中。如果设置了智能ABC为默认输入法&#xff0c;那么电脑启动时就会加载它的进程&#xff0c;随着频繁使用智能ABC而导致该进程文件Phonetic变多。还有就是因为智能ABC自身存在的BUG&#xff0c…

小学计算机打字基础知识教案绿色圃,小学信息技术公开课教案智能ABC输入法教学设计与反思...

一、教学内容分析 本节课是在学生已经学会了“智能ABC输入法”和在“写字板中输入文字”的基础上&#xff0c;继续学习使用“智能ABC输入法”快捷输入词语以及特殊词语、保存“写字板”里的内容的方法。 通过本节课的学习&#xff0c;不仅能加强学生输入文字操作技能的训练&…

用计算机写作文主题,用计算机写作文》——学习智能ABC输入法

《用计算机写作文》——学习智能ABC输入法 一、课程标准中的相关内容 (1)从生活实际中选择问题&#xff0c;提高学习兴趣。 (2)在已学习知识的基础上&#xff0c;通过教师指导以及自主学习&#xff0c;掌握智能ABC输入法的要领。 二、教学目标 1、知识与技能&#xff1a; (1)掌…