質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Bluetooth

Bluetoothとは短距離の間でデータを交換するための無線通信規格である。固定・モバイル両方のデバイスから、短波の電波送信を行うことで、高いセキュリティをもつパーソナルエリアネットワーク(PAN)を構築する。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Q&A

1回答

2256閲覧

Android BLEにてonServicesDiscovered()が呼ばれないことがある

saihoooooooo

総合スコア10

Bluetooth

Bluetoothとは短距離の間でデータを交換するための無線通信規格である。固定・モバイル両方のデバイスから、短波の電波送信を行うことで、高いセキュリティをもつパーソナルエリアネットワーク(PAN)を構築する。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

0グッド

2クリップ

投稿2018/11/09 02:49

前提・実現したいこと

BluetoothGatt.discoverServices()を呼んだ後、サービスが発見できないのかどれだけ待ってもBluetoothGattCallback.onServicesDiscovered()が呼ばれないことがあります。

毎回ではなく頻度としては数十回に一回程度で発生します。

接続してから500msほどウェイトを入れたりしても特に効果がないようです。
同じ現象が発生した方いらっしゃいますでしょうか。

該当のソースコード

java

1private final BluetoothGattCallback mGattCallback = new BluetoothGattCallback() { 2 @Override 3 public void onConnectionStateChange(BluetoothGatt gatt, int status, int newState) { 4 if (newState == BluetoothProfile.STATE_CONNECTED) { 5 // あまり意味はない? 6 try { 7 Thread.sleep(500); 8 } catch (InterruptedException e) { 9 e.printStackTrace(); 10 } 11 12 mGatt.discoverServices(); 13 } else if (newState == BluetoothProfile.STATE_DISCONNECTED) { 14 if (mGatt != null) { 15 mGatt.close(); 16 mGatt = null; 17 } 18 } 19 } 20 21 @Override 22 public void onServicesDiscovered(BluetoothGatt gatt, int status) { 23 // 呼ばれない 24 Log.d(TAG, "Service discovered"); 25 26 if (status == BluetoothGatt.GATT_SUCCESS) { 27 mService = mGatt.getService(SERVICE_UUID); 28 } 29 } 30}; 31 32private final ScanCallback mScanCallback = new ScanCallback() { 33 @Override 34 public void onScanResult(int callbackType, ScanResult result) { 35 mGatt = result.getDevice().connectGatt(mContext, false, mGattCallback); 36 } 37};

補足情報

Android6/7/8

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hillacken

2019/01/08 00:01

解決しましたか?
guest

回答1

0

同じような現象で悩んでましたが、以下の条件で今のところ安定しているようです。
①600msのウェイトを入れる(500msでもいいかも)
②メインスレッドで呼ぶ

Java

1new Handler(Looper.getMainLooper()).postDelayed(new Runnable() { 2 @Override 3 public void run() { 4 boolean ans = mBluetoothGatt.discoverServices(); 5 } 6}, 600);

投稿2018/12/02 00:13

marimonohana

総合スコア16

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

saihoooooooo

2018/12/04 01:24

ありがとうございます > ②メインスレッドで呼ぶ この対応を行い100回程度実行しましたが今のところは発生していません 引き続き様子を見たいと思います
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問