我在我的应用程序中使用Android Beacon Library,我逐字逐句地复制了他们的测距示例,但我一直收到你在代码下面看到的错误。任何帮助都将不胜感激,我刚刚进入BTLE/信标
package com.example.josh.beacons;
import android.os.Bundle;
import android.os.RemoteException;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import org.altbeacon.beacon.Beacon;
import org.altbeacon.beacon.BeaconConsumer;
import org.altbeacon.beacon.BeaconManager;
import org.altbeacon.beacon.BeaconParser;
import org.altbeacon.beacon.RangeNotifier;
import org.altbeacon.beacon.Region;
import java.util.Collection;
public class MainActivity extends AppCompatActivity implements BeaconConsumer {
protected static final String TAG = "RangingActivity";
private BeaconManager beaconManager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
beaconManager = BeaconManager.getInstanceForApplication(this);
beaconManager.getBeaconParsers().add(new BeaconParser().setBeaconLayout("m:2-3=beac,i:4-19,i:20-21,i:22-23,p:24-24,d:25-25"));
beaconManager.bind(this);
}
@Override
protected void onDestroy() {
super.onDestroy();
beaconManager.unbind(this);
}
@Override
public void onBeaconServiceConnect() {
beaconManager.setRangeNotifier(new RangeNotifier() {
@Override
public void didRangeBeaconsInRegion(Collection<Beacon> beacons, Region region) {
if (beacons.size() > 0) {
Log.i(TAG, "The first beacon I see is about " + beacons.iterator().next().getDistance() + " meters away.");
}
}
});
try {
beaconManager.startRangingBeaconsInRegion(new Region("myRangingUniqueId", null, null, null));
} catch (RemoteException e) { }
}
}
我得到的错误:
05-12 20:21:44.769 25775-25775/com.example.josh.beacons D/BluetoothAdapter: STATE_ON
05-12 20:21:44.770 25775-25775/com.example.josh.beacons D/BluetoothLeScanner: could not find callback wrapper
05-12 20:21:44.787 25775-26783/com.example.josh.beacons D/RangingActivity: didRangeBeacons 0
虽然您可以安全地忽略此消息,但它告诉了您一些信息。很可能是它告诉你,你的设备已经关闭了应用程序的位置权限,这阻止了你的信标扫描工作。如果该应用程序具有适当的权限并正在正确扫描,你会看到更像的东西
D/BluetoothAdapter: STATE_ON
D/BluetoothLeScanner: onClientRegistered() - status=0 clientIf=5
如果你的目标是API 23+级,即使你的minsdk设置得更低(如16),你也一定要检查你的代码中是否启用了位置权限。
我为此损失了很多小时,才意识到这只是由于应用程序的定位服务被关闭而导致的无声故障。
如果您在LogCat中看到的行不是来自您自己的代码,请注意不要过于认真。如果这一行以"D/"开头,这一点尤其正确,这表示调试行,而不是错误("E/")。我已经构建了几十个信标应用程序,看到这一行的次数多得数不清,并且可以自信地说这并不表示有问题。
一句话:您可以放心地忽略该消息请注意,Android蓝牙堆栈在LogCat中的噪音是出了名的。这不会是你学会忽略的第一句话。
不确定是否有人在过去4年中调整了代码,因为BluetoothLeScanner建议的内容与发布的答案不同。
事实证明,对stopScan()
的不正确调用是罪魁祸首。如果传入的ScanCallback
参数周围的包装器实现是null
,则BluetoothLeScanner
将打印此日志消息并返回而不停止扫描。我认为应该将其记录为错误(Log.e
),而不是调试日志。
我可以通过确保只有在以前调用startScan(callback)
的情况下才调用stopScan(callback)
来消除它。
正如很多人所说,这个消息通常可以被安全地忽略。然而,我遇到了和你类似的问题——有时,我使用BluetoothLeScanner检测到0 BLE设备。
通过查看BluetoothLeScanner类在Logcat中生成的Debug输出,我发现每当检测到零个设备时,就会出现onScannerRegistered() - status=6 scannerId=-1 mScannerId=0
。通常,作为参考,输出为onScannerRegistered() - status=0 scannerId=10 mScannerId=0
。
通过查看各种Github repos,我发现这组输出与Android BLE不支持在30秒内停止/启动扫描5次以上的事实相对应。像这样的日志消息通常可以被安全地忽略,但查看文档以检查它显示的任何信息总是很好的。也许不在这个代码片段中,但我希望您在使用BLE时会遇到这个问题。