检测IBeacon在LogCat中工作,但不在手机上



我正在研究一个检测iBeaconAndroid应用程序。现在我的问题是,在LogCat中,我可以看到信标的正确名称以及ip地址

BtGatt。btif btif_gatc_update_properties BLE设备名称=..BtGattGattService onScanResult() ip地址

但是onBeaconServiceConnect()方法仍然作为集合进入else部分(Size为0)。我已经在这里阅读了关于这个主题的线程并搜索了互联网,但没有找到答案。

我的代码:

public class RangingActivity extends Activity implements BeaconConsumer {
  protected static final String TAG = "RangingActivity";
  private BeaconManager beaconManager = BeaconManager.getInstanceForApplication(this);
  private BluetoothAdapter btAdapt;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_ranging);
    beaconManager.setBackgroundScanPeriod(1000);
    beaconManager.bind(this);
  }
  @Override 
  protected void onDestroy() {
    super.onDestroy();
    beaconManager.unbind(this);
  }
  @Override 
  protected void onPause() {
    super.onPause();
  }
  @Override 
  protected void onResume() {
    super.onResume();
  }
  @Override
  public void onBeaconServiceConnect() {
    beaconManager.setRangeNotifier(new RangeNotifier() {
    public void didRangeBeaconsInRegion(Collection<Beacon> beacons, Region region) {
        logToDisplay("Number of beacons detected: "+beacons.size());
        if (beacons.size() > 0) {
            EditText editText = (EditText)RangingActivity.this
                    .findViewById(R.id.rangingText);
            Beacon firstBeacon = beacons.iterator().next();
            logToDisplay("The first beacon "+firstBeacon.toString());
        }else{
            logToDisplay("No beacon");
        }
    }
    });
    try {
        beaconManager.startRangingBeaconsInRegion(new Region("myRangingUniqueId", null, null, null));
    } catch (RemoteException e) {   }
}
private void logToDisplay(final String line) {
    runOnUiThread(new Runnable() {
        public void run() {
            EditText editText = (EditText)RangingActivity.this
                    .findViewById(R.id.rangingText);
            editText.append(line+"n");             
        }
    });
}

}

您在LogCat中提到的日志行表明Android的蓝牙堆栈看到了蓝牙LE设备。这并不意味着它看到的蓝牙设备是一个可识别的信标。

最可能的解释是,您没有任何传输的信标,库将识别。默认情况下,Android信标库只检测AltBeacons,这是一种无知识产权的传输格式。如果希望库检测专有信标,则需要使用自定义BeaconParser对其进行配置。这其实很容易做到。请仔细阅读setBeaconLayout方法的文档,了解如何执行此操作。

如果这不能解决您的问题,并且您希望进一步调试它,请尝试在库中启用调试日志记录以在LogCat中获取更多信息。您可以通过在onCreate方法中添加一行来实现:

beaconManager.setDebug(true);

最新更新