Android开发之USB数据通信

2024-04-23 01:08

本文主要是介绍Android开发之USB数据通信,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Android开发中USB串口通信开发主要涉及到以下几个类及相应的方法:
1 ,UsbManager:负责管理USB设备的类,你可以在相应代码中通过以下方法获得

//获取UsbManager实例方法
UsbManager manager = (UsbManager) getSystemService(Context.USB_SERVICE);

该类提供的主要方法有:
1) getDeviceList()
获得设备列表,返回的是一个HashMap.;
2) hasPermission(UsbDevice device)
判断你的应用程序是否有接入此USB设备的权限,如果有则返回真,否则返回false.
3) openDevice(UsbDevice device)
打开USB设备,以便向此USB设备发送和接受数据,返回一个关于此USB设备的连接。
4) requestPermission(UsbDevice device, PendingIntent pi)
向USB设备请求临时的接入权限。

2,UsbDevice:一个USB设备对象,每个设备一般包括一个接口,也可能有多个,每个接口又包含节点用来与此设备传输数据。主要方法有:
1) getDeviceClass()
返回此USB设备的类别,用一个整型来表示。
2) getDeviceId()
返回唯一标识此设备的ID号,也用一个整型来表示。
3) getDeviceName()
返回此设备的名称,用一个字符串来表示。
4) getDeviceProtocol()
返回此设备的协议类别,用一个整型来表示。
5) getDeviceSubclass()
返回此设备的子类别,用一个整型来表示。
6) getVendorId()
返回生产商ID
7) getProductId()
返回产品ID
8) getInterfaceCount()
返回此设备的接口数量
9) getInterface(int index)
得到此设备的一个接口,返回一个UsbInterface。

3,UsbInterface:代表USB设备的一个接口(物理接口),UsbInterface本身是一个类,此类的主要方法有以下:
1) getId()
得到给接口的id号。
2) getInterfaceClass()
得到该接口的类别。
3) getInterfaceSubclass()
得到该接口的子类。
4) getInterfaceProtocol()
得到该接口的协议类别。
5) getEndpointCount()
获得关于此接口的节点数量。
6) getEndpoint(int index)
对于指定的index获得此接口的一个节点,返回一个UsbEndpoint.
4, UsbEndpoint:代表一个接口的某个节点的类。该类主要方法:
1) getAddress()
获得此节点的地址
2) getAttributes()
获得此节点的属性
3) getDirection()
获得此节点的数据传输方向
5 ,UsbDeviceConnection:代表USB连接的一个类。用此连接可以想USB设备发送和接收数据,主要方法有:
1)bulkTransfer(UsbEndpoint endpoint, byte[] buffer, int length, int timeout)
通过给定的endpoint来进行大量的数据传输,传输的方向取决于该节点的方向,buffer是要发送或接收的字节数组,length是该字节数组的长度。传输成功则返回所传输的字节数组的长度,失败则返回负数。
2)controlTransfer(int requestType, int request, int value, int index, byte[] buffer, int length, int timeout)
该方法通过0节点向此设备传输数据,传输的方向取决于请求的类别,如果requestType为USB_DIR_OUT则为写数据,USB_DIR_IN, 则为读数据
以上介绍资料主要来自博文: http://www.osedu.net/article/linux/2014-04-16/678.html。

—-示例代码——

public class UsbTestActivity extends Activity implements View.OnClickListener {//设备列表private HashMap<String, UsbDevice> deviceList;//从设备读数据private Button read_btn;//给设备写数据(发指令)private Button write_btn;//USB管理器:负责管理USB设备的类private UsbManager manager;//找到的USB设备private UsbDevice mUsbDevice;//代表USB设备的一个接口private UsbInterface mInterface;private UsbDeviceConnection mDeviceConnection;//代表一个接口的某个节点的类:写数据节点private UsbEndpoint usbEpOut;//代表一个接口的某个节点的类:读数据节点private UsbEndpoint usbEpIn;//要发送信息字节private byte[] sendbytes;//接收到的信息字节private byte[] receiveytes;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_usb);initUsbData();initViews();}private void initUsbData() {// 获取USB设备manager = (UsbManager) getSystemService(Context.USB_SERVICE);//获取到设备列表deviceList = manager.getDeviceList();Iterator<UsbDevice> deviceIterator = deviceList.values().iterator();while (deviceIterator.hasNext()) {Log.e("ldm", "vid=" + usb.getVendorId() + "---pid=" + usb.getProductId());//if (mVendorID == usb.getVendorId() && mProductID == usb.getProductId()) {//找到指定设备mUsbDevice = deviceIterator.next();}// }}//获取设备接口for (int i = 0; i < mUsbDevice.getInterfaceCount(); ) {// 一般来说一个设备都是一个接口,你可以通过getInterfaceCount()查看接口的个数// 这个接口上有两个端点,分别对应OUT 和 INUsbInterface usbInterface = mUsbDevice.getInterface(i);mInterface = usbInterface;break;}//用UsbDeviceConnection 与 UsbInterface 进行端点设置和通讯if (mInterface.getEndpoint(1) != null) {usbEpOut = mInterface.getEndpoint(1);}if (mInterface.getEndpoint(0) != null) {usbEpIn = mInterface.getEndpoint(0);}if (mInterface != null) {// 判断是否有权限if (manager.hasPermission(mUsbDevice)) {// 打开设备,获取 UsbDeviceConnection 对象,连接设备,用于后面的通讯mDeviceConnection = manager.openDevice(mUsbDevice);if (mDeviceConnection == null) {return;}if (mDeviceConnection.claimInterface(mInterface, true)) {showTmsg("找到设备接口");} else {mDeviceConnection.close();}} else {showTmsg("没有权限");}} else {showTmsg("没有找到设备接口!");}}private void initViews() {this.read_btn = (Button) findViewById(R.id.read_btn);this.write_btn = (Button) findViewById(R.id.write_btn);this.read_btn.setOnClickListener(this);this.write_btn.setOnClickListener(this);}@Overridepublic void onClick(View view) {switch (view.getId()) {case R.id.write_btn:sendToUsb("按照规则给设备发指令!");break;case R.id.read_btn:readFromUsb();break;}}private void sendToUsb(String content) {sendbytes = content.getBytes();int ret = -1;// 发送准备命令ret = mDeviceConnection.bulkTransfer(usbEpOut, sendbytes, sendbytes.length, 5000);showTmsg("指令已经发送!");// 接收发送成功信息(相当于读取设备数据)receiveytes = new byte[128];   //根据设备实际情况写数据大小ret = mDeviceConnection.bulkTransfer(usbEpIn, receiveytes, receiveytes.length, 10000);
//        result_tv.setText(String.valueOf(ret));Toast.makeText(this, String.valueOf(ret), Toast.LENGTH_SHORT).show();}private void readFromUsb() {//读取数据2int outMax = usbEpOut.getMaxPacketSize();int inMax = usbEpIn.getMaxPacketSize();ByteBuffer byteBuffer = ByteBuffer.allocate(inMax);UsbRequest usbRequest = new UsbRequest();usbRequest.initialize(mDeviceConnection, usbEpIn);usbRequest.queue(byteBuffer, inMax);if (mDeviceConnection.requestWait() == usbRequest) {byte[] retData = byteBuffer.array();try {showTmsg("收到数据:" + new String(retData, "UTF-8"));} catch (UnsupportedEncodingException e) {e.printStackTrace();}}}//文字提示方法private void showTmsg(String msg) {Toast.makeText(UsbTestActivity.this, msg, Toast.LENGTH_SHORT).show();}
}

另外要与USB通信,在开发项目的配置上还需要注意:
1,添加相应权限:

 <uses-permission android:name="android.permission.HARDWARE_TEST" />

2,AndroidManifest.xml中添加uses-feature过滤所有你设备不支持的应用:

 <uses-feature android:name="android.hardware.usb.host" android:required="true"/>

3, SDK必须是12以上的,因为从 Android3.1开始,才正式支持USB Host相应开发。
4,在AndroidManifext.xml中对操作USB对应的Activity配置做修改,添加USB_DEVICE_ATTACHED与:

<activity android:name=".UsbTestActivity"><intent-filter><action android:name="android.hardware.usb.action.USB_DEVICE_ATTACHED" /></intent-filter><!-- 以下这个meta-data是要手工增加上,他是用来过滤你的具体USB设备的,其中的device_filter是个xml文件 --><meta-data
    android:name="android.hardware.usb.action.USB_DEVICE_ATTACHED"android:resource="@xml/device_filter" /></activity>

—–@xml/device_filter—–

<?xml version="1.0" encoding="utf-8"?>
<resources><!-- 以下内容的 vendor-id、product-id就是USB的vid和pid了,填写自己设备对应的数据-><usb-device vendor-id="1155" product-id="22352"/>
</resources>

参考博客:http://www.xuebuyuan.com/702736.html

这篇关于Android开发之USB数据通信的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

使用Go语言开发一个命令行文件管理工具

《使用Go语言开发一个命令行文件管理工具》这篇文章主要为大家详细介绍了如何使用Go语言开发一款命令行文件管理工具,支持批量重命名,删除,创建,移动文件,需要的小伙伴可以了解下... 目录一、工具功能一览二、核心代码解析1. 主程序结构2. 批量重命名3. 批量删除4. 创建文件/目录5. 批量移动三、如何安

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

基于Python开发PPTX压缩工具

《基于Python开发PPTX压缩工具》在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,不便于传输和存储,所以本文将使用Python开发一个PPTX压缩工具,需要的可以了解下... 目录引言全部代码环境准备代码结构代码实现运行结果引言在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要