Не удается обнаружить USB-подключение на Android

У меня аппарат андроид 5.1.1, кабель OTG и ACS CardReader. Я хочу определить, когда CardReader подключен через кабель OTG. Я могу обнаружить DETACH, но не повезло с ATTACH.

Вот что у меня есть:

Файл манифеста:

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

<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity
        android:name=".MainActivity"
        android:label="@string/app_name"
        android:theme="@style/AppTheme.NoActionBar">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <action android:name="android.hardware.usb.action.USB_DEVICE_ATTACHED" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>

        <meta-data
            android:name="android.hardware.usb.action.USB_DEVICE_ATTACHED"
            android:resource="@xml/device_filter" />
    </activity>
</application>

XML-файл фильтра:

<?xml version="1.0" encoding="utf-8"?>

<resources>
    <!--usb-device vendor-id="1234" product-id="5678" class="255" subclass="66" protocol="1" /-->
    <usb-device />
</resources>

Основная деятельность:

private static final String TAG = MainActivity.class.getSimpleName();

private static final String ACTION_USB_PERMISSION = "com.guness.deleteme.USB_PERMISSION";
private final BroadcastReceiver mUsbReceiver = 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) {
                        //call method to set up device communication
                        Log.e(TAG, "permission granted " + device);
                    }
                } else {
                    Log.e(TAG, "permission denied for device " + device);
                }
            }
        }
    }
};

private PendingIntent mPermissionIntent;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    Log.e(TAG, "onCreate");
    setContentView(R.layout.activity_main);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    mPermissionIntent = PendingIntent.getBroadcast(this, 0, new Intent(ACTION_USB_PERMISSION), 0);
    IntentFilter filter = new IntentFilter(ACTION_USB_PERMISSION);
    registerReceiver(mUsbReceiver, filter);
}

@Override
protected void onResume() {
    super.onResume();
    Log.e(TAG, "onResume");
}

@Override
protected void onNewIntent(Intent intent) {
    super.onNewIntent(intent);
    Log.e(TAG, "onNewIntent");
}

Я еще не спрашивал разрешения, спрошу, когда обнаружат. Независимо от того, что я не вижу ожидаемых журналов.

Хорошо, я проверил мышь и флешку; тоже не может их обнаружить. Android-устройство поддерживает OTG и CardReader; проверил с другими приложениями. Я предполагаю, что у них есть таймер, периодически проверяющий, было ли подключено USB-устройство.


person guness    schedule 06.10.2016    source источник


Ответы (1)


Попробуйте создать фильтр намерений программным способом:

1) удалить

<action android:name="android.hardware.usb.action.USB_DEVICE_ATTACHED" />

а также

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

строки из файла манифеста (также вы можете удалить файл фильтра XML)

2) создать IntentFilter в MainActivity (примерно так):

private static final String TAG = MainActivity.class.getSimpleName();

private final BroadcastReceiver mUsbReceiver = new BroadcastReceiver() {

    public void onReceive(Context context, Intent intent) {
        String action = intent.getAction();
        if (UsbManager.ACTION_USB_DEVICE_ATTACHED.equals(action)) {
            Log.d(TAG, "USB device attached");

        } else if (UsbManager.ACTION_USB_DEVICE_DETACHED.equals(action)) {
            Log.d(TAG, "USB device detached");
        }
    }
};

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    Log.e(TAG, "onCreate");
    setContentView(R.layout.activity_main);

    IntentFilter filter = new IntentFilter();
    filter.addAction(UsbManager.ACTION_USB_DEVICE_ATTACHED);
    filter.addAction(UsbManager.ACTION_USB_DEVICE_DETACHED);
    registerReceiver(mUsbReceiver, filter);
}

3) работа с разрешениями в

UsbManager.ACTION_USB_DEVICE_ATTACHED.equals(action)

кейс.

person Andrii Omelchenko    schedule 11.10.2016
comment
Скоро попробую, но проблема, похоже, в версии Android 5.1.1. - person guness; 12.10.2016
comment
это проблема устройства или версии Android. - person guness; 14.10.2016
comment
Проблема с вашим решением в том, что приемник будет зарегистрирован только при запуске приложения. Это означает, что система Android будет передавать трансляцию в приложение только в том случае, если вы сначала запустите его. Но он не будет слушать в фоновом режиме. - person Radon8472; 07.07.2017
comment
@Radon8472 Согласен, но это можно реализовать, например, в Service с BOOT_COMPLETE. Это просто подход, а не окончательное решение. - person Andrii Omelchenko; 07.07.2017