web-dev-qa-db-ja.com

USBデバイスと通信するには?

ホストとしてUSB通信を確立しようとしています。私はここの例 http://developer.Android.com/guide/topics/usb/Host.html に従っていますが、これを機能させることができません。これが私のコードです:

_private static final String ACTION_USB_PERMISSION = "com.multitools.andres.LCView";
    UsbDevice device;
    //Pide permisos al usuario para comunicacion con el dispositivo USB
    private final BroadcastReceiver mUsbReceiver = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {
            String action = intent.getAction();
            if (ACTION_USB_PERMISSION.equals(action)) {
                synchronized (this) {
                    UsbDevice device = (UsbDevice)intent.getParcelableExtra(UsbManager.EXTRA_DEVICE);
                    if (intent.getBooleanExtra(UsbManager.EXTRA_PERMISSION_GRANTED, false)) {
                        if(device != null){
                            //call method to set up device communication
                        }
                    } 
                    else {
                        Log.d(TAG, "permission denied for device " + device);
                    }
                }
            }
        }
    };

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        if(DEBUG) Log.i(TAG, "onCreate() -> MainMenu");

        actionBar = getActionBar();                     //obtengo el ActionBar
        actionBar.setDisplayHomeAsUpEnabled(true);      //el icono de la aplicacion funciona como boton HOME
        //Menu
        setListAdapter(new ArrayAdapter<String>(MainMenu.this, Android.R.layout.simple_list_item_1, MenuNames));

        //USB
        if(DEBUG) Log.i(TAG, "Setting UsbManager -> MainMenu");
        UsbManager mUsbManager = (UsbManager) getSystemService(Context.USB_SERVICE);
        PendingIntent mPermissionIntent;

        if(DEBUG) Log.i(TAG, "Setting PermissionIntent -> MainMenu");
        mPermissionIntent = PendingIntent.getBroadcast(this, 0, new Intent(ACTION_USB_PERMISSION), 0);
        if(DEBUG) Log.i(TAG, "Setting IntentFilter -> MainMenu");
        IntentFilter filter = new IntentFilter(ACTION_USB_PERMISSION);
        if(DEBUG) Log.i(TAG, "Setting registerReceiver -> MainMenu");
        registerReceiver(mUsbReceiver, filter);
        if(DEBUG) Log.i(TAG, "Setting requestPermission -> MainMenu");
        mUsbManager.requestPermission(device, mPermissionIntent);

    }
_

mUsbManager.requestPermission(device, mPermissionIntent);のコメントを外すと、強制的に閉じるダイアログが表示されます。コメントを付けると、強制的に閉じることができませんが、機能しません。私は問題があると思います:

_private static final String ACTION_USB_PERMISSION = "com.multitools.andres.LCView";
_

Googleの例では、次のようになります。

_private static final String ACTION_USB_PERMISSION = "com.Android.example.USB_PERMISSION";
_

しかし、私はそこに何を入れなければならないのか正確にはわかりません。それについての説明も見つかりませんでした。私はそこに何を入れなければならないのですか、または私のエラーはどこにありますか?これは、アプリケーションを起動したときに取得するLogCatです。

_04-17 00:57:50.944: I/dalvikvm(1362): threadid=3: reacting to signal 3
04-17 00:57:51.331: I/dalvikvm(1362): Wrote stack traces to '/data/anr/traces.txt'
04-17 00:57:51.981: I/(1362): onCreate() -> MainMenu
04-17 00:57:52.013: I/dalvikvm(1362): threadid=3: reacting to signal 3
04-17 00:57:52.151: I/dalvikvm(1362): Wrote stack traces to '/data/anr/traces.txt'
04-17 00:57:52.570: I/dalvikvm(1362): threadid=3: reacting to signal 3
04-17 00:57:52.731: I/dalvikvm(1362): Wrote stack traces to '/data/anr/traces.txt'
04-17 00:57:53.122: I/dalvikvm(1362): threadid=3: reacting to signal 3
04-17 00:57:53.231: I/dalvikvm(1362): Wrote stack traces to '/data/anr/traces.txt'
04-17 00:57:53.390: I/(1362): Setting UsbManager -> MainMenu
04-17 00:57:53.451: I/(1362): Setting PermissionIntent -> MainMenu
04-17 00:57:53.470: I/(1362): Setting IntentFilter -> MainMenu
04-17 00:57:53.470: I/(1362): Setting registerReceiver -> MainMenu
04-17 00:57:53.511: I/(1362): Setting requestPermission -> MainMenu
04-17 00:57:53.660: I/dalvikvm(1362): threadid=3: reacting to signal 3
04-17 00:57:53.791: I/dalvikvm(1362): Wrote stack traces to '/data/anr/traces.txt'
04-17 00:57:54.311: I/dalvikvm(1362): threadid=3: reacting to signal 3
04-17 00:57:54.401: I/dalvikvm(1362): Wrote stack traces to '/data/anr/traces.txt'
04-17 00:57:54.531: I/(1362): onCreateOptionsMenu() -> MainMenu
04-17 00:57:54.683: I/dalvikvm(1362): threadid=3: reacting to signal 3
04-17 00:57:54.772: I/dalvikvm(1362): Wrote stack traces to '/data/anr/traces.txt'
04-17 00:57:55.186: I/dalvikvm(1362): threadid=3: reacting to signal 3
04-17 00:57:55.291: I/dalvikvm(1362): Wrote stack traces to '/data/anr/traces.txt'
04-17 00:57:55.661: I/dalvikvm(1362): threadid=3: reacting to signal 3
04-17 00:57:55.751: I/dalvikvm(1362): Wrote stack traces to '/data/anr/traces.txt'
04-17 00:57:55.791: D/gralloc_goldfish(1362): Emulator without GPU emulation detected.
04-17 01:11:47.323: I/dalvikvm(1459): threadid=3: reacting to signal 3
04-17 01:11:47.720: I/dalvikvm(1459): Wrote stack traces to '/data/anr/traces.txt'
04-17 01:11:48.124: I/dalvikvm(1459): threadid=3: reacting to signal 3
04-17 01:11:48.291: I/dalvikvm(1459): Wrote stack traces to '/data/anr/traces.txt'
04-17 01:11:48.452: I/(1459): onCreate() -> MainMenu
04-17 01:11:48.691: I/dalvikvm(1459): threadid=3: reacting to signal 3
04-17 01:11:48.813: I/dalvikvm(1459): Wrote stack traces to '/data/anr/traces.txt'
04-17 01:11:49.172: I/dalvikvm(1459): threadid=3: reacting to signal 3
04-17 01:11:49.321: I/dalvikvm(1459): Wrote stack traces to '/data/anr/traces.txt'
04-17 01:11:49.653: I/dalvikvm(1459): threadid=3: reacting to signal 3
04-17 01:11:49.821: I/dalvikvm(1459): Wrote stack traces to '/data/anr/traces.txt'
04-17 01:11:49.901: I/(1459): Setting UsbManager -> MainMenu
04-17 01:11:49.931: I/(1459): Setting PermissionIntent -> MainMenu
04-17 01:11:50.021: I/(1459): Setting IntentFilter -> MainMenu
04-17 01:11:50.031: I/(1459): Setting registerReceiver -> MainMenu
04-17 01:11:50.051: I/(1459): Setting requestPermission -> MainMenu
04-17 01:11:50.071: D/AndroidRuntime(1459): Shutting down VM
04-17 01:11:50.133: W/dalvikvm(1459): threadid=1: thread exiting with uncaught exception (group=0x409c01f8)
04-17 01:11:50.231: I/dalvikvm(1459): threadid=3: reacting to signal 3
04-17 01:11:50.331: I/dalvikvm(1459): Wrote stack traces to '/data/anr/traces.txt'
04-17 01:11:50.401: E/AndroidRuntime(1459): FATAL EXCEPTION: main
04-17 01:11:50.401: E/AndroidRuntime(1459): Java.lang.RuntimeException: Unable to start activity ComponentInfo{com.multitools.andres/com.multitools.andres.MainMenu}: Java.lang.NullPointerException
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.app.ActivityThread.performLaunchActivity(ActivityThread.Java:1956)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.app.ActivityThread.handleLaunchActivity(ActivityThread.Java:1981)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.app.ActivityThread.access$600(ActivityThread.Java:123)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.app.ActivityThread$H.handleMessage(ActivityThread.Java:1147)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.os.Handler.dispatchMessage(Handler.Java:99)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.os.Looper.loop(Looper.Java:137)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.app.ActivityThread.main(ActivityThread.Java:4424)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Java.lang.reflect.Method.invokeNative(Native Method)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Java.lang.reflect.Method.invoke(Method.Java:511)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.Java:784)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:551)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at dalvik.system.NativeStart.main(Native Method)
04-17 01:11:50.401: E/AndroidRuntime(1459): Caused by: Java.lang.NullPointerException
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.os.Parcel.readException(Parcel.Java:1333)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.os.Parcel.readException(Parcel.Java:1281)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.hardware.usb.IUsbManager$Stub$Proxy.requestDevicePermission(IUsbManager.Java:535)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.hardware.usb.UsbManager.requestPermission(UsbManager.Java:361)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at com.multitools.andres.MainMenu.onCreate(MainMenu.Java:80)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.app.Activity.performCreate(Activity.Java:4465)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.app.Instrumentation.callActivityOnCreate(Instrumentation.Java:1049)
04-17 01:11:50.401: E/AndroidRuntime(1459):     at Android.app.ActivityThread.performLaunchActivity(ActivityThread.Java:1920)
04-17 01:11:50.401: E/AndroidRuntime(1459):     ... 11 more
04-17 01:11:50.751: I/dalvikvm(1459): threadid=3: reacting to signal 3
04-17 01:11:50.851: I/dalvikvm(1459): Wrote stack traces to '/data/anr/traces.txt'
04-17 01:11:51.331: I/dalvikvm(1459): threadid=3: reacting to signal 3
04-17 01:11:51.403: I/dalvikvm(1459): Wrote stack traces to '/data/anr/traces.txt'
04-17 01:11:51.774: I/dalvikvm(1459): threadid=3: reacting to signal 3
04-17 01:11:51.961: I/dalvikvm(1459): Wrote stack traces to '/data/anr/traces.txt'
_

ありがとうございます :)

14
Andres

その文字列は単なるマーカーなので、registerReceiver(mUsbReceiver, filter);を呼び出したときに返される意図を認識できます。それは問題ではありません。

私は問題がここにあると思います:

UsbManager mUsbManager = (UsbManager) getSystemService(Context.USB_SERVICE);

この行はあなたのUSBマネージャーを取得するはずですが、私が覚えている限り、すべての電話がAndroid USB Accessory APIをサポートする必要があるわけではありません。この行はおそらくnullmUsbManagerにすると、コードのさらに下の方でメソッドを呼び出すときにNullPointerExceptionになります。呼び出しを行う前に、それがnullでないかどうかを確認してください。

詳細については、次のリンクをご覧ください。

  1. http://developer.Android.com/guide/topics/usb/index.html
  2. http://developer.Android.com/guide/topics/usb/accessory.html

編集:

私は今問題が何であるかを理解していると思います。そうです、USBマネージャーではありません。これは、UsbDeviceオブジェクト(device)です。コードのどこでも初期化されることはありません。この行では:

mUsbManager.requestPermission(device, mPermissionIntent);

あなたは基本的に、UsbDeviceオブジェクトdeviceで表されるデバイスで作業してもよいかどうかをユーザーに尋ねる意図を発動しています。ただし、この呼び出しが発生したとき、deviceはまだ初期化されていません(したがって、デフォルト値はnullです)。したがって、許可を要求しようとすると、予期した結果の代わりにNullPointerExceptionを取得することになります。これを修正するには、接続するデバイスを特定して、deviceに割り当てる必要があります。 「デバイスの列挙」の下にある ここ を見て、さまざまな方法を見つけます。接続するデバイスの名前がわかっている場合の1つの方法は、USBマネージャーを取得した後で次の呼び出しを行うことです。

HashMap<String, UsbDevice> deviceList = mUsbManager.getDeviceList();
device = deviceList.get("<deviceName>");

(明らかに、<deviceName>は、デバイスの実際の名前です。

18
chandsie

minSdkVersionは12以上でなければなりません

USBホストAPIサポートを有効にするには、Android.hardware.usb.Host.xmlという名前のファイルを追加し、次の行を含めます。

<permissions>
 <feature name="Android.hardware.usb.Host"/>
3
dajun