Android USB 通信开发

Android USB 通信开发主要涉及两种模式:主机模式(Host Mode)和配件模式(Accessory Mode)。以下是开发USB通信应用的关键知识点和步骤。

1. 基本概念

主机模式(Host Mode)

  • Android设备作为USB主机,控制连接的USB设备

  • 需要设备支持USB主机功能(通常需要OTG支持)

配件模式(Accessory Mode)

  • Android设备作为USB配件被其他主机控制

  • 需要设备支持USB配件模式

2. 开发准备

清单文件配置

XML 复制代码
<!-- 声明USB主机功能 -->
<uses-feature android:name="android.hardware.usb.host" />

<!-- 声明USB配件功能(如果需要) -->
<uses-feature android:name="android.hardware.usb.accessory" />

<!-- 添加必要的权限 -->
<uses-permission android:name="android.permission.USB_PERMISSION" />

3. USB主机模式开发

发现连接的USB设备

java 复制代码
UsbManager usbManager = (UsbManager) getSystemService(Context.USB_SERVICE);
HashMap<String, UsbDevice> deviceList = usbManager.getDeviceList();

请求设备权限

java 复制代码
private static final String ACTION_USB_PERMISSION = "com.example.USB_PERMISSION";

PendingIntent permissionIntent = PendingIntent.getBroadcast(this, 0, 
    new Intent(ACTION_USB_PERMISSION), PendingIntent.FLAG_IMMUTABLE);

IntentFilter filter = new IntentFilter(ACTION_USB_PERMISSION);
registerReceiver(usbReceiver, filter);

usbManager.requestPermission(device, permissionIntent);

广播接收器处理权限结果

java 复制代码
private final BroadcastReceiver usbReceiver = new BroadcastReceiver() {
    public void onReceive(Context context, Intent intent) {
        String action = intent.getAction();
        if (ACTION_USB_PERMISSION.equals(action)) {
            synchronized (this) {
                UsbDevice device = intent.getParcelableExtra(UsbManager.EXTRA_DEVICE);
                if (intent.getBooleanExtra(UsbManager.EXTRA_PERMISSION_GRANTED, false)) {
                    if(device != null){
                        // 权限已授予,可以通信
                        openDevice(device);
                    }
                } else {
                    Log.d(TAG, "权限被拒绝 for device " + device);
                }
            }
        }
    }
};

打开设备并通信

java 复制代码
private void openDevice(UsbDevice device) {
    UsbInterface intf = device.getInterface(0);
    UsbEndpoint endpoint = intf.getEndpoint(0);
    
    UsbDeviceConnection connection = usbManager.openDevice(device);
    if (connection == null) return;
    
    connection.claimInterface(intf, true);
    
    // 发送数据
    byte[] sendData = "Hello".getBytes();
    int sent = connection.bulkTransfer(endpoint, sendData, sendData.length, 0);
    
    // 接收数据
    byte[] receiveData = new byte[64];
    int received = connection.bulkTransfer(endpoint, receiveData, receiveData.length, 0);
}

4. USB配件模式开发

清单文件配置

java 复制代码
<activity ...>
    <intent-filter>
        <action android:name="android.hardware.usb.action.USB_ACCESSORY_ATTACHED" />
    </intent-filter>
    <meta-data 
        android:name="android.hardware.usb.action.USB_ACCESSORY_ATTACHED"
        android:resource="@xml/accessory_filter" />
</activity>

配件过滤器(xml/accessory_filter.xml)

XML 复制代码
<resources>
    <usb-accessory 
        manufacturer="YourCompany" 
        model="YourModel" 
        version="1.0" />
</resources>

检测配件连接

java 复制代码
UsbManager usbManager = (UsbManager) getSystemService(Context.USB_SERVICE);
UsbAccessory[] accessoryList = usbManager.getAccessoryList();

if (accessoryList != null && accessoryList.length > 0) {
    UsbAccessory accessory = accessoryList[0];
    openAccessory(accessory);
}

打开配件通信

java 复制代码
private void openAccessory(UsbAccessory accessory) {
    ParcelFileDescriptor fd = usbManager.openAccessory(accessory);
    if (fd != null) {
        FileDescriptor fileDescriptor = fd.getFileDescriptor();
        FileInputStream inputStream = new FileInputStream(fileDescriptor);
        FileOutputStream outputStream = new FileOutputStream(fileDescriptor);
        
        // 现在可以通过输入输出流进行通信
    }
}

5. 常见问题

  1. 权限问题:确保正确请求和处理USB权限

  2. 设备兼容性:并非所有Android设备都支持USB主机模式

  3. 线程阻塞:USB通信可能阻塞UI线程,建议在后台线程进行

  4. 连接稳定性:处理USB设备插拔事件

6. 高级主题

  • USB串口通信:使用CDC(Communication Device Class)协议

  • HID设备通信:与键盘、鼠标等HID设备交互

  • 同步通信:使用控制传输(Control Transfer)和中断传输(Interrupt Transfer)

7. 推荐库

开发时请参考Android官方USB文档获取最新信息。

相关推荐
曳渔6 分钟前
UDP/TCP套接字编程简单实战指南
java·开发语言·网络·网络协议·tcp/ip·udp
Wgllss15 分钟前
雷电雨效果:Kotlin+Compose+协程+Flow 实现天气UI
android·架构·android jetpack
hqxstudying38 分钟前
JAVA项目中邮件发送功能
java·开发语言·python·邮件
最初的↘那颗心41 分钟前
Java HashMap深度解析:原理、实现与最佳实践
java·开发语言·面试·hashmap·八股文
小兔兔吃萝卜1 小时前
Spring 创建 Bean 的 8 种主要方式
java·后端·spring
亲爱的马哥1 小时前
重磅更新 | 填鸭表单TDuckX2.9发布!
java
Java中文社群1 小时前
26届双非上岸记!快手之战~
java·后端·面试
whitepure1 小时前
万字详解Java中的面向对象(二)——设计模式
java·设计模式
whitepure1 小时前
万字详解Java中的面向对象(一)——设计原则
java·后端
2301_793086872 小时前
SpringCloud 02 服务治理 Nacos
java·spring boot·spring cloud