我的灯塔(SensorTag CC2541)是一个广告客户,每秒播放10次信息.
我的Android应用程序扫描了一个BluetoothLeScanner
.我登记的每个扫描结果之间的时间BluetoothLeScanner
大约是0.1秒到0.6秒,这完全没问题.但有时(每5秒钟)每次扫描结果之间的时间超过2秒.有时最多5个.这使我的应用程序关闭,因为我需要快速检测信标.
我没有批量扫描,我只是处理每个扫描结果.
我尝试通过创建自己的问题scanSettings
并将reportDelay强制为0并将扫描模式强制为低延迟来解决这个非常规问题.但是,当我使用下面的代码实现它时,我的扫描仪只会接收每个信标ONCE.但是当使用" mLeScanner.startScan(scanCallback)
不"时,scanSettings
我会从同一个信标中获得多个结果(尽管如上所述,间隔不一致).有谁知道这个问题可能是由什么引起的?
BluetoothManager bluetoothManager = (BluetoothManager) getSystemService(Context.BLUETOOTH_SERVICE); BluetoothAdapter mBluetoothAdapter = bluetoothManager.getAdapter(); BluetoothLeScanner mLeScanner = mBluetoothAdapter.getBluetoothLeScanner(); ScanSettings.Builder scanSettingsBuilder = new ScanSettings.Builder(); scanSettingsBuilder.setScanMode(ScanSettings.SCAN_MODE_LOW_LATENCY); scanSettingsBuilder.setReportDelay(0); scanSettingsBuilder.setCallbackType(ScanSettings.CALLBACK_TYPE_ALL_MATCHES); ScanSettings scanSettings = scanSettingsBuilder.build(); ScanCallback scanCallback = new ScanCallback() { @Override public void onScanResult(int callbackType, ScanResult result) { super.onScanResult(callbackType, result); //Handle result } @Override public void onBatchScanResults(Listresults) { super.onBatchScanResults(results); //Not used, any code I put here never gets run } @Override public void onScanFailed(int errorCode) { super.onScanFailed(errorCode); } }; mLeScanner.startScan(null, scanSettings, scanCallback);
结果显示callbackType = 1,当我在mLeScanner.startScan(....)之前记录时,scanSettings也是这样,所以据我所知,这不是问题.
更新:使用scanSettings时似乎只扫描一次的问题是因为我的信标启用了可连接模式.我明天会尝试禁用它们.
但是,覆盖扫描设置会不会有助于我的违规情况呢?