0

Android でランタイムにジンバル ビーコン距離の変更を取得しようとしています。ビーコンに接続でき、Android アプリにも同じことが反映されます。

しかし、アプリで変更された RSSIを取得できません。以下は私のコードです。

private PlaceManager placeManager;
private PlaceEventListener placeEventListener;
private ArrayAdapter<String> listAdapter;
private ListView listView;
private BeaconManager bm;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    listAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_expandable_list_item_1);
    listView = (ListView) findViewById(R.id.list);
    listView.setAdapter(listAdapter);

    listAdapter.add("Setting API Key");
    listAdapter.notifyDataSetChanged();
    Gimbal.setApiKey(this.getApplication(), "my key");

    bm = new BeaconManager();
    bm.addListener(new BeaconEventListener() {
        @Override
        public void onBeaconSighting(BeaconSighting beaconSighting) {

            super.onBeaconSighting(beaconSighting);

            Log.d("beacon1", beaconSighting.getBeacon().toString());
            Log.d("beacon2", String.format("", beaconSighting.getRSSI()));
        }
    });
    bm.startListening();


    placeEventListener = new PlaceEventListener() {

        @Override
        public void onVisitStart(Visit visit) {

            super.onVisitStart(visit);

            listAdapter.add(String.format("Start Visit for %s", visit.getPlace().getName()));
            listAdapter.notifyDataSetChanged();

            Log.d("1", String.valueOf(visit.getArrivalTimeInMillis()));
            Log.d("2", String.valueOf(visit.getDepartureTimeInMillis()));
            Log.d("3", String.valueOf(visit.getPlace()));
            Log.d("4", String.valueOf(visit.getDwellTimeInMillis()));
            /*BeaconSighting demo = new BeaconSighting();
            Beacon beac = demo.getBeacon();
            Log.d("", beac.getUuid());*/
        }

        @Override
        public void onVisitEnd(Visit visit) {

            super.onVisitEnd(visit);

            listAdapter.add(String.format("End Visit for %s", visit.getPlace().getName()));
            listAdapter.notifyDataSetChanged();

            Log.d("ending","ending");
        }
    };

    placeManager = PlaceManager.getInstance();
    placeManager.addListener(placeEventListener);
    placeManager.startMonitoring();

    CommunicationManager.getInstance().startReceivingCommunications();

以下は私のログ出力です。

11-24 00:18:49.128 9801-9801/com.gimbal.hello_gimbal_android D/1: 1448353129095
11-24 00:18:49.128 9801-9801/com.gimbal.hello_gimbal_android D/2: 1448353076508
11-24 00:18:49.128 9801-9801/com.gimbal.hello_gimbal_android D/3: Place [identifier=D4786F227DA24C56D46884FD8A33F97E, name=abc, attributes=com.gimbal.android.a.a@123]
11-24 00:18:49.128 9801-9801/com.gimbal.hello_gimbal_android D/4: -52587
11-24 00:18:49.208 9801-9801/com.gimbal.hello_gimbal_android D/1: 1448353129095
11-24 00:18:49.208 9801-9801/com.gimbal.hello_gimbal_android D/2: 1448353076508
11-24 00:18:49.208 9801-9801/com.gimbal.hello_gimbal_android D/3: Place [identifier=6D63654565EA48D38D2D1F81E1D558F4, name=xyz, attributes=com.gimbal.android.a.a@456]
11-24 00:18:49.208 9801-9801/com.gimbal.hello_gimbal_android D/4: -52587
11-24 00:18:49.226 9801-9801/com.gimbal.hello_gimbal_android D/1: 1448353129095
11-24 00:18:49.226 9801-9801/com.gimbal.hello_gimbal_android D/2: 1448353076508
11-24 00:18:49.226 9801-9801/com.gimbal.hello_gimbal_android D/3: Place [identifier=A6E32B4B5FBF5849F7ED78FBF02D701, name=lmn, attributes=null]
11-24 00:18:49.226 9801-9801/com.gimbal.hello_gimbal_android D/4: -52587
11-24 01:33:39.383 21329-21329/com.gimbal.hello_gimbal_android D/beacon1: Beacon [identifier=uid123, name=abc, iconURL=null, batteryLevel=HIGH, temperature=74]
11-24 01:33:39.383 21329-21329/com.gimbal.hello_gimbal_android D/beacon2: -62

ここに問題があります。

ログ「beacon1」と「beacon2」がランダムまたは不規則に出力されます。「 BeaconEventListener 」がこのような動作をする理由がわかりません。ほとんどの場合、まったく印刷されません。このため、移動中にモバイルとビーコンの間の距離を取得できないため、障害は発生しません。

編集

より多くのエラー ログを抽出できました。logcat 出力の最後の 2 行を追加しました。

どんな助けでも大歓迎です。

4

1 に答える 1

0

Gimbal チームはこの問題をほぼ解決したので、この問題を抱えている人は今後も助けを得ることができます。

私のOPと同様に、以下が私のコードの元の部分であることがわかります。

bm = new BeaconManager();
bm.addListener(new BeaconEventListener() {
    @Override
    public void onBeaconSighting(BeaconSighting beaconSighting) {

        super.onBeaconSighting(beaconSighting);

        Log.d("beacon1", beaconSighting.getBeacon().toString());
        Log.d("beacon2", String.format("", beaconSighting.getRSSI()));
    }
});
bm.startListening();

ここで、追加する必要がonBeaconSighting()ありPlaceEventListener()ます。したがって、コードの新しい部分は次のようになります。

 placeEventListener = new PlaceEventListener() {

    @Override
    public void onVisitStart(Visit visit) {

        super.onVisitStart(visit);
        //do anything
    }

     @Override
     public void onVisitEnd(Visit visit) {

        super.onVisitEnd(visit);
        //do anything
     }

     public void onBeaconSighting(BeaconSighting sighting, List<Visit> visits) { 
     // This will be invoked when a beacon assigned to a place within a current visit is sighted. 
    }
  }

重複または別のリスナーを追加した理由は、ジンバル チームから次のように回答されました。

: 重複したリスナーを追加するとコードが機能するようになった理由を教えていただけますか? このリスナーは既に BeaconManger で処理されているため、機能するはずです。

Gimbal Team : PlaceManager の onBeaconSighting は、現在の訪問内の場所に割り当てられたビーコンが検出されると呼び出されます。ビーコンが検出されると、BeaconManager の onBeaconSighting が呼び出されます。

問題がどこにあり、どのように解決されたかについては、かなり明確になったと思います。それがあなたにも役立つことを願っています。

乾杯。

于 2015-12-27T21:18:29.707 に答える