Androidスタジオを使用して、estimote sdkを初めて使用します。自宅にビーコンが 1 つあり、それに取り組み、SDK を使用してフローを取得したいと考えています。Android 4.4.4 api19 で Xiaomi を使用する
私は奇妙な問題を抱えています.私の電話はnearableを発見しましたが、nearableの実際のリストは空です. しばらくグーグルで検索しましたが、誰も同様の問題を抱えていませんでした。それは、今私が理解できない、本当に単純なことかもしれません。何か分かりますか?ブルートゥースを有効にしました。近くにあるビーコンは 1 つだけです。ハッカソンでは、ビーコンの過負荷によりブルートゥースがクラッシュしました。
私のコード
package com.example.tom.test;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.TextView;
import com.estimote.sdk.Beacon;
import com.estimote.sdk.BeaconManager;
import com.estimote.sdk.Nearable;
import com.estimote.sdk.Region;
import java.util.List;
public class MainActivity extends ActionBarActivity {
private BeaconManager beaconManager;
private String scanId;
private Nearable currentNearable;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
beaconManager = new BeaconManager(getApplicationContext());
setContentView(R.layout.activity_main);
beaconManager.setNearableListener(new BeaconManager.NearableListener() {
@Override
public void onNearablesDiscovered(List<Nearable> listOfNearables) {
Log.d(null, "nearable discovered");
Log.d(null, "size of list is " + String.valueOf(listOfNearables.size()));
int maxPower = 0;
if (!listOfNearables.isEmpty()) {
Log.d(null, "in");
maxPower = listOfNearables.get(0).power.powerInDbm;
currentNearable = listOfNearables.get(0);
for (Nearable nearable : listOfNearables) {
if (maxPower < nearable.power.powerInDbm) {
maxPower = nearable.power.powerInDbm;
currentNearable = nearable;
}
}
displayCurrentNearableInfo();
}
}
});
}
@Override
protected void onStart() {
beaconManager.connect(new BeaconManager.ServiceReadyCallback() {
@Override
public void onServiceReady() {
scanId = beaconManager.startNearableDiscovery();
}
});
super.onStart();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
@Override
protected void onDestroy() {
beaconManager.disconnect();
super.onDestroy();
}
@Override protected void onStop() {
beaconManager.stopNearableDiscovery(scanId);
super.onStop();
}
private void displayCurrentNearableInfo() {
if(currentNearable != null){
StringBuilder builder = new StringBuilder()
.append("temperature: ").append(currentNearable.temperature).append("\n")
.append("contents: ").append(currentNearable.describeContents())
.append("power: " ).append(currentNearable.power.powerInDbm);
TextView infoText = (TextView) findViewById(R.id.textView);
infoText.setText(builder.toString());
}
}
}
コンソール
11-11 10:18:19.750 5940-6027/com.example.tom.test D/BluetoothAdapter﹕ startLeScan(): null
11-11 10:18:19.750 5940-5952/com.example.tom.test D/BluetoothAdapter﹕ onClientRegistered() - status=0 clientIf=5
11-11 10:18:20.780 5940-6027/com.example.tom.test D/BluetoothAdapter﹕ stopLeScan()
11-11 10:18:20.820 5940-5940/com.example.tom.test D/﹕ nearable discovered
11-11 10:18:20.820 5940-5940/com.example.tom.test E/﹕ size of list is 0