前提・実現したいこと
タブレット(セントラル)・ウォッチ(ペリフェラル)間でBLE通信を行うプログラムを作成しています。
ペリフェラル側で新規にUUIDを作成し、作成したUUIDをもとにサービスを作成します。
セントラル側で、アドバタイズから取得できる
・端末名
・MACアドレス
・サービスのUUID
をもとに画面上にリスト表示し、選択した端末に接続します。
発生している問題・エラーメッセージ
エラーはありません。
ペリフェラル側では、サービスが作成されていることは確認済みです。
セントラル側では、アドバタイズをスキャンし、アドバタイズから取得できる
サービスのUUIDをもとに、サービスを取得しますが、
nullで取得されます。
新規にアプリをいれたときはサービスをうまく取得できますが、
2回目以降からサービスがnullとなります。
また、1回目のサービスは2回目以降でもうまくサービスを取得します。
UUIDがコロコロ変わることがダメなのでしょうか。
仕様的にUUIDは固定でなくても、相互で同じUUIDを認識していれば大丈夫だと考えています。
ペリフェラル側
java
1public class MainWearActivity extends WearableActivity implements View.OnClickListener { 2 3 BluetoothGattServer mBtGattServer = null; 4 BluetoothGattCharacteristic mBtCharacteristic = null; 5 BluetoothDevice mDevice = null; 6 BluetoothManager mBleManager = null; 7 BluetoothAdapter mBleAdapter = null; 8 BluetoothLeAdvertiser mBtAdvertiser = null; 9 private Handler handler = new Handler(); 10 private String WEAR_UUID = ""; 11 12 /** 13 * アドバタイズ開始 14 */ 15 private void start() { 16 17 /** bluetooth使用準備 */ 18 mBleManager = (BluetoothManager) getSystemService(Context.BLUETOOTH_SERVICE); 19 mBleAdapter = mBleManager.getAdapter(); 20 21 WEAR_UUID = UUID.randomUUID().toString(); 22 Log.d(LOG_TAG_DATA, "今回のUUID:" + WEAR_UUID); 23 24 // BLEでのデータのやり取りで使用する、ServiceとCharacteristicの準備. 25 BluetoothGattService btGattService = new BluetoothGattService((UUID.fromString(WEAR_UUID)), BluetoothGattService.SERVICE_TYPE_PRIMARY); 26 27 // CentralからWrite・Read・Notificationができるようにする. 28 mBtCharacteristic = new BluetoothGattCharacteristic(UUID.fromString(CUSTOM_CHARACTERSTIC_UUID) 29 ,BluetoothGattCharacteristic.PROPERTY_NOTIFY | BluetoothGattCharacteristic.PROPERTY_READ | BluetoothGattCharacteristic.PROPERTY_WRITE 30 , BluetoothGattDescriptor.PERMISSION_WRITE | BluetoothGattCharacteristic.PERMISSION_READ); 31 boolean resultC = btGattService.addCharacteristic(mBtCharacteristic); 32 Log.d(LOG_TAG_DATA, "set addCharacteristic : " + resultC); 33 34 // Notificationのやり取りで使用するDescriptorの準備. 35 BluetoothGattDescriptor dataDescriptor = new BluetoothGattDescriptor( 36 UUID.fromString(ANDROID_CENTRAL_UUID) 37 ,BluetoothGattDescriptor.PERMISSION_WRITE | BluetoothGattDescriptor.PERMISSION_READ); 38 boolean resultD = mBtCharacteristic.addDescriptor(dataDescriptor); 39 Log.d(LOG_TAG_DATA, "set addDescriptor : " + resultD); 40 41 // やりとりするデータを管理するサーバを開き、サービスを追加する. 42 mBtGattServer = mBleManager.openGattServer(this, mGattServerCallback); 43 boolean resultS = mBtGattServer.addService(btGattService); 44 Log.d(LOG_TAG_DATA, "set addService : " + resultS); 45 } 46 47 /** 48 * アドバタイズ開始 49 */ 50 private void startAdvertiser() { 51 52 mBtAdvertiser = null; 53 mDevice = null; 54 55 /** アドバタイズ設定 */ 56 mBtAdvertiser = mBleAdapter.getBluetoothLeAdvertiser(); 57 if (mBtAdvertiser != null) { 58 59 // Advertisingの設定. 60 AdvertiseData dataBuilder = new AdvertiseData.Builder() 61 .setIncludeTxPowerLevel(false) 62 .addServiceUuid(ParcelUuid.fromString(WEAR_UUID)) 63 .build(); 64 AdvertiseSettings settingsBuilder = new AdvertiseSettings.Builder() 65 .setAdvertiseMode(AdvertiseSettings.ADVERTISE_MODE_LOW_LATENCY) 66 .setConnectable(true) 67 .setTxPowerLevel(AdvertiseSettings.ADVERTISE_TX_POWER_HIGH) 68 .build(); 69 // Central側から発見・接続できるようにするためのAdvertisingの開始. 70 mBtAdvertiser.startAdvertising(settingsBuilder, dataBuilder, mAdvertiseCallback); 71 } 72 } 73 74 /** 75 * アドバタイズコールバック 76 */ 77 private AdvertiseCallback mAdvertiseCallback = new AdvertiseCallback() { 78 @Override 79 public void onStartSuccess(AdvertiseSettings settingsInEffect) { 80 Log.d(LOG_TAG_DATA, "-----------------アドバタイズ開始"); 81 } 82 @Override 83 public void onStartFailure(int errorCode) { 84 Log.d(LOG_TAG_DATA, "----------------アドバタイズ失敗:" + errorCode); 85 } 86 }; 87 88 /** コールバック作成 */ 89 private BluetoothGattServerCallback mGattServerCallback = new BluetoothGattServerCallback() { 90 91 @Override 92 public void onConnectionStateChange(BluetoothDevice device, int status, int newState) { 93 if(newState == BluetoothProfile.STATE_CONNECTED){ 94 mDevice = device; 95 Log.d(LOG_TAG_DATA, "----------------接続完了"); 96 } 97 else{ 98 Log.d(LOG_TAG_DATA, "-------------接続解除"); 99 mDevice = null; 100 } 101 } 102 103 /** サービスが正常に追加されたか */ 104 @Override 105 public void onServiceAdded(int status, BluetoothGattService service) { 106 super.onServiceAdded(status, service); 107 Log.d(LOG_TAG_DATA, "--------onServiceAdded"); 108 Log.d(LOG_TAG_DATA, "BluetoothGattService.UUID : " + service.getUuid()); 109 List<BluetoothGattCharacteristic> tmpList = service.getCharacteristics(); 110 /** アドバタイズ開始 */ 111 startAdvertiser(); 112 } 113 }; 114} 115
試したこと
ログを出しつつ、動作確認しましたが、よくわかりませんでした。
ペリフェラル側ではサービスは作成できているようです。
補足情報(FW/ツールのバージョンなど)
セントラル:AndroidOS 7
ペリフェラル:WearOS 2.0
あなたの回答
tips
プレビュー