建议使用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 新特性

    1. 新增16进制字符串自动转换成普通字符串
    2. 新增可传入自定义搜索页面的功能
  • V3.0.0-beta0 新特性:

    1. 链式调用
    2. API更新,详情见下方使用说明
    3. 上传至Jcenter,优化引用
    4. 新增Debug模式
    5. 新增自动重连功能
    6. 删除对输入框的监听
    7. 支持 Android5.0 及以上
  • 修复:

    1. 修复多Activity跳转报错的问题
    2. 修复进入搜索页面返回后权限申请对话框不消失的问题

开源仓库地址

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.+的更多相关文章

  1. Android Studio 的蓝牙串口通信(附Demo源码下载)

    根据相关代码制作了一个开源依赖包,将以下所有的代码进行打包,直接调用即可完成所有的操作.详细说明地址如下,如果觉得有用可以GIthub点个Star支持一下: 项目官网 Kotlin版本说明文档 Jav ...

  2. BluetoothChat用于蓝牙串口通信的修改方法

    本人最近在研究嵌入式的串口通信,任务是要写一个手机端的遥控器用来遥控双轮平衡小车.界面只用了一个小时就写好了,重要的问题是如何与板子所带的SPP-CA蓝牙模块进行通信. SPP-CA模块自带代码,在这 ...

  3. Android蓝牙串口通讯【转】

    本文转载自:http://blog.sina.com.cn/s/blog_631e3f2601012ixi.html Android蓝牙串口通讯 闲着无聊玩起了Android蓝牙模块与单片机蓝牙模块的 ...

  4. Android开发调试日志工具类[支持保存到SD卡]

    直接上代码: package com.example.callstatus; import java.io.File; import java.io.FileWriter; import java.i ...

  5. Android开源项目大全 - 工具类

    主要包括那些不错的开发库,包括依赖注入框架.图片缓存.网络相关.数据库ORM建模.Android公共库.Android 高版本向低版本兼容.多媒体相关及其他. 一.依赖注入DI 通过依赖注入减少Vie ...

  6. wemall app商城源码android开发MD5加密工具类

    wemall-mobile是基于WeMall的android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享android开发MD5加密工具类主要代码,供 ...

  7. Android弹出Toast工具类总结

    Android弹出Toast工具类总结,包括系统自带的,也包括自定义的. public class ToastUtil { public ToastUtil() { } public static T ...

  8. Android 中替代 sharedpreferences 工具类的实现

    Android 中替代 sharedpreferences 工具类的实现 背景 想必大家一定用过 sharedpreferences 吧!就我个人而言,特别讨厌每次 put 完数据还要 commit. ...

  9. Https通信工具类

    记录一个在微信开发中用到的https通信工具类,以后会用到的. 用于https通信的证书信任管理器 import java.security.cert.CertificateException; im ...

随机推荐

  1. GitFlow 工作流

    1.概述 GitFlow 工作流定义了一个围绕项目发布的严格分支模型.虽然比功能分支工作流复杂几分,但提供了用于一个健壮的用于管理大型项目的框架. GitFlow 工作流没有用超出功能分支工作流的概念 ...

  2. gitLab上dev分支上的内容都拉取到本地了

    从dev分支上更新代码 1.与远程仓库建立连接:git remote add origin XXXXX.git 2.使用git branch 查看本地是否具有dev分支 3.如果没有 git fetc ...

  3. Java 实现汇总排序

    排序在系统中经常能用到,一般可以在数据库做排序,也可以在服务端做排序.在数据库一般使用 order by 排序.而服务端也是使用快排.本期使用汇总排序. 问题 统计销售数据,每个销售员都有对应的部门和 ...

  4. SpringCloudAlibaba 微服务讲解(四)Sentinel--服务容错(一)

    4.1 高并发带来的问题 在微服务中,我们将业务拆分成一个个的服务,服务与服务之间可以相互调用,但是由于网络原因或者自身的原因,服务并不能保证100%可用,如果单个服务出现问题,调用这个服务就会出现网 ...

  5. OOP 中的 组合、聚合和关联有什么区别?

    如果两个对象彼此有关系,就说他们是彼此相关联的.组合和聚合是面向对象中 的两种形式的关联.组合是一种比聚合更强力的关联.组合中,一个对象是另一 个的拥有者,而聚合则是指一个对象使用另一个对象.如果对象 ...

  6. 单片,SOA 和微服务架构有什么区别?

    单片架构类似于大容器,其中应用程序的所有软件组件组装在一起并紧密 封装.第一个面向服务的架构是一种相互通信服务的集合.通信可以涉及简单的数 据传递,也可以涉及两个或多个协调某些活动的服务.微服务架构是 ...

  7. Mybatis 开发 dao 的方法

    1.分析SqlSession使用范围 1.1.SqlSessionFactoryBuilder 通过 SqlSessionFactoryBuilder 创建会话工厂 SqlSessionFactory ...

  8. 学习Puppet(一)

    puppet的入门 1.简介 puppet是一种采用C/S星状结构的linux.Unix平台的集中配置管理系统. puppet拥有自己的语言,可管理配置文件.用户.cron任务.软件包.系统服务等. ...

  9. 遇到MyBatis-Plus的错误之“Table 'mybatis_plus.user' doesn't exist”

    一.问题 Table 'mybatis_plus.user' doesn't exist 二.原因 表中没有user表 三.解决方案 生成user表既可 四.结果图 运行后显示查询出来的数据 五.总结 ...

  10. 自启动Servlet

    自启动servlet也叫自动实例化servlet 特点 该Servlet的实例化过程不依赖于请求,而依赖于容器的启动,当Tomcat启动时就会实例化该Servlet 普通Servlet是在浏览器第一次 ...