【uniapp】uni-app开发手持PDA上的激光扫码程序,uniapp主动触发pda激光扫码(附完整代码)

本文主要是介绍【uniapp】uni-app开发手持PDA上的激光扫码程序,uniapp主动触发pda激光扫码(附完整代码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 项目需求

我们项目采购了Seuic东集CRUISE Ge-X3 工业级智能手机(PDA),PDA设备是Android9系统,带有激光扫码灯,现在要使用uniapp开发安卓程序,并实现在PDA设备上的激光扫码程序。

2. 前置条件

  1. 确保扫描工具已经正常启动,并在扫描工具中的设置-开发者选项中-获取指定的广播名称、键值名称等数据
    在这里插入图片描述
    在这里插入图片描述

  2. pda特色设置中关闭《禁止将扫描按键的键值传递给应用》的选项

在这里插入图片描述

3. 代码实现

激光扫码是硬解的方案,扫码的速度远高于需要唤醒过程的摄像头扫码方式,激光扫码几乎可以实时返回结果。不过其依赖Android 8以上的版本才可以通过广播的方式被应用监听,因此在开发的过程中会造成一些阻碍。无论是原生的Android开发方式,还是像uni-app的跨平台解决方案,都需要在激光扫描模块获取到结果后向系统发出一条广播,接着可以通过应用监听广播的方式来获取扫码结果。

下面是扫码的scanCode.js文件内容:

// pda的特色设置中需要关闭-禁止将扫描按键的键值传递给应用的开关
let mainActivity; // 运行时的主要活动activity
let intentFilter; // 实例化的意图过滤器
let broadcastReceiver; // 广播接收器
let repeatFlag = false;// 初始化定义广播
const init = (onReceiveCallback) => {/* #ifdef APP-PLUS */// 获取activitymainActivity = plus.android.runtimeMainActivity();// 导入类const IntentFilter = plus.android.importClass('android.content.IntentFilter');//实例化一个意图过滤器intentFilter = new IntentFilter();// addAction添加动作, com.android.server.scannerservice.broadcast为设备配置的广播名称intentFilter.addAction("com.android.server.scannerservice.broadcast");// BroadcastReceiver广播接收器接口:implements 实现接口  onReceive实现接口的方法broadcastReceiver = plus.android.implements('io.dcloud.feature.internal.reflect.BroadcastReceiver', {onReceive: function(context, intent) {plus.android.importClass(intent);// 扫描设置的开发者选项--手持机pda的广播键值scannerdataconst code = intent.getStringExtra("scannerdata");console.log('pda原始扫描数据:', code);//防重复if (repeatFlag) return;repeatFlag = true;setTimeout(function() {repeatFlag = false;}, 150);// 到这里扫描成功,获取结果,可以调用自己的业务逻辑onReceiveCallback && onReceiveCallback(code);}});/* #endif */
}// 开始广播监听扫码
const start = () => {/* #ifdef APP-PLUS */mainActivity.registerReceiver(broadcastReceiver, intentFilter);/* #endif */
}// 停止广播监听扫码
const stop = () => {/* #ifdef APP-PLUS */mainActivity.unregisterReceiver(broadcastReceiver);/* #endif */
}// 主动触发扫描
const triggerScan = () => {// 获取Android意图类let Intent = plus.android.importClass("android.content.Intent");// 实例化意图  let intent = new Intent();// 定义意图,由厂商提供(此处设置为东大的:开始扫描广播com.scan.onStartScan,对应的停止扫描广播为com.scan.onEndScan)intent.setAction("com.scan.onStartScan");// 广播这个意图mainActivity.sendBroadcast(intent);
}export const broadcastScan = {init,start,stop,triggerScan,
};// 引入使用
// 	import { broadcastScan } from './scanCode.js';

下面是uniapp页面中vue内容:

<template><view class="home-container"><view class="intro">广播名称:com.android.server.scannerservice.broadcast</view><view class="intro">广播键值:scannerdata</view><view class="intro">主动开始扫描广播:com.scan.onStartScan</view><view class="intro">主动结束扫描广播:com.scan.onEndScan</view><text class="intro">详见:</text><view class="href"><uni-link :href="href" text="Seuic东集-CRUISE Ge 工业级智能产品说明pdf"></uni-link></view><br /><view style="bth-list"><u-button type="primary" text="开始扫码" @click="openScan"></u-button></view><view class="result-container"><u--textarea v-model="result" autoHeight height='200'></u--textarea></view></view>
</template><script>import scanCode from '@/components/scanCode/scanCode.vue'; // 扫码接收import { broadcastScan } from '@/utils/scanCode.js';export default {data() {return {href: 'https://code.dt-insight.com/pdf?url=https://obs-dj-gym.obs.cn-east-3.myhuaweicloud.com/pdf/202205/1529643516374945792.pdf',result: '',}},methods: {// 自定义扫描的结果回调函数getScanCode(code) {let parseData = code.trim();console.log('自定义扫描的结果回调函数:', parseData);this.result = parseData;},// 主动触发扫描openScan() {broadcastScan.triggerScan();},},// onLoad 是在页面加载时触发,用于页面的初始化操作,只执行一次onLoad() {// init传入一个回调函数做参数,在扫描时候会将数据传入此方法里,然后处理此方法的自定义业务逻辑broadcastScan.init(this.getScanCode);},onUnload() {broadcastScan.stop();},// 在页面展示时触发,用于处理页面显示相关的逻辑,可能会多次执行,包括页面首次展示和从后台切换到前台时onShow() {broadcastScan.start();},onHide() {broadcastScan.stop();},}
</script><style lang="scss">.home-container {padding: 20px;font-size: 14px;line-height: 24px;.bth-list {display: flex;flex-direction: row;}.result-container {margin-top: 10rpx;border: 1px solid $u-primary;}}
</style>

4. 实现效果

激光扫码效果见如下视频

pda扫码效果

https://blog.csdn.net/ZhouLoverBrother/article/details/111169771
https://ask.dcloud.net.cn/article/40134

这篇关于【uniapp】uni-app开发手持PDA上的激光扫码程序,uniapp主动触发pda激光扫码(附完整代码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/789276

相关文章

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Java实现自定义table宽高的示例代码

《Java实现自定义table宽高的示例代码》在桌面应用、管理系统乃至报表工具中,表格(JTable)作为最常用的数据展示组件,不仅承载对数据的增删改查,还需要配合布局与视觉需求,而JavaSwing... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Go语言代码格式化的技巧分享

《Go语言代码格式化的技巧分享》在Go语言的开发过程中,代码格式化是一个看似细微却至关重要的环节,良好的代码格式化不仅能提升代码的可读性,还能促进团队协作,减少因代码风格差异引发的问题,Go在代码格式... 目录一、Go 语言代码格式化的重要性二、Go 语言代码格式化工具:gofmt 与 go fmt(一)

SpringBoot集成LiteFlow工作流引擎的完整指南

《SpringBoot集成LiteFlow工作流引擎的完整指南》LiteFlow作为一款国产轻量级规则引擎/流程引擎,以其零学习成本、高可扩展性和极致性能成为微服务架构下的理想选择,本文将详细讲解Sp... 目录一、LiteFlow核心优势二、SpringBoot集成实战三、高级特性应用1. 异步并行执行2