当前位置: 首页 > news >正文

【uniapp蓝牙】基于native.js链接ble和非ble蓝牙

【uniapp蓝牙】基于native.js链接ble和非ble蓝牙

uniapp不是仅支持低功耗蓝牙(基础蓝牙通讯不支持),有些可能需要基础蓝牙。我现在同步我的手机蓝牙列表低功耗,基础蓝牙都支持

/*** @author wzj* 通用蓝牙模块封装* 搜索 ble 和非 ble 蓝牙设备*/
class Ble {constructor() {// false 蓝牙关闭, true 蓝牙打开this.bluetooth = falsethis.systemPlatform = uni.$uv.os()this.context = plus.android.importClass('android.content.Context')this.locationManager = plus.android.importClass('android.location.LocationManager')this.main = plus.android.runtimeMainActivity()this.mainSvr = this.main.getSystemService(this.context.LOCATION_SERVICE)this.Intent = plus.android.importClass('android.content.Intent')this.Settings = plus.android.importClass('android.provider.Settings')this.IntentFilter = plus.android.importClass('android.content.IntentFilter')this.BluetoothAdapter = plus.android.importClass('android.bluetooth.BluetoothAdapter')this.BluetoothDevice = plus.android.importClass('android.bluetooth.BluetoothDevice')this.UUID = plus.android.importClass('java.util.UUID')// 未配对蓝牙设备列表this.unpairedList = []// 已配对蓝牙设备列表this.pairedList = []}// 监听蓝牙状态改变listenerConnection() {plus.bluetooth.onBLEConnectionStateChange(function (e) {console.log('connection state changed: ' + JSON.stringify(e))})}// 提示框showToast(title, options = {}) {uni.showToast({title,...options})}// 初始化蓝牙模块openBluetoothAdapter() {this.getBluetoothState()if (!this.bluetooth) {this.showToast('请先打开蓝牙!', {icon: 'error',duration: 2000})return false}if (this.systemPlatform !== 'android') {this.showToast('蓝牙功能只支持Android系统!', {icon: 'error',duration: 2000})return false}// 定位检测this.checkLocation()}// gps是否开启isProviderEnabled() {return this.mainSvr.isProviderEnabled(this.locationManager.GPS_PROVIDER)}// 建立连接createBLEConnection(mac_address) {const that = thisvar BAdapter = this.BluetoothAdapter.getDefaultAdapter()let device = BAdapter.getRemoteDevice(mac_address)plus.android.importClass(device)let bdevice = new this.BluetoothDevice()// 判断是否配对const getBondState = device.getBondState() === bdevice.BOND_NONEif (!getBondState) {console.log('已配对蓝牙设备')return true}// 参数如果跟取得的mac地址一样就配对const addressSame = device.getAddress() === mac_addressif (!addressSame) return false// 配对命令const createBond = device.createBond()if (!createBond) return falselet cha = setInterval(() => {if (device.getBondState() === bdevice.BOND_BONDED) {clearInterval(cha)// 删除未配对蓝牙,添加到已配对that.unpairedList.map((item, i) => {if (item.address === mac_address) {that.pairedList.push(item)that.unpairedList.splice(i, 1)}})}}, 1000)}// 执行蓝牙打印blueToothPrint(mac_address, dataToSend) {if (!mac_address) {this.showToast('请选择蓝牙打印机', {icon: 'error',})return false}let uuid = this.UUID.fromString('00001101-0000-1000-8000-00805f9b34fb')let BAdapter = this.BluetoothAdapter.getDefaultAdapter()let device = BAdapter.getRemoteDevice(mac_address)plus.android.importClass(device)let bluetoothSocket = device.createInsecureRfcommSocketToServiceRecord(uuid)plus.android.importClass(bluetoothSocket)if (bluetoothSocket.isConnected()) {let outputStream = bluetoothSocket.getOutputStream()plus.android.importClass(outputStream)let bytes = plus.android.invoke(dataToSend, 'getBytes', 'gbk')console.log('发送数据完成', bytes)outputStream.write(bytes)outputStream.flush()// 这里关键device = null// 必须关闭蓝牙连接否则意外断开的话打印错误bluetoothSocket.close()} else {console.log('检测到设备未连接,尝试连接....')bluetoothSocket.connect()}}// 定位检测checkLocation() {const GPS_PROVIDER = this.isProviderEnabled()if (GPS_PROVIDER) {this.searchDevices()return true}uni.showModal({title: "提示",content: "请打开定位服务功能",showCancel: false, // 不显示取消按钮success() {if (GPS_PROVIDER) {this.showToast('GPS功能已开启!', {icon: 'success',})return true}const intent = new this.Intent(this.Settings.ACTION_LOCATION_SOURCE_SETTINGS)// 打开系统设置GPS服务页面this.main.startActivity(intent)}})return false}// 开始搜寻附近的蓝牙外围设备startBluetoothDevicesDiscovery() {const that = thislet main = this.mainlet BluetoothAdapter = this.BluetoothAdapteruni.startBluetoothDevicesDiscovery({success: (res) => {let BAdapter = BluetoothAdapter.getDefaultAdapter()const isEnabled = BAdapter !== null && !BAdapter.isEnabled()if (isEnabled) {const intent = new this.Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE)main.startActivityForResult(intent, 200)}uni.showLoading({title: "开始搜索设备",})let filter = new this.IntentFilter()let bdevice = new this.BluetoothDevice()let BluetoothDevice = this.BluetoothDevice// 开启搜索BAdapter.startDiscovery()// 获取配得和未配对蓝牙回调let receiver = plus.android.implements('io.dcloud.android.content.BroadcastReceiver', {//实现onReceiver回调函数onReceive: function (context, intent) {// 通过 intent 实例引入 intent 类,方便以后的‘.’操作plus.android.importClass(intent)let BleDevice = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE)// 获取已经配对的蓝牙设备const getBondState = BleDevice.getBondState() !== bdevice.BOND_NONEif (getBondState) {// 已配对蓝牙设备const addressLen = that.unpairedList.filter(item => item.address === BleDevice.getAddress())if (addressLen.length > 0) returnthat.unpairedList.push({name: BleDevice.getName(),address: BleDevice.getAddress(),})}const action = intent.getAction() === "android.bluetooth.adapter.action.DISCOVERY_FINISHED"if (action) {// 取消监听main.unregisterReceiver(receiver)uni.hideLoading()return false}const isBondState = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE).getBondState() === 10if (isBondState) {const name = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE).getName()const address = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE).getAddress()var y = 0const unpairedListLength = that.unpairedList.lengthfor (let x = 0; x < unpairedListLength; x++) {let isAddress = that.unpairedList[x].address === addressif (isAddress) {y++}}if (y > 0) {return y = 0}if (!name) {return}that.unpairedList.push({name,address,})}}})filter.addAction(bdevice.ACTION_FOUND)filter.addAction(BAdapter.ACTION_DISCOVERY_STARTED)filter.addAction(BAdapter.ACTION_DISCOVERY_FINISHED)filter.addAction(BAdapter.ACTION_STATE_CHANGED)main.registerReceiver(receiver, filter)},fail: (res) => {console.log('startBluetoothDevicesDiscovery fail', res)},})}// 搜索蓝牙设备searchDevices() {this.openBluetooth(() => {if (!this.bluetooth) {return false}this.startBluetoothDevicesDiscovery()})}// 打开蓝牙模块openBluetooth(callBack) {const that = thisuni.openBluetoothAdapter({success(res) {uni.getBluetoothAdapterState({success(res) {that.bluetooth = res.availablecallBack && callBack()}})},fail(res) {console.log('openBluetoothAdapter fail', res)}})}// 获取蓝牙状态getBluetoothState() {/* 判断是否打开蓝牙 */this.openBluetooth()}
}export default Ble

相关文章:

【uniapp蓝牙】基于native.js链接ble和非ble蓝牙

【uniapp蓝牙】基于native.js链接ble和非ble蓝牙 uniapp不是仅支持低功耗蓝牙&#xff08;基础蓝牙通讯不支持&#xff09;&#xff0c;有些可能需要基础蓝牙。我现在同步我的手机蓝牙列表低功耗&#xff0c;基础蓝牙都支持 /*** author wzj* 通用蓝牙模块封装* 搜索 ble 和非…...

.NET Core 各版本特点、差异及适用场景详解

随着 .NET Core 的不断发展&#xff0c;微软推出了一系列版本来满足不同场景下的开发需求。这些版本随着时间的推移逐渐演变为统一的 .NET 平台&#xff08;从 .NET 5 开始&#xff09;。本文将详细说明每个版本的特点、差异以及适用场景&#xff0c;帮助开发者更好地选择和使用…...

Linux中自动检测并定时关闭KDialog程序

自动检测并关闭对话框的程序示例 创建并打开KDialog的脚本自动检测并定时关闭KDialog的脚本 创建并打开KDialog的脚本 #!/bin/bash kdialog --msgbox "demo"自动检测并定时关闭KDialog的脚本 #!/bin/bash# Continuously check for kdialog dialog while true; do# …...

CSS学习记录12

CSS浮动 CSSfloat属性规定元素如何浮动 CSSclear属性规定哪些元素可以在清除的元素旁边以及在哪一侧浮动。 float属性 float属性用于定位和格式化内容&#xff0c;例如让图像向左浮动到容器的文本那里。 float属性可以设置以下值之一&#xff1a; left - 元素浮动到其容器…...

【Java基础面试题016】JavaObject类中有什么主要方法,作用是什么?

equals() 作用&#xff1a;用于比较两个对象是否相等。默认实现比较对象的内存地址&#xff0c;即判断两个引用是否指向同一个对象 使用&#xff1a;通常会重写此方法来比较对象的内容 hashCode() 作用&#xff1a;返回对象的哈希值&#xff0c;用整数表示对象。 使用&…...

实践环境-docker安装mysql8.0.40步骤

一、docker安装mysql 8.0.40版本 1、检索镜像版本 docker search mysql:8.0.40 NAME DESCRIPTION STARS OFFICIAL mysql MySQL is a widely used, open-source relation… …...

边缘智能创新应用大赛获奖作品系列一:智能边缘计算✖软硬件一体化,开启全场景效能革命新征程

边缘智能技术快速迭代&#xff0c;并与行业深度融合。它正重塑产业格局&#xff0c;催生新产品、新体验&#xff0c;带动终端需求增长。为促进边缘智能技术的进步与发展&#xff0c;拓展开发者的思路与能力&#xff0c;挖掘边缘智能应用的创新与潜能&#xff0c;高通技术公司联…...

决策树的生成与剪枝

决策树的生成与剪枝 决策树的生成生成决策树的过程决策树的生成算法 决策树的剪枝决策树的损失函数决策树的剪枝算法 代码 决策树的生成 生成决策树的过程 为了方便分析描述&#xff0c;我们对上节课中的训练样本进行编号&#xff0c;每个样本加一个ID值&#xff0c;如图所示…...

蓝桥杯算法训练 黑色星期五

题目描述 有些西方人比较迷信&#xff0c;如果某个月的13号正好是星期五&#xff0c;他们就会觉得不太吉利&#xff0c;用古人的说法&#xff0c;就是“诸事不宜”。请你编写一个程序&#xff0c;统计出在某个特定的年份中&#xff0c;出现了多少次既是13号又是星期五的情形&am…...

MySQL存储引擎-存储结构

Innodb存储结构 Buffer Pool(缓冲池)&#xff1a;BP以Page页为单位&#xff0c;页默认大小16K&#xff0c;BP的底层采用链表数据结构管理Page。在InnoDB访问表记录和索引时会在Page页中缓存&#xff0c;以后使用可以减少磁盘IO操作&#xff0c;提升效率。 ○ Page根据状态可以分…...

理解torch函数bmm

基本信息 功能描述 torch.bmm 是 PyTorch 中的一个函数&#xff0c;用于执行批量矩阵乘法&#xff08;Batch Matrix Multiplication&#xff09;。它适用于处理一批矩阵的乘法操作&#xff0c;特别适合于深度学习任务中的场景&#xff0c;比如卷积神经网络中的某些层。 参数…...

2024 年的科技趋势

2024 年在科技领域有着诸多重大进展与突破。从人工智能、量子计算到基因组医学、可再生能源以及新兴技术重塑了众多行业。随着元宇宙等趋势的兴起以及太空探索取得的进步&#xff0c;未来在接下来的岁月里有望继续取得进展与突破。让我们来探讨一下定义 2024 年的一些关键趋势&…...

win服务器的架设、windows server 2012 R2 系统的下载与安装使用

文章目录 windows server 2012 R2 系统的下载与安装使用1 windows server 2012 的下载2 打开 VMware 虚拟机软件&#xff08;1&#xff09;新建虚拟机&#xff08;2&#xff09;设置虚拟机&#xff08;3&#xff09;打开虚拟机 windows server 2012&#xff08;4&#xff09;进…...

leetcode45.跳跃游戏II

标签&#xff1a;动态规划 给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说&#xff0c;如果你在 nums[i] 处&#xff0c;你可以跳转到任意 nums[i j] 处:返回到达 nums[n - 1] 的最小跳跃次数。…...

边缘智能创新应用大赛获奖作品系列三:边缘智能强力驱动,机器人天团花式整活赋能千行百业

边缘智能技术快速迭代&#xff0c;并与行业深度融合。它正重塑产业格局&#xff0c;催生新产品、新体验&#xff0c;带动终端需求增长。为促进边缘智能技术的进步与发展&#xff0c;拓展开发者的思路与能力&#xff0c;挖掘边缘智能应用的创新与潜能&#xff0c;高通技术公司联…...

基于语义的NLP任务去重:大语言模型应用与实践

引言 在自然语言处理&#xff08;NLP&#xff09;任务中&#xff0c;数据质量是模型性能的关键因素之一。重复或冗余的数据会导致模型过度拟合或浪费计算资源&#xff0c;特别是在大语言模型&#xff08;如 BERT、GPT 系列等&#xff09;训练和推理阶段。传统的基于字符匹配的…...

使用阿里云Certbot-DNS-Aliyun插件自动获取并更新免费SSL泛域名(通配符)证书

进入nginx docker&#xff0c;一般是Alpine Linux系统 1. 依次执行命令: sudo docker-compose exec nginx bashapk updateapk add certbot apk add --no-cache python3 python3-dev build-baseapk add python3 py3-pippip3 install --upgrade pippip3 install certbot-dns-ali…...

Node.js安装配置+Vue环境配置+创建一个VUE项目

目录 安装Node.js搭建VUE环境 安装Node.js 下载 测试是否安装成功 在目录下新建两个文件夹 管理员打开cmd npm config set prefix "D:\Software\nodejs\node_global" npm config set cache "D:\Software\nodejs\node_cache"将默认的 C 盘下【 AppData\…...

“TA”说|表数据备份还原:SQLark 百灵连接助力项目部署验收

&#x1f4ac; 南飞雁&#xff5c;应用开发工程师 有些重要项目的部署验收&#xff0c;会在生产环境完成&#xff0c;验收完成后&#xff0c;又需要把这部分数据清空。这时就需要对数据表进行备份和还原&#xff0c;虽然可以通过命令直接实现&#xff0c;但是有一些操作门槛&am…...

【FFmpeg】解封装 ① ( 封装与解封装流程 | 解封装函数简介 | 查找码流标号和码流参数信息 | 使用 MediaInfo 分析视频文件 )

文章目录 一、解封装1、封装与解封装流程2、解封装 常用函数 二、解封装函数简介1、avformat_alloc_context 函数2、avformat_free_context 函数3、avformat_open_input 函数4、avformat_close_input 函数5、avformat_find_stream_info 函数6、av_read_frame 函数7、avformat_s…...

css实现圆环展示百分比,根据值动态展示所占比例

代码如下 <view class""><view class"circle-chart"><view v-if"!!num" class"pie-item" :style"{background: conic-gradient(var(--one-color) 0%,#E9E6F1 ${num}%),}"></view><view v-else …...

基于ASP.NET+ SQL Server实现(Web)医院信息管理系统

医院信息管理系统 1. 课程设计内容 在 visual studio 2017 平台上&#xff0c;开发一个“医院信息管理系统”Web 程序。 2. 课程设计目的 综合运用 c#.net 知识&#xff0c;在 vs 2017 平台上&#xff0c;进行 ASP.NET 应用程序和简易网站的开发&#xff1b;初步熟悉开发一…...

新能源汽车智慧充电桩管理方案:新能源充电桩散热问题及消防安全监管方案

随着新能源汽车的快速普及&#xff0c;充电桩作为核心配套设施&#xff0c;其安全性与可靠性备受关注。然而&#xff0c;在高温、高负荷运行环境下&#xff0c;充电桩的散热问题与消防安全隐患日益凸显&#xff0c;成为制约行业发展的关键瓶颈。 如何通过智慧化管理手段优化散…...

微信小程序云开发平台MySQL的连接方式

注&#xff1a;微信小程序云开发平台指的是腾讯云开发 先给结论&#xff1a;微信小程序云开发平台的MySQL&#xff0c;无法通过获取数据库连接信息的方式进行连接&#xff0c;连接只能通过云开发的SDK连接&#xff0c;具体要参考官方文档&#xff1a; 为什么&#xff1f; 因为…...

什么是Ansible Jinja2

理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具&#xff0c;可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板&#xff0c;允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板&#xff0c;并通…...

SiFli 52把Imagie图片,Font字体资源放在指定位置,编译成指定img.bin和font.bin的问题

分区配置 (ptab.json) img 属性介绍&#xff1a; img 属性指定分区存放的 image 名称&#xff0c;指定的 image 名称必须是当前工程生成的 binary 。 如果 binary 有多个文件&#xff0c;则以 proj_name:binary_name 格式指定文件名&#xff0c; proj_name 为工程 名&…...

在QWebEngineView上实现鼠标、触摸等事件捕获的解决方案

这个问题我看其他博主也写了&#xff0c;要么要会员、要么写的乱七八糟。这里我整理一下&#xff0c;把问题说清楚并且给出代码&#xff0c;拿去用就行&#xff0c;照着葫芦画瓢。 问题 在继承QWebEngineView后&#xff0c;重写mousePressEvent或event函数无法捕获鼠标按下事…...

20个超级好用的 CSS 动画库

分享 20 个最佳 CSS 动画库。 它们中的大多数将生成纯 CSS 代码&#xff0c;而不需要任何外部库。 1.Animate.css 一个开箱即用型的跨浏览器动画库&#xff0c;可供你在项目中使用。 2.Magic Animations CSS3 一组简单的动画&#xff0c;可以包含在你的网页或应用项目中。 3.An…...

C/C++ 中附加包含目录、附加库目录与附加依赖项详解

在 C/C 编程的编译和链接过程中&#xff0c;附加包含目录、附加库目录和附加依赖项是三个至关重要的设置&#xff0c;它们相互配合&#xff0c;确保程序能够正确引用外部资源并顺利构建。虽然在学习过程中&#xff0c;这些概念容易让人混淆&#xff0c;但深入理解它们的作用和联…...

从“安全密码”到测试体系:Gitee Test 赋能关键领域软件质量保障

关键领域软件测试的"安全密码"&#xff1a;Gitee Test如何破解行业痛点 在数字化浪潮席卷全球的今天&#xff0c;软件系统已成为国家关键领域的"神经中枢"。从国防军工到能源电力&#xff0c;从金融交易到交通管控&#xff0c;这些关乎国计民生的关键领域…...