# Android-Serialport **Repository Path**: jambestwick/Android-Serialport ## Basic Information - **Project Name**: Android-Serialport - **Description**: 引用大神的工程,android串口链接,支持多种参数 - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 10 - **Forks**: 3 - **Created**: 2020-04-13 - **Last Updated**: 2025-08-29 ## Categories & Tags **Categories**: android-modules **Tags**: None ## README # Android-Serialport 移植谷歌官方串口库[android-serialport-api](https://code.google.com/archive/p/android-serialport-api/),仅支持串口名称及波特率,该项目添加支持校验位、数据位、停止位、流控配置项 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)[![Demo apk download](https://img.shields.io/crates/dv/rustc-serialize.svg)](https://fir.im/lcuy) [![AppVeyor branch](https://img.shields.io/appveyor/ci/:user/:repo/:branch.svg)](https://github.com/xmaihh/Android-Serialport/tree/master)[![GitHub license](https://img.shields.io/github/license/xmaihh/Android-Serialport.svg)](https://github.com/xmaihh/Android-Serialport) # 文档 - [English](https://github.com/xmaihh/Android-Serialport/blob/master/README_EN.md) # 使用依赖[![Download](https://api.bintray.com/packages/xmaihh/maven/serialport/images/download.svg)](https://bintray.com/xmaihh/maven/serialport/_latestVersion) 1. `Gradle`引用 ``` implementation 'tp.xmaihh:serialport:2.1' ``` 2. `Maven`引用 ``` tp.xmaihh serialport 2.1 pom ``` # 属性支持 | 属性 | 参数| | --- | :---: | |波特率 | [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); 默认无奇偶校验| | 停止位| 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.粘包处理 支持粘包处理,原因见[issue](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) # 完整Demo地址 演示效果 [![apk下载](https://img.shields.io/crates/dv/rustc-serialize.svg)](https://fir.im/lcuy) PC端调试工具 [友善串口调试工具](https://github.com/xmaihh/Android-Serialport/raw/master/serial_port_utility_latest.exe) # 更新日志 ## [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`权限 ``` adb shell chmod 666 /dev/ttyS1 ```