Android AS下的OTG串口设备读写

2024-08-21 12:48
文章标签 android 串口 读写 设备 otg

本文主要是介绍Android AS下的OTG串口设备读写,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Android AS下的OTG串口设备读写

  • 新建工程
  • 添加工具类
  • 添加设备参数列表
  • 具体实现
  • WIFI adb

了解嵌入式的读者应该知道在单片机编程中串口(uart)通讯接口最常用的就是TTL和USB接口,将单片机TTL转USB就可以接入电脑查看串口数据实现电脑与单片机通讯,在Android AS下的NDK开发中讲解了Android使用TTL方式的接口收发数据,当然咱们常用的Android手机没有这样的接口,要实现手机和单片机串口通讯就可以用OTG来实现。

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

新建工程

在这里插入图片描述

添加工具类

在添加工具类时可能会有错误提示,只是包名错了,修改报错文件的包成自己当前工程的包名即可解决问题:
在这里插入图片描述

添加设备参数列表

在AndroidManifest中声明指定的USB设备,设备信息存放在resource="@xml/device_filter"
在这里插入图片描述

<intent-filter><action android:name="android.hardware.usb.action.USB_DEVICE_ATTACHED"/>
</intent-filter>
<meta-dataandroid:name="android.hardware.usb.action.USB_DEVICE_ATTACHED"android:resource="@xml/device_filter"/>

xml文件夹下命名为device_filter.xml:
在这里插入图片描述

<?xml version="1.0" encoding="utf-8"?>
<resources><!-- 0x0403 / 0x6001: FTDI FT232R UART --><usb-device vendor-id="1027" product-id="24577" /><!-- 0x0403 / 0x6015: FTDI FT231X --><usb-device vendor-id="1027" product-id="24597" /><!-- 0x2341 / Arduino --><usb-device vendor-id="9025" /><!-- 0x16C0 / 0x0483: Teensyduino  --><usb-device vendor-id="5824" product-id="1155" /><!-- 0x10C4 / 0xEA60: CP210x UART Bridge --><usb-device vendor-id="4292" product-id="60000" /><!-- 0x067B / 0x2303: Prolific PL2303 --><usb-device vendor-id="1659" product-id="8963" />
</resources>

至于这个文件里面的数据表示的是什么,将USB转TTL模块插入电脑,在设备管理器里面可以看到:
在这里插入图片描述
PID_2303:2303的10进制是8963,也就是:product-id=“8963”
VID_067B:067B的10进制是1659,vendor-id=“1659”
不同的模块这两个值就不一样,所以就有了这样一个列表,当然这也不全,没有包含所有的型号。

具体实现

在MainActivity里面就可以写设备获取与数据收发了:

package com.example.otgdemo;import android.hardware.usb.UsbDevice;
import android.hardware.usb.UsbManager;
import android.os.AsyncTask;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.widget.Toast;import com.example.otgdemo.usbserial.driver.UsbSerialDriver;
import com.example.otgdemo.usbserial.driver.UsbSerialProber;
import com.example.otgdemo.usbserial.util.SerialInputOutputManager;
import com.example.otgdemo.utils.LogUtils;import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;public class MainActivity extends AppCompatActivity {private UsbManager mUsbManager;         // usb设备管理private List<DeviceEntry> mEntries;     // 串口设备列表private static UsbSerialDriver sDriver; // 打开的串口设备private static SerialInputOutputManager mSerialIoManager;   //数据发送、接收工具private ExecutorService mExecutorService;   //数据读取线程管理@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);// 获取USB_SERVICE的管理器mUsbManager = (UsbManager)getSystemService(this.USB_SERVICE);mEntries = new ArrayList<>();mExecutorService = Executors.newSingleThreadExecutor();refreshDeviceList();}/*** 刷新usb设备列表*/private void refreshDeviceList() {new AsyncTask<Void, Void, List<DeviceEntry>>() {@Overrideprotected List<DeviceEntry> doInBackground(Void... params) {Log.d("log","刷新设备列表 ...");final List<DeviceEntry> result = new ArrayList<>();Map<String, UsbDevice> deviceList = mUsbManager.getDeviceList();if (deviceList.isEmpty()) {Log.d("log","设备列表为空");} else {for (final UsbDevice device : mUsbManager.getDeviceList().values()) {final List<UsbSerialDriver> drivers = UsbSerialProber.probeSingleDevice(mUsbManager, device);Log.d("log","发现设备: " + device);if (drivers.isEmpty()) {Log.d("log","  - 空设备列表.");result.add(new DeviceEntry(null));} else {for (UsbSerialDriver driver : drivers) {Log.d("log","  + " + driver);result.add(new DeviceEntry(driver));}}}}return result;}@Overrideprotected void onPostExecute(List<DeviceEntry> result) {if (result.isEmpty()) {Toast.makeText(MainActivity.this, "没发现可用设备!", Toast.LENGTH_SHORT).show();return;}mEntries.clear();mEntries.addAll(result);sDriver = mEntries.get(0).driver;reStart();Log.d("log","停止刷新,发现" + mEntries.size() + " 个设备.");}}.execute((Void) null);}/*** 打开串口*/private void reStart() {if (sDriver == null) {Toast.makeText(this, "没有发现串口设备.", Toast.LENGTH_SHORT).show();} else {try {sDriver.open();sDriver.setParameters(57600, 8, UsbSerialDriver.STOPBITS_1, UsbSerialDriver.PARITY_NONE);} catch (IOException e) {LogUtils.d("设备打开错误: " + e.getMessage(), e);Toast.makeText(this, "设备打开错误: " + e.getMessage(), Toast.LENGTH_SHORT).show();try {sDriver.close();} catch (IOException e2) {// Ignore.}sDriver = null;return;}Toast.makeText(this, " 串口设备: " + sDriver.getClass().getSimpleName(), Toast.LENGTH_SHORT).show();}onDeviceStateChange();}/*** 重置串口*/private void onDeviceStateChange() {stopIoManager();startIoManager();}/*** 关闭串口*/private void stopIoManager() {if (mSerialIoManager != null) {LogUtils.d("Stopping io manager ..");mSerialIoManager.stop();mSerialIoManager = null;}}/*** 打开串口*/private void startIoManager() {if (sDriver != null) {LogUtils.d("Starting io manager ..");mSerialIoManager = new SerialInputOutputManager(sDriver, mListener);mExecutorService.submit(mSerialIoManager);//开启数据读取线程}}/*** Simple container for a UsbDevice and its driver.*/private static class DeviceEntry {public UsbSerialDriver driver;DeviceEntry(UsbSerialDriver driver) {this.driver = driver;}}/*** 数据读取回调*/private final SerialInputOutputManager.Listener mListener = new SerialInputOutputManager.Listener() {@Overridepublic void onRunError(Exception e) {LogUtils.d("Runner stopped.");}// 数据接收的回调函数@Overridepublic void onNewData(byte[] data, int len) {}};/*** 数据发送** @param data 要发送的数据*/public static void sendData(byte[] data) {if (mSerialIoManager != null) {mSerialIoManager.writeAsync(data);}}
}

WIFI adb

如果手机要调试那么会占用手机的usb端口,要下程序又要接OTG,来回拔插比较麻烦,可以在AS中使用wifi adb方式来部署应用。在file->seting->Plugins下选择下方中间一项:
在这里插入图片描述

右侧会有一个install的按钮,我之前安装过了就是这个样子:
在这里插入图片描述
安装完后会有这样一个图标:
在这里插入图片描述
在usb接到手机之后点击这个图标,出现如下,点击右侧的CONNECT即可:
在这里插入图片描述
变成这样就说明链接成功,就可以拔掉usb线了:
在这里插入图片描述
最新demo加入了CH340支持。

这篇关于Android AS下的OTG串口设备读写的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1093210

相关文章

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

C++读写word文档(.docx)DuckX库的使用详解

《C++读写word文档(.docx)DuckX库的使用详解》DuckX是C++库,用于创建/编辑.docx文件,支持读取文档、添加段落/片段、编辑表格,解决中文乱码需更改编码方案,进阶功能含文本替换... 目录一、基本用法1. 读取文档3. 添加段落4. 添加片段3. 编辑表格二、进阶用法1. 文本替换2

录音功能在哪里? 电脑手机等设备打开录音功能的技巧

《录音功能在哪里?电脑手机等设备打开录音功能的技巧》很多时候我们需要使用录音功能,电脑和手机这些常用设备怎么使用录音功能呢?下面我们就来看看详细的教程... 我们在会议讨论、采访记录、课堂学习、灵感创作、法律取证、重要对话时,都可能有录音需求,便于留存关键信息。下面分享一下如何在电脑端和手机端上找到录音功能

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

在Android中使用WebView在线查看PDF文件的方法示例

《在Android中使用WebView在线查看PDF文件的方法示例》在Android应用开发中,有时我们需要在客户端展示PDF文件,以便用户可以阅读或交互,:本文主要介绍在Android中使用We... 目录简介:1. WebView组件介绍2. 在androidManifest.XML中添加Interne

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

MySQL中读写分离方案对比分析与选型建议

《MySQL中读写分离方案对比分析与选型建议》MySQL读写分离是提升数据库可用性和性能的常见手段,本文将围绕现实生产环境中常见的几种读写分离模式进行系统对比,希望对大家有所帮助... 目录一、问题背景介绍二、多种解决方案对比2.1 原生mysql主从复制2.2 Proxy层中间件:ProxySQL2.3

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.