Android BTLE -> 找不到回调包装器



我在我的应用程序中使用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时会遇到这个问题。

相关内容

  • 没有找到相关文章

最新更新