SerialPort-4.0.+ 使用说明(Java版本)
SerialPort-4.0.+
项目官网
Kotlin版本使用说明
介绍
SerialPort 是一个开源的对 Android 蓝牙串口通信的轻量封装库,轻松解决了构建自己的串口调试APP的复杂程度,让人可以专注追求自己设计,不用考虑蓝牙串口底层的配置。
相较于3.0.+版本,4.0.+新增了对蓝牙4.0及以上设备的支持。具体更新内容见下文详细说明。
特性
- 兼容传统蓝牙与BLE蓝牙设备
- 内部集成搜索页面
- 自动重连上一次连接的设备
- 间隔时间自动重连
- Toast提示信息修改
QQ技术交流群

最新版本信息
- 4.1.0
- 修复内置搜索页面搜索到设备名为空的设备造成闪退的问题
- 修复连接设备成功后会报广播接收器没有被注册的问题
- 优化搜索结果的处理
- 内置搜索页面新增设备类型字段
- 内置搜索页面设备图标跟设备类型相匹配
- 新增附带搜索设备类型的搜索状态回调
- 新增通过设置地址自动区分设备连接函数
- 优化对蓝牙开关状态的处理
- 4.0.2
- 添加搜索状态回调,
setDiscoveryStatusCallback - 接收回调函数名修改,由
setReceivedDataListener变更为setReceivedDataCallback
- 添加搜索状态回调,
- 4.0.1
- 修复
setLegacyUUID和setBleUUID不能链式调用的问题
- 修复
- 4.0.0
- 新特性
- 支持蓝牙4.0以上设备
- 新增间隔自动重连
- 新增Toast提示内容修改
- 新增搜索页面忽视没有名字的设备
- 部分API过时,详情见下文
- 修复
- 打开内置搜索页面闪退
- 断开连接延时过长
- 未连接时发送数据自动打开内置搜索页面不稳定
- 发送十六进制 0A 时,自动变为 0A 0D
- 新特性
源码地址
Demo示例源码地址
使用说明
添加依赖
- 根目录下的
build.gradle加入以下代码:
allprojects {
repositories {
//...
maven { url 'https://jitpack.io' }
}
}
- app模块的
build.gradle加入以下代码即可:
dependencies {
//根据自身网络情况以下两个仓库二选一即可
implementation 'com.github.Shanyaliux:SerialPortSample:4.1.0' //国外仓库
implementation 'com.gitee.Shanya:SerialPortSample:4.1.0' //国内仓库
}
获取SerialPort实例
SerialPort serialPort = SerialPortBuilder.INSTANCE
//是否打印调试信息
.isDebug(true)
//设置传统设备连接UUID(不设置则为以下默认值)
// .setLegacyUUID("00001101-0000-1000-8000-00805F9B34FB")
//设置BLE设备连接UUID(不设置则为以下默认值)
// .setBleUUID("0000ffe1-0000-1000-8000-00805f9b34fb")
//是否开启启动时自动重连
.autoConnect(false)
//是否开启间隔时间自动重连(间隔时间time不设置则默认为10000ms)
.setAutoReconnectAtIntervals(false, 10000)
//搜索结果是否忽略没有名字的设备
.isIgnoreNoNameDevice(true)
//发送数据时若未连接设备是否自动打开内置搜索页面
.autoOpenDiscoveryActivity(true)
//在接收数据格式为十六进制时,是否将其自动转换为字符串
.autoHexStringToString(false)
//设置接收数据格式(若不设置则默认为字符串)
// .setReadDataType(SerialPort.READ_STRING)
//设置发送数据格式(若不设置则默认为字符串)
// .setSendDataType(SerialPort.SEND_STRING)
//搜索状态监听(status 为搜索状态)
.setDiscoveryStatusCallback((status) -> {<span class="token keyword">return</span> <span class="token keyword">null</span><span class="token punctuation">;</span>
<span class="token punctuation">}</span><span class="token punctuation">)</span>
<span class="token comment">//搜索状态带类型的监听</span>
<span class="token comment">//deviceType = SerialPort.DISCOVERY_BLE 搜索BLE设备</span>
<span class="token comment">//deviceType = SerialPort.DISCOVERY_LEGACY 搜索传统类型</span>
<span class="token comment">//status 为搜索状态</span>
<span class="token punctuation">.</span><span class="token function">setDiscoveryStatusWithTypeCallback</span><span class="token punctuation">(</span><span class="token punctuation">(</span>deviceType<span class="token punctuation">,</span> status<span class="token punctuation">)</span> <span class="token operator">-></span> <span class="token punctuation">{<!-- --></span> <span class="token keyword">return</span> <span class="token keyword">null</span><span class="token punctuation">;</span>
<span class="token punctuation">}</span><span class="token punctuation">)</span>
<span class="token comment">//连接状态监听(status 为连接状态,bluetoothDevice 为连接设备)</span>
<span class="token punctuation">.</span><span class="token function">setConnectionStatusCallback</span><span class="token punctuation">(</span><span class="token punctuation">(</span>status<span class="token punctuation">,</span>bluetoothDevice<span class="token punctuation">)</span> <span class="token operator">-></span><span class="token punctuation">{<!-- --></span> <span class="token keyword">return</span> <span class="token keyword">null</span><span class="token punctuation">;</span>
<span class="token punctuation">}</span><span class="token punctuation">)</span>
<span class="token comment">//接收数据监听(string 为收到的数据)</span>
<span class="token punctuation">.</span><span class="token function">setReceivedDataListener</span><span class="token punctuation">(</span><span class="token punctuation">(</span>string<span class="token punctuation">)</span> <span class="token operator">-></span> <span class="token punctuation">{<!-- --></span> <span class="token keyword">return</span> <span class="token keyword">null</span><span class="token punctuation">;</span>
<span class="token punctuation">}</span><span class="token punctuation">)</span>
<span class="token punctuation">.</span><span class="token function">build</span><span class="token punctuation">(</span><span class="token keyword">this</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
设置UUID
- 传统设备
SerialPort.Companion.setLegacyUUID("00001101-0000-1000-8000-00805F9B34FB");
- BLE设备
SerialPort.Companion.setBleUUID("0000ffe1-0000-1000-8000-00805f9b34fb");
BLE设备的UUID可以在连接后调用
serialPort.printPossibleBleUUID()来查看一些可选值
搜索设备
//以下两种方案均可
serialPort.doDiscovery(this);
SerialPortBuilder.INSTANCE.doDiscovery(this);
停止搜索
serialPort.cancelDiscovery(this);
搜索状态监听
//status 为搜索状态
serialPort.setDiscoveryStatusCallback((status) ->{ return null;
});
//搜索状态带类型的监听
//deviceType = SerialPort.DISCOVERY_BLE 搜索BLE设备
//deviceType = SerialPort.DISCOVERY_LEGACY 搜索传统类型
//status 为搜索状态
serialPort.setDiscoveryStatusWithTypeCallback((deviceType, status) -> {return null;
});
若多处设置了监听,仅最后一次设置的生效
获取搜索结果
serialPort.getPairedDevicesList(); //获取已配对设备
serialPort.getUnPairedDevicesList(); //获取未配对设备
上述方法在4.0.0开始被弃用,建议使用以下方法
serialPort.getPairedDevicesListBD(); //获取已配对设备
serialPort.getUnPairedDevicesListBD(); //获取未配对设备
连接设备
- 打开内部集成的搜索页面
serialPort.openDiscoveryActivity();
- 打开自定义的搜索页面
Intent intent = new Intent(this, YourActivity.class);
serialPort.openDiscoveryActivity(intent);
- 通过设备地址连接
- 传统设备连接
serialPort.connectLegacyDevice("98:D3:32:21:67:D0");
- BLE设备连接
serialPort.connectBle("98:D3:32:21:67:D0");
断开连接
serialPort.disconnect()
连接状态监听
serialPort.setConnectStatusCallback((status,device)->{<span class="token keyword">return</span> <span class="token keyword">null</span><span class="token punctuation">;</span>
});
上述方法在4.0.0开始被弃用,建议使用以下方法
serialPort.setConnectionStatusCallback((status,bluetoothDevice)->{<span class="token keyword">return</span> <span class="token keyword">null</span><span class="token punctuation">;</span>
});
若多处设置了监听,仅最后一次设置的生效
设置接收数据格式
//SerialPort.READ_HEX 十六进制
//SerialPort.READ_STRING 字符串
//不设置则默认字符串形式
serialPort.setReadDataType(SerialPort.READ_HEX);
目前BLE设备暂不支持设置数据格式设置
设置发送数据格式
//SerialPort.SEND_HEX 十六进制
//SerialPort.SEND_STRING 字符串
//不设置则默认字符串形式
serialPort.setSendDataType(SerialPort.SEND_HEX);
目前BLE设备暂不支持设置数据格式设置
发送数据
//以下两种方案均可
serialPort.sendData("hello");
SerialPortBuilder.INSTANCE.sendData("hello");
若发送的数据为十六进制,则输入的数据需要为偶数个,只有一位的需要在其前面补0,且字母大写
例如:发送0x0a 0x0D,需要写成serialPort.sendData("0A 0D")
接收消息监听
serialPort.setReceivedDataCallback((string) -> {<span class="token keyword">return</span> <span class="token keyword">null</span><span class="token punctuation">;</span>
});
若多处设置了监听,仅最后一次设置的生效
十六进制字符串转换成字符串
String string = serialPort.hexStringToString(hexString);
此时的接收数据格式为十六进制
修改Toast提示
//是否显示
SerialPortToast.INSTANCE.getConnectSucceeded().setStatus(true);
//提示内容
SerialPortToast.INSTANCE.getConnectSucceeded().setContent("连接成功");
//显示时长 Toast.LENGTH_SHORT 或 Toast.LENGTH_LONG
SerialPortToast.INSTANCE.getConnectSucceeded().setTime(Toast.LENGTH_SHORT);
| 项目 | 描述 | 默认值 |
|---|---|---|
| connectSucceeded | 连接成功时 | 连接成功 |
| connectFailed | 连接失败时 | 连接失败 |
| disconnect | 断开连接时 | 断开连接 |
| connectFirst | 未连接设备时执行发送数据 | 请先连接设备 |
| disconnectFirst | 已连接设备后执行连接操作 | 请先断开连接 |
| permission | 询问是否开启定位权限 | 请先开启位置权限 |
| hexTip | 发送十六进制时,数据格式不对提示 | 请输入的十六进制数据保持两位,不足前面补0 |
| openBluetoothSucceeded | 打开蓝牙成功时 | 蓝牙打开成功 |
| openBluetoothFailed | 打开蓝牙失败时 | 蓝牙打开失败 |
SerialPort-4.0.+ 使用说明(Java版本)的更多相关文章
- SerialPort-4.0.+ 使用说明(Kotlin版本)
SerialPort-4.0.+ 项目官网 Java版本使用说明 介绍 SerialPort 是一个开源的对 Android 蓝牙串口通信的轻量封装库,轻松解决了构建自己的串口调试APP的复杂程度,让 ...
- linux ubuntu下如何安装并且切换java版本(Unsupported major.minor version 52.0)
最近在做一个dcos(数据中心操作系统)的东西,需要用marathon来做进程管理.遗憾的是0.6版本的marathon在API方面很是缺少,换成了0.15版本之后,运行时提示“Unsupported ...
- Java进阶(十二)JDK版本错误之Unsupported major.minor version 51.0(jdk版本错误)
错误:Unsupported major.minor version 51.0(jdk版本错误) 如果在win7下开发项目是使用的jdk版本和项目运行服务器jdk版本不同就会出现上面的问题. 用jdk ...
- Redis集群环境使用的是redis4.0.x的版本,在用java客户端jedisCluster启动集群做数据处理时报java.lang.NumberFormatException: For input string: "7003@17003"问题解决
java.lang.NumberFormatException: For input string: "7003@17003" at java.lang.NumberFormatE ...
- 复利计算5.0(改成Java版本)与 单元测试
//由于C语言版本不方便单元测试,所以改成了java版本,部分代码如下:import java.util.Scanner; public class FuLi{ public static void ...
- Log4j 2.0 使用说明
原文地址:http://blog.csdn.net/welcome000yy/article/details/7962447 Log4j 2.0 使用说明(1) 之HelloWorld 最近刚接触 ...
- R树判断点在多边形内-Java版本
1.什么是RTree 待补充 2.RTree java依赖 rtree的java开源版本在GitHub上:https://github.com/davidmoten/rtree 上面有详细的使用说明 ...
- Java版本:识别Json字符串并分隔成Map集合
前言: 最近又看了点Java的知识,于是想着把CYQ.Data V5迁移到Java版本. 过程发现坑很多,理论上看大部分很相似,实践上代码写起来发现大部分都要重新思考方案. 遇到的C#转Java的一些 ...
- 你的程序支持复杂的时间调度嘛?如约而来的 java 版本
你的程序支持复杂的时间调度嘛? 这篇文章介绍了时间适配器的c#版本,是给客户端用的,服务器自然也要有一套对应的做法,java版本的 [年][月][日][星期][时间] [*][*][*][*][*] ...
- 错误:Unsupported major.minor version 51.0(jdk版本错误)的解决方法
错误:Unsupported major.minor version 51.0(jdk版本错误)的解决方法 java.lang.UnsupportedClassVersionError: org/ap ...
随机推荐
- Docker容器入门介绍
1.前言 Docker是一种新兴的虚拟化技术,能够一定程度上的代替传统虚拟机.不过,Docker 跟传统的虚拟化方式相比具有众多的优势.Docker: 本意是码头工人,言外之意是集装箱: Java号称 ...
- 接口(interface)与抽象类(abstract class)两者的异同
首先说明一下,JDK1.8以后接口可以有默认方法和静态方法以及私有方法. 一.概念: 接口(interface):是抽象类的变体,其中所有的方法都是抽象的且不能有方法体,而且只能定义 static f ...
- Spring Boot 2.X 有什么新特性?与 1.X 有什么区别?
配置变更JDK 版本升级第三方类库升级响应式 Spring 编程支持HTTP/2 支持配置属性绑定更多改进与加强-
- 什么是 Spring MVC 框架的控制器?
控制器提供一个访问应用程序的行为,此行为通常通过服务接口实现.控制器解 析用户输入并将其转换为一个由视图呈现给用户的模型.Spring 用一个非常抽象 的方式实现了一个控制层,允许用户创建多种用途的控 ...
- 创建POJO
创建一个名为student.java的POJO. 第一步,在包里面创建一个student类,右键点击包,点击新建,再点击创建一个类. 第二步,输入类名,点击完成. 第三步,输入数据类型和主键名,再写一 ...
- 软件构造实验-Guns
根据guns开发示例,搭建汽车信息管理系统
- 微信小程序插件组件-Taro UI
微信小程序组件使用以下官网查看 ↓ ↓ ↓ https://taro-ui.jd.com/#/docs/fab
- 关于json对象的使用小结!
json是前后端数据交互的关键.后端提供的接口中的数据几乎都是通过json来表现的,所以,需要对这个json做一些小结: 这里要推进谷歌的插件Fehelp前端助手,这个可以清楚的看到json的数据: ...
- linux(Ubuntu)安装python
Linux下安装python 提前安装一个依赖环境 (1)ubuntu/Debian: sudo apt-get install -y gcc make cmake build-essential l ...
- MFC---文档与视图结构
文档与视图结构 文档.视图的关系,是一对多的映射,一个文档可以对应多个视图,而一个视图只能对应一个文档.例如,一个.html文件,可以用记事本打开,也可以用浏览器打开,这里的.html文件就是文档,记 ...