AltBeacon:选择埃迪斯通灯塔的简单方法



这是选择灯塔埃迪斯通类型的唯一方法吗?

     if (b.getServiceUuid() == 0xfeaa) {
        if (b.getBeaconTypeCode() == 0x00) {
            // Eddystone-UID
        } else if (b.getBeaconTypeCode() == 0x10) {
            // Eddystone-URL
        } else if (b.getBeaconTypeCode() == 0x20) {
            // Eddystone-TLM
        }
    } else {
        // AltBeacon...
    }

使用Android Beacon Library 2.8+版本,这要容易得多。为每个BeaconParser添加了一个可选的字符串标识符。这个标识符被传递给任何使用该解析器匹配的Beacon实例,因此您可以很容易地判断出哪个信标类型是

这是一个如何工作的例子:

beaconManager.getBeaconParsers().add(new BeaconParser("Eddystone-UID")
  .setBeaconLayout(BeaconParser.EDDYSTONE_UID_LAYOUT));
...
if (beacon.getParserIdentifier().equals("Eddystone-UID")) {
  // This is Eddystone-UID
}

只要确保在构造BeaconParser时设置标识符即可。

添加此项正是因为在确定您的问题中指出的信标类型时很尴尬。

检查altbeacon库:http://altbeacon.org

要区分信标,请以这种方式使用if语句:

if (String.valueOf(beac.getId2()).trim().equals("13191"))//Getting the major of the beacon
                            {
                                //do something
                            }

一旦信标在范围内,代码就会在UI线程中运行:

  public void Run(View view){
        beaconManager.addRangeNotifier(new RangeNotifier() {
            @Override
            public void didRangeBeaconsInRegion(final Collection<Beacon> collection, Region region) {
                runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        for (Beacon beac : collection) { //LOOP searches for all the beacons within the range...
                            //beac.getId1()// 
                            beaconUUID = beac.getId2().toString(); //Major
                            //beac.getId3()//Minor
                            udaljenost1 = Math.round(beac.getDistance() * 100.0) / 100.0; //dobivanje integera iz decimala, zaokruzivanje na cjeli broj
                            if (String.valueOf(beac.getId2()).trim().equals("13191"))//Getting the major of the beacon
                            {
                                //do something
                            }
                        }
                    }
                });

            }
        });
    }

最新更新