<!--[![](https://github.com/xmaihh/Android-Serialport/raw/master/art/logo.png)](https://code.google.com/archive/p/android-serialport-api/)-->
# Android-Serialport
移植谷歌官方串口库[android-serialport-api](https://code.google.com/archive/p/android-serialport-api/),仅支持串口名称及波特率,该项目添加支持校验位、数据位、停止位、流控配置项
<!--<img src="https://github.com/xmaihh/Android-Serialport/raw/master/art/compile_env.png" width="80%" height="80%" align="middle" alt="编译环境"/>-->
<img src ="https://github.com/xmaihh/Android-Serialport/blob/master/art/logo.svg" height = 150 alt ="Android-Serialport"/>
[![GitHub forks](https://img.shields.io/github/forks/xmaihh/Android-Serialport.svg)](https://github.com/xmaihh/Android-Serialport/network)[![GitHub issues](https://img.shields.io/github/issues/xmaihh/Android-Serialport.svg)](https://github.com/xmaihh/Android-Serialport/issues)[![GitHub stars](https://img.shields.io/github/stars/xmaihh/Android-Serialport.svg)](https://github.com/xmaihh/Android-Serialport/stargazers)[![Source persent](https://img.shields.io/badge/Java-73.2%25-brightgreen.svg)](https://github.com/xmaihh/Android-Serialport/search?l=C)[![Jcenter2.1](https://img.shields.io/badge/jcenter-2.1-brightgreen.svg)](https://bintray.com/xmaihh/maven/serialport)![Maven Central](https://img.shields.io/maven-central/v/io.github.xmaihh/serialport)
[![GitHub license](https://img.shields.io/github/license/xmaihh/Android-Serialport.svg)](https://github.com/xmaihh/Android-Serialport)
# 文档
<p >
<a href="https://github.com/xmaihh/Android-Serialport/blob/master/README.md">中文</a>
| <a href="https://github.com/xmaihh/Android-Serialport/blob/master/README_EN.md">English</a>
</p>
# 使用依赖
1. 在项目根目录的`build.gradle`文件中添加:
```
allprojects {
repositories {
...
mavenCentral()
}
}
```
2. 在项目Module下的`build.gradle`文件中添加:
```
dependencies {
implementation 'io.github.xmaihh:serialport:2.1.1'
}
```
# 属性支持
| 属性 | 参数 |
| --- |:------------------------------------------------------------------------------------------------------------------------------------:|
|波特率 | [BAUDRATE](https://github.com/xmaihh/Android-Serialport/blob/master/serialport/src/main/java/android_serialport_api/SerialPort.java) |
|数据位 | 5,6,7,8 ;默认值8 |
|校验位 | 无奇偶校验(NONE), 奇校验(ODD), 偶校验(EVEN), 0校验(SPACE), 1校验(MARK); 默认无奇偶校验 |
| 停止位| 1,2 ;默认值1 |
|流控 | 不使用流控(NONE), 硬件流控(RTS/CTS), 软件流控(XON/XOFF); 默认不使用流控 |
# 代码功能
## 1.列出串口列表
```
serialPortFinder.getAllDevicesPath();
```
## 2.串口属性设置
```
serialHelper.setPort(String sPort); //设置串口
serialHelper.setBaudRate(int iBaud); //设置波特率
serialHelper.setStopBits(int stopBits); //设置停止位
serialHelper.setDataBits(int dataBits); //设置数据位
serialHelper.setParity(int parity); //设置校验位
serialHelper.setFlowCon(int flowcon); //设置流控
```
[![](https://img.shields.io/badge/warning-%09%20admonition-yellow.svg)](https://github.com/xmaihh/Android-Serialport)
串口属性设置需在执行`open()`函数之前才能设置生效
## 3.打开串口
```
serialHelper.open();
```
## 4.关闭串口
```
serialHelper.close();
```
## 5.发送
```
serialHelper.send(byte[] bOutArray); // 发送byte[]
serialHelper.sendHex(String sHex); // 发送Hex
serialHelper.sendTxt(String sTxt); // 发送ASCII
```
## 6.接收
```
@Override
protected void onDataReceived(final ComBean comBean) {
Toast.makeText(getBaseContext(), new String(comBean.bRec, "UTF-8"), Toast.LENGTH_SHORT).show();
}
```
## 7.粘包处理
支持粘包处理,原因见[issues#1](https://github.com/xmaihh/Android-Serialport/issues/1),提供的粘包处理有
1. [不处理](https://github.com/xmaihh/Android-Serialport/blob/master/serialport/src/main/java/tp/xmaihh/serialport/stick/BaseStickPackageHelper.java)(默认)
2. [首尾特殊字符处理](https://github.com/xmaihh/Android-Serialport/blob/master/serialport/src/main/java/tp/xmaihh/serialport/stick/SpecifiedStickPackageHelper.java)
3. [固定长度处理](https://github.com/xmaihh/Android-Serialport/blob/master/serialport/src/main/java/tp/xmaihh/serialport/stick/StaticLenStickPackageHelper.java)
4. [动态长度处理](https://github.com/xmaihh/Android-Serialport/blob/master/serialport/src/main/java/tp/xmaihh/serialport/stick/VariableLenStickPackageHelper.java)
支持自定义粘包处理,第一步实现[AbsStickPackageHelper](https://github.com/xmaihh/Android-Serialport/blob/master/serialport/src/main/java/tp/xmaihh/serialport/stick/AbsStickPackageHelper.java)接口
```
/**
* 接受消息,粘包处理的helper,通过inputstream,返回最终的数据,需手动处理粘包,返回的byte[]是我们预期的完整数据
* note:这个方法会反复调用,直到解析到一条完整的数据。该方法是同步的,尽量不要做耗时操作,否则会阻塞读取数据
*/
public interface AbsStickPackageHelper {
byte[] execute(InputStream is);
}
```
设置粘包处理
```
serialHelper.setStickPackageHelper(AbsStickPackageHelper mStickPackageHelper);
```
* 其实数据粘包可参考socket通讯的粘包处理,例如此处粘包处理方法出自于[XAndroidSocket](https://github.com/Blankeer/XAndroidSocket)
# 屏幕截图
![Screenshot showing screen](art/screen.png "Screenshot showing screen")
<a href="https://play.google.com/store/apps/details?id=com.ex.serialport"><img src="https://play.google.com/intl/en_us/badges/static/images/badges/en_badge_web_generic.png" height="70"></a>
PC端调试工具 [友善串口调试工具](https://github.com/xmaihh/Android-Serialport/raw/master/serial_port_utility_latest.exe)
# 更新日志
## [2.1.2](https://github.com/xmaihh/Android-Serialport/tree/v2.1.2)
### 新增
- 添加支持设置校验位:0校验(SPACE)、1校验(MARK)
- 添加支持设置自定义波特率 见[issues#26](https://github.com/xmaihh/Android-Serialport/issues/26)
## [2.1.1](https://github.com/xmaihh/Android-Serialport/tree/v2.1.1)
### 修复
- 修复引用依赖问题见[issues#17](https://github.com/xmaihh/Android-Serialport/issues/17)
- 迁移到到MavenCentral
## [2.1](https://github.com/xmaihh/Android-Serialport/tree/v2.1)
### 新增
- 添加支持设置接收数据粘包处理,支持设置自定义粘包处理
## [2.0](https://github.com/xmaihh/Android-Serialport/tree/v2.0)
### 新增
- 添加支持设置校验位、数据位、停止位、流控配置项
## [1.0](https://github.com/xmaihh/Android-Serialport/tree/v1.0)
### 新增
- 基础功能,串口设置串口号、波特率,发送、接收数据
# FAQ
* 此library不提供ROOT权限,请自行打开串口`666`权限
```shell
adb shell chmod 666 /dev/ttyS1
```
long_hai_d
- 粉丝: 4
- 资源: 5
最新资源
- 流浪猫流浪狗领养PHP网站源码.7z
- 西门子1500PLC博途程序加经典Wincc7.5程序案例,水处理项目,具体为滤液生化段处理项目,文件内容有博途V16程序及本项目电气自控图纸 送WINCC7.5画面:MBR系统,加药系统,电气系统
- 西门子1200博途程序与威纶触摸屏画面实例 ,博图版本V15及以上,内容涉及上位机通讯,modbus485,伺服等 具体有: 1,西门子1200控制4台步进电机; 2,西门子1200与4台MS300
- 自动驾驶,AutoWareAuto框架全框架梳理思维导图及代码注释 授人以鱼不如授人以渔,涵盖:融合感知模块,定位模块,决策规划模块,控制模块,预测模块等较为详细的注释(并非每行都有注释)及框架梳理
- 1月10日hyh汇报ppt
- Picker抓抓辅助工具(句柄获取工具)
- 智慧旅游系统+Java,JSP+智慧旅游+旅游推荐
- 什么是CDN分流CDN的分流技术PDF
- 旅游景点个性化推荐论文+java,JSP+旅游景点推荐
- 基于java+ssm+mysql的实验室管理与排课系统开题报告.doc
- 基于java+ssm+mysql的题库管理系统开题报告.docx
- 基于java+ssm+mysql的图书管理系统v2开题报告.docx
- 基于java+ssm+mysql的校园疫情管控系统任务书.docx
- 基于java+ssm+mysql的疫情期间高校人员管理系统开题报告.docx
- 基于java+ssm+mysql的长安材料批发市场管理系统开题报告.docx
- 大模型监测 这段代码使用了 Hugging Face 的 Vision Transformer (ViT) 模型,完成一个图像分类任务 以下是主要功能: 模型加载:加载预训练的 ViT 模型 goo
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈