Android Bluetooth в представлении вкладок вызывает ошибку закрытия - PullRequest
0 голосов
/ 08 мая 2011

Я использую приложение для определения местоположения на основе GPS.

Я использую tabview, где на первой вкладке есть карта и GPS, а на второй вкладке Bluetooth-соединение.

В эмуляторе первая вкладка работает нормально, а вторую вкладку я не могу проверить.

Когда я запускаю его на устройстве Android, приложение закрывается, и я получаю эту ошибку, и я не могу понять, что не так с приложением.

Любая помощь будет очень ценится,

`06-05 23:31:36.961: ERROR/AndroidRuntime(3889): FATAL EXCEPTION: main

 06-05 23:31:36.961: ERROR/AndroidRuntime(3889): java.lang.NoSuchMethodError:        android.bluetooth.BluetoothAdapter.listenUsingInsecureRfcommWithServiceRecord

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at trail.com.BluetoothChatService$AcceptThread.<init>(BluetoothChatService.java:280)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at trail.com.BluetoothChatService.start(BluetoothChatService.java:119)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at trail.com.BluetoothChat.onResume(BluetoothChat.java:144)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1149)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.Activity.performResume(Activity.java:3823)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3124)
06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:170)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.LocalActivityManager.dispatchResume(LocalActivityManager.java:518)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.ActivityGroup.onResume(ActivityGroup.java:58)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1149)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.Activity.performResume(Activity.java:3823)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3124)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3149)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2064)
06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.os.Handler.dispatchMessage(Handler.java:99)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.os.Looper.loop(Looper.java:123)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at android.app.ActivityThread.main(ActivityThread.java:4633)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at java.lang.reflect.Method.invokeNative(Native Method)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at java.lang.reflect.Method.invoke(Method.java:521)

06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
06-05 23:31:36.961: ERROR/AndroidRuntime(3889):     at dalvik.system.NativeStart.main(Native Method)

06-05 23:31:36.971: ERROR/RequestQueueHelper(3939): [Thread-10/10] Next pending job not found!!

Я звоню listenUsingInsecureRfcommWithServiceRecord по следующей части:

public AcceptThread(boolean secure) {
        BluetoothServerSocket tmp = null;
        mSocketType = secure ? "Secure":"Insecure";

        // Create a new listening server socket
        try {
            if (secure) {
                tmp = mAdapter.listenUsingRfcommWithServiceRecord(NAME_SECURE,
                    MY_UUID_SECURE);
            } else {
                tmp = mAdapter.listenUsingInsecureRfcommWithServiceRecord(
                        NAME_INSECURE, MY_UUID_INSECURE);
            }
        } catch (IOException e) {
            Log.e(TAG, "Socket Type: " + mSocketType + "listen() failed", e);
        }
        mmServerSocket = tmp;
    }

1 Ответ

0 голосов
/ 03 декабря 2012

возможным решением является применение блока try-catch и попытка запуска приложения.

try{
public AcceptThread(boolean secure) { BluetoothServerSocket tmp = null; mSocketType = secure ? "Secure":"Insecure";
}
catch(Exception e){
e.printStackTrace();
}

Также проверьте версию ОС устройства, которое у вас есть ...

Это фатальное исключение происходитиз-за причины, по которой версия вашего устройства ниже, а метод отсутствует в ПЗУ устройства.

...