Android 蓝牙串口通信工具类 SerialPortUtil 3.0.+
建议使用4.+版本,避免一些不必要的bug。4.+版本文档地址:https://www.cnblogs.com/shanya/articles/16062256.html
SerialPortUtil 3.0.+
介绍
SerialPortUtil 简介
SerialPort 是一个开源的对 Android 蓝牙串口通信的轻量封装库,轻松解决了构建自己的串口调试APP的复杂程度,让人可以专注追求自己设计,不用考虑蓝牙串口底层的配置。
从 3.0.0 开始新增链式调用,更新大量API,并上传至Jcenter,让使用变得更加简单。
- 集成搜索Activity,不用自己费力去实现
- 通过回调处理接收数据
- 异步处理发送
- 接收与发送均可使用十六进制和字符串
特性
- 内部集成的搜索页面
- 自动重连上一次连接的设备
- 可自行选择发送接收的数据格式
QQ技术交流群

最新版本 V3.0.0-beta3
V3.0.0-beta3 新特性
- 新增16进制字符串自动转换成普通字符串
- 新增可传入自定义搜索页面的功能
V3.0.0-beta0 新特性:
- 链式调用
- API更新,详情见下方使用说明
- 上传至Jcenter,优化引用
- 新增Debug模式
- 新增自动重连功能
- 删除对输入框的监听
- 支持 Android5.0 及以上
修复:
- 修复多Activity跳转报错的问题
- 修复进入搜索页面返回后权限申请对话框不消失的问题
开源仓库地址
GitHub仓库
Gitee仓库
开始
安装
gradle
添加
JitPack仓库到你的配置文件根目录下的
build.gradle加入以下代码:allprojects {
repositories {
//...
maven { url 'https://jitpack.io' }
}
}
添加依赖
app模块的 build.gradle 加入以下代码即可:
Github 仓库
dependencies {
implementation 'com.github.Shanyaliux:SerialPortSample:3.0.0-beta3'
}
国内仓库
dependencies {
implementation 'com.gitee.Shanya:SerialPortSample:3.0.0-beta3'
}
使用
以下所有代码块,第一块是Kotlin,第二块是Java
快速上手
val serialPort = SerialPortBuilder
//是否开启Debug模式(Debug模式在Logcat打印一些信息,便于调试)
.isDebug(true)
//是否开启自动连接
.autoConnect(true)
//设置接收数据格式(SerialPort.READ_HEX 为十六进制,SerialPort.READ_STRING 为字符串)
.setReadDataType(SerialPort.READ_HEX)
//设置接收数据格式(SerialPort.SEND_HEX 为十六进制,SerialPort.SEND_STRING 为字符串)
.setSendDataType(SerialPort.SEND_HEX)
//设置接收 消息监听
.setReceivedDataListener {
Log.d("SerialPortDebug", "received: ${it}")
}
//设置连接状态监听 (status 为连接状态,device 为当前连接设备)
.setConnectStatusCallback { status, device ->
if (status) {
Log.d("SerialPortDebug", "连接: ${device.address}")
} else {
Log.d("SerialPortDebug", "断开")
}
}
//创建实例(需要传入上下文)
.build(this)
SerialPort serialPort = SerialPortBuilder.INSTANCE
//是否开启Debug模式(Debug模式在Logcat打印一些信息,便于调试)
.isDebug(true)
//是否开启自动连接
.autoConnect(true)
//设置接收数据格式(SerialPort.READ_HEX 为十六进制,SerialPort.READ_STRING 为字符串)
.setReadDataType(SerialPort.READ_HEX)
//设置接收数据格式(SerialPort.SEND_HEX 为十六进制,SerialPort.SEND_STRING 为字符串)
.setSendDataType(SerialPort.SEND_HEX)
//设置接收 消息监听
.setReceivedDataListener(new Function1<String, Unit>() {
@Override
public Unit invoke(String s) {
return null;
}
})
//设置连接状态监听 (status 为连接状态,device 为当前连接设备)
.setConnectStatusCallback(new Function2<Boolean, Device, Unit>() {
@Override
public Unit invoke(Boolean aBoolean, Device device) {
return null;
}
})
//创建实例(需要传入上下文)
.build(this);
以上仅是获取了 SerialPort 的实例,想要开始使用 SerialPort 请先连接设备。方法如下:
连接设备
使用内部集成的搜索页面进行连接
serialPort.openDiscoveryActivity()
serialPort.openDiscoveryActivity();
打开页面点击需要连接的设备即可
自行使用设备地址进行连接
serialPort.connectDevice("98:D3:32:21:67:D0")
serialPort.connectDevice("98:D3:32:21:67:D0");
自行使用设备地址连接的设备名称为空。
断开连接
serialPort.disconnect()
serialPort.disconnect();
设置接收数据格式
| 可选参数(默认是 字符类型) | |
|---|---|
| SerialPort.READ_STRING | 字符类型 |
| SerialPort.READ_HEX | 十六进制 |
serialPort.setReadDataType(SerialPort.READ_HEX)
serialPort.setReadDataType(SerialPort.READ_HEX);
设置发送数据类型
| 可选参数(默认是 字符类型) | |
|---|---|
| SerialPort.SEND_STRING | 字符类型 |
| SerialPort.SEND_HEX | 十六进制 |
serialPort.setSendDataType(SerialPort.SEND_HEX)
serialPort.setSendDataType(SerialPort.SEND_HEX);
发送数据
serialPort.sendData("hello")
serialPort.sendData("hello");
如果发送数据格式设置为16进制,输入的数据需要为偶数,只有一位的数据需要在前面补0。
例如:0x0A 需要写成 0A,serialPort.sendData("0A")
接收消息监听
serialPort.setReceivedDataListener { it
// it即为接收数据
Log.d("SerialPortDebug", "received: ${it}")
}
serialPort.setReceivedDataListener(new Function1<String, Unit>() {
@Override
public Unit invoke(String s) {
return null;
}
});
接收数据回调如果在多个地方调用,仅最后一个生效。
连接状态监听
serialPort.setConnectStatusCallback { status, device ->
if (status) {
Log.d("SerialPortDebug", "连接: ${device.address}")
} else {
Log.d("SerialPortDebug", "断开")
}
}
serialPort.setConnectStatusCallback(new Function2<Boolean, Device, Unit>() {
@Override
public Unit invoke(Boolean aBoolean, Device device) {
return null;
}
})
连接状态回调如果在多个地方调用,仅最后一个生效。
十六进制字符串转换成字符串
需使用 3.0.0-beta2 版本及以上
此时的接收数据格式为十六进制
调用方法转换
serialPort.hexStringToString(hexString)
serialPort.hexStringToString(hexString);
自动转换(初始化的时候打开标志位即可)
val serialPort = SerialPortBuilder
.autoHexStringToString(true)
.build(this)
SerialPort serialPort = SerialPortBuilder.INSTANCE
.autoHexStringToString(true)
.build(this);
自定义搜索页面
需使用 3.0.0-beta3 版本及以上
serialPort.openDiscoveryActivity(Intent(this,DiscoveryActivity::class.java))
serialPort.openDiscoveryActivity(new Intent(this, DiscoveryActivity.class));
搜索设备
需使用 3.0.0-beta3 版本及以上
serialPort.doDiscovery(this)
serialPort.doDiscovery(this);
Android 蓝牙串口通信工具类 SerialPortUtil 3.0.+的更多相关文章
- Android Studio 的蓝牙串口通信(附Demo源码下载)
根据相关代码制作了一个开源依赖包,将以下所有的代码进行打包,直接调用即可完成所有的操作.详细说明地址如下,如果觉得有用可以GIthub点个Star支持一下: 项目官网 Kotlin版本说明文档 Jav ...
- BluetoothChat用于蓝牙串口通信的修改方法
本人最近在研究嵌入式的串口通信,任务是要写一个手机端的遥控器用来遥控双轮平衡小车.界面只用了一个小时就写好了,重要的问题是如何与板子所带的SPP-CA蓝牙模块进行通信. SPP-CA模块自带代码,在这 ...
- Android蓝牙串口通讯【转】
本文转载自:http://blog.sina.com.cn/s/blog_631e3f2601012ixi.html Android蓝牙串口通讯 闲着无聊玩起了Android蓝牙模块与单片机蓝牙模块的 ...
- Android开发调试日志工具类[支持保存到SD卡]
直接上代码: package com.example.callstatus; import java.io.File; import java.io.FileWriter; import java.i ...
- Android开源项目大全 - 工具类
主要包括那些不错的开发库,包括依赖注入框架.图片缓存.网络相关.数据库ORM建模.Android公共库.Android 高版本向低版本兼容.多媒体相关及其他. 一.依赖注入DI 通过依赖注入减少Vie ...
- wemall app商城源码android开发MD5加密工具类
wemall-mobile是基于WeMall的android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享android开发MD5加密工具类主要代码,供 ...
- Android弹出Toast工具类总结
Android弹出Toast工具类总结,包括系统自带的,也包括自定义的. public class ToastUtil { public ToastUtil() { } public static T ...
- Android 中替代 sharedpreferences 工具类的实现
Android 中替代 sharedpreferences 工具类的实现 背景 想必大家一定用过 sharedpreferences 吧!就我个人而言,特别讨厌每次 put 完数据还要 commit. ...
- Https通信工具类
记录一个在微信开发中用到的https通信工具类,以后会用到的. 用于https通信的证书信任管理器 import java.security.cert.CertificateException; im ...
随机推荐
- Redis系统学习
准备写一些关于Redis学习的文章的,发现网上有N多资料有人已经做了总结.查看这些Redis资料,按次序浏览这些Redis资料,相信想学习Redis的同学会很快熟悉: 1.Redis学习手册(目录) ...
- 浅析DES原理
对称密码体制 对称密码体制:一种加密系统.其加密密钥和解密密钥是相同的,或者能够从其中之一推知另一个.对称密码体制根据对明文加密方式不同分为分组密码和流密码. 分组密码 分组密码按照一定长度(如64b ...
- 半吊子菜鸟学Web开发 -- PHP学习2-正则,cookie和session
1正则表达式 1.1基本的匹配字符串 $p = '/apple/'; $str = "apple banna"; if (preg_match($p, $str)) { echo ...
- 半吊子菜鸟学Web开发6 -- Vscode开发环境配置
1vscode上手一周不到,终于弄出点门路,终于弄清楚了点vscode的设置是什么样子的了....哭 2就我这两天的使用来看,一般vscode默认只让打开一个文件夹,然后在你打开的文件夹里面自动生成 ...
- 如何规划一台 Linux 主机,步骤是怎样?
1.确定机器是做什么用的,比如是做 WEB .DB.还是游戏服务器.不同的用途,机器的配置会有所不同. 2.确定好之后,就要定系统需要怎么安装,默认安装哪些系统.分区怎么做. 3.需要优化 ...
- 创建自定义ClassLoader,绕过双亲委派
1.什么是类加载 通过javac将.java文件编译成.class字节码文件后,则需要将.class加载到JVM中运行,哪么是谁将.class加载到JVM的呢?那就是类加载器啦. 2.类加载器类型 B ...
- jdk 8 HashMap源码解读
转自:https://www.cnblogs.com/little-fly/p/7344285.html 在原来的作者的基础上,增加了本人对源代码的一些解读. 如有侵权,请联系本人 这几天学习了Has ...
- Python - Pycharm常用快捷键
1. 自动格式调整: pycharm有自动调整代码格式的快捷键,默认为Alt+Ctrl+L 2. 选中相同字符: 快捷键组合:Ctrl + Shift + Alt + J 3.批量缩进: 选择代码区域 ...
- Spring官宣网传大漏洞,并提供解决方案
Spring沦陷了!这样的标题这几天是不是看腻了?然而,仔细看看都是拿着之前的几个毫不相干的CVE来大吹特吹.所以,昨天发了一篇关于最近网传的Spring大漏洞的文章,聊了聊这些让人迷惑的营销文.以及 ...
- Codepen 每日精选(2018-4-20)
按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以打开原始页面. 图书打开的交互效果https://codepen.io/jcoulterde... 进度条交互效果http ...