android ble 中使用connectGatt()进行连接,没有进入onConnectionStateC

移动开发 码拜 8年前 (2016-09-24) 2287次浏览
最近在学习蓝牙 4.0,看了一下与android ble有关的api,在android手机上写了个小程序,与TI CC2540进行通信,扫描到设备之后进行连接,然后传输数据,传输完毕之后断开连接再进行扫描。大致传输7、8次数据之后,手机端再使用connectGatt()进行连接时,无法进入onConnectionStateChange()回调函数,数据接收无法继续,程序好像是死在这了。但是前面几次都是正常的,假如此时在后台关闭该程序再重新打开,就又可以正常接收数据了。不知道怎么回事,求指点!
程序片段及调试记录如下:

private void connect(BluetoothDevice device) {
		if (!isConnected) {
			handler.removeCallbacks(runnable);
			mAdapter.stopLeScan(mLeScanCallback);
			isScaning = false;
			connectCounter = new Counter(5, "connectCounter",
					new CounterTask() {
						@Override
						public void run() {
							search();
							handler.postDelayed(runnable, GattConstants.POST_PERIOD);
						}
					});
			connectCounter.start();
			bluetoothGatt = device.connectGatt(context, true, gattCallback);
			Log.d(BLUETOOTH_INFO, "start connect");
		}
	}
		public void onConnectionStateChange(BluetoothGatt gatt, int status,
					int newState) {
				// TODO Auto-generated method stub
				super.onConnectionStateChange(gatt, status, newState);
				Log.d(BLUETOOTH_INFO," In onConnectionStateChange");
				if (BluetoothGatt.GATT_SUCCESS == status) {
					Log.d(BLUETOOTH_INFO,"onConnectionStateChange:status --> success");
				} else {
					Log.d(BLUETOOTH_INFO,"onConnectionStateChange:status --> failed");
				}
				// CQ :status 表示相应的连接或断开操作能否完成,而不是指连接状态
				if (newState == BluetoothGatt.STATE_DISCONNECTED) {
					Log.d(BLUETOOTH_INFO, "onConnectionStateChange --> disconnected");
					if (!isConnected) {
						connectCounter.addCount();
						if (connectCounter.getCount() <= connectCounter.getMaxCount()){
							gatt.connect();
						}
					} else {
						if (dataTransferTimer != null){
							dataTransferTimer.close();
						}
						gatt.connect();
					}
				}
				else if (newState == BluetoothGatt.STATE_CONNECTED) {
					Log.d(BLUETOOTH_INFO, "onConnectionStateChange --> connected");
					isConnected = true;
					connectCounter.close();
					gatt.discoverServices();
				}
			}

下面是用记事本保存的Logcat记录片段:
android ble 中使用connectGatt()进行连接,没有进入onConnectionStateC
android ble 中使用connectGatt()进行连接,没有进入onConnectionStateC

解决方案

CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明android ble 中使用connectGatt()进行连接,没有进入onConnectionStateC
喜欢 (0)
[1034331897@qq.com]
分享 (0)