From 4b2116c060f12eb951efa69dc380d0248b86cd2b Mon Sep 17 00:00:00 2001 From: Alexandros Schillings Date: Mon, 10 Mar 2014 13:56:58 +0000 Subject: [PATCH] Added details activity --- AndroidManifest.xml | 6 +- res/layout/activity_details.xml | 21 +++ .../btlescan/activities/DetailsActivity.java | 78 +++++++++++ .../{ => activities}/MainActivity.java | 121 ++++++++++-------- 4 files changed, 169 insertions(+), 57 deletions(-) create mode 100644 res/layout/activity_details.xml create mode 100644 src/uk/co/alt236/btlescan/activities/DetailsActivity.java rename src/uk/co/alt236/btlescan/{ => activities}/MainActivity.java (58%) diff --git a/AndroidManifest.xml b/AndroidManifest.xml index 1a2e314..4b46797 100644 --- a/AndroidManifest.xml +++ b/AndroidManifest.xml @@ -21,7 +21,7 @@ android:label="@string/app_name" android:theme="@style/AppTheme" > @@ -29,6 +29,10 @@ + + \ No newline at end of file diff --git a/res/layout/activity_details.xml b/res/layout/activity_details.xml new file mode 100644 index 0000000..bf1fe2d --- /dev/null +++ b/res/layout/activity_details.xml @@ -0,0 +1,21 @@ + + + + + + + + \ No newline at end of file diff --git a/src/uk/co/alt236/btlescan/activities/DetailsActivity.java b/src/uk/co/alt236/btlescan/activities/DetailsActivity.java new file mode 100644 index 0000000..a66c805 --- /dev/null +++ b/src/uk/co/alt236/btlescan/activities/DetailsActivity.java @@ -0,0 +1,78 @@ +package uk.co.alt236.btlescan.activities; + +import java.util.Collection; + +import uk.co.alt236.btlescan.R; +import uk.co.alt236.btlescan.containers.AdRecord; +import uk.co.alt236.btlescan.containers.AdRecordUtils; +import uk.co.alt236.btlescan.containers.BluetoothLeDevice; +import android.app.Activity; +import android.os.Bundle; +import android.widget.TextView; +import butterknife.ButterKnife; +import butterknife.InjectView; + +public class DetailsActivity extends Activity{ + public static final String EXTRA_DEVICE = "extra_device"; + + @InjectView(R.id.tvDetails) TextView mTvDetails; + + private BluetoothLeDevice mDevice; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_details); + ButterKnife.inject(this); + + mDevice = getIntent().getParcelableExtra(EXTRA_DEVICE); + + pupulateDetails(mDevice); + } + + private void pupulateDetails(BluetoothLeDevice device) { + final StringBuilder sb = new StringBuilder(); + + if(device == null){ + append(sb, "Invalid Device Data!", null); + } else { + append(sb, "Device Name", device.getName()); + append(sb, "Device Address", device.getAddress()); + + append(sb, "", null); + append(sb, "Device Class", device.getBluetoothDeviceClassName()); + append(sb, "Bonding State", device.getBluetoothDeviceBondState()); + + append(sb, "", null); + append(sb, "Ad Records", null); + append(sb, "-----------------", null); + + + final Collection adRecords = device.getAdRecordStore().getRecordsAsCollection(); + + for(AdRecord record : adRecords){ + append(sb, + "Record Id'" +record.getType()+ "' - " + record.getHumanReadableType(), AdRecordUtils.getRecordDataAsString(record)); + } + } + + mTvDetails.setText(sb.toString()); + } + + + private void append(StringBuilder sb, String label, boolean value){ + append(sb, label, String.valueOf(value)); + } + + private void append(StringBuilder sb, String label, long value){ + append(sb, label, String.valueOf(value)); + } + + private void append(StringBuilder sb, String label, String value){ + if(value != null){ + sb.append("#" + label +":\t" + value + "\n"); + } else { + sb.append(label + "\n"); + } + } +} diff --git a/src/uk/co/alt236/btlescan/MainActivity.java b/src/uk/co/alt236/btlescan/activities/MainActivity.java similarity index 58% rename from src/uk/co/alt236/btlescan/MainActivity.java rename to src/uk/co/alt236/btlescan/activities/MainActivity.java index f2ea20d..f59912e 100644 --- a/src/uk/co/alt236/btlescan/MainActivity.java +++ b/src/uk/co/alt236/btlescan/activities/MainActivity.java @@ -1,20 +1,19 @@ -package uk.co.alt236.btlescan; - -import java.util.Collection; +package uk.co.alt236.btlescan.activities; +import uk.co.alt236.btlescan.R; import uk.co.alt236.btlescan.adapters.LeDeviceListAdapter; -import uk.co.alt236.btlescan.containers.AdRecord; -import uk.co.alt236.btlescan.containers.AdRecordUtils; import uk.co.alt236.btlescan.containers.BluetoothLeDevice; import uk.co.alt236.btlescan.util.BluetoothLeScanner; import uk.co.alt236.btlescan.util.BluetoothUtils; import android.app.ListActivity; import android.bluetooth.BluetoothAdapter; import android.bluetooth.BluetoothDevice; +import android.content.Intent; import android.os.Bundle; -import android.util.Log; import android.view.Menu; import android.view.MenuItem; +import android.view.View; +import android.widget.ListView; import android.widget.TextView; import butterknife.ButterKnife; import butterknife.InjectView; @@ -32,13 +31,11 @@ public class MainActivity extends ListActivity { public void onLeScan(final BluetoothDevice device, int rssi, byte[] scanRecord) { final BluetoothLeDevice deviceLe = new BluetoothLeDevice(device, rssi, scanRecord); - Log.d("TAG", "~ New BT Device: " + deviceLe); - - final Collection adRecords = deviceLe.getAdRecordStore().getRecordsAsCollection(); - - for(final AdRecord record : adRecords){ - Log.d("TAG", "~ Has Record: " + record.getType() + ": '" + record.getHumanReadableType() +"', data: '"+ AdRecordUtils.getRecordDataAsString(record) + "'"); - } + // Log.d("TAG", "~ New BT Device: " + deviceLe); + // final Collection adRecords = deviceLe.getAdRecordStore().getRecordsAsCollection(); + // for(final AdRecord record : adRecords){ + // Log.d("TAG", "~ Has Record: " + record.getType() + ": '" + record.getHumanReadableType() +"', data: '"+ AdRecordUtils.getRecordDataAsString(record) + "'"); + // } runOnUiThread(new Runnable() { @Override @@ -51,7 +48,19 @@ public class MainActivity extends ListActivity { } }; - @Override + @Override + protected void onListItemClick(ListView l, View v, int position, long id) { + final BluetoothLeDevice device = mLeDeviceListAdapter.getDevice(position); + if (device == null) return; + + + final Intent intent = new Intent(this, DetailsActivity.class); + intent.putExtra(DetailsActivity.EXTRA_DEVICE, device); + + startActivity(intent); + } + + @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); @@ -60,44 +69,44 @@ public class MainActivity extends ListActivity { mScanner = new BluetoothLeScanner(mLeScanCallback, mBluetoothUtils); } - - @Override - public boolean onCreateOptionsMenu(Menu menu) { - getMenuInflater().inflate(R.menu.main, menu); - if (!mScanner.isScanning()) { - menu.findItem(R.id.menu_stop).setVisible(false); - menu.findItem(R.id.menu_scan).setVisible(true); - menu.findItem(R.id.menu_refresh).setActionView(null); - } else { - menu.findItem(R.id.menu_stop).setVisible(true); - menu.findItem(R.id.menu_scan).setVisible(false); - menu.findItem(R.id.menu_refresh).setActionView(R.layout.actionbar_progress_indeterminate); - } - return true; - } - - @Override - public boolean onOptionsItemSelected(MenuItem item) { - switch (item.getItemId()) { - case R.id.menu_scan: - startScan(); - break; - case R.id.menu_stop: - mScanner.scanLeDevice(-1, false); - invalidateOptionsMenu(); - break; - } - return true; - } - - @Override - protected void onPause() { - super.onPause(); - mScanner.scanLeDevice(-1, false); - mLeDeviceListAdapter.clear(); - } - @Override + @Override + public boolean onCreateOptionsMenu(Menu menu) { + getMenuInflater().inflate(R.menu.main, menu); + if (!mScanner.isScanning()) { + menu.findItem(R.id.menu_stop).setVisible(false); + menu.findItem(R.id.menu_scan).setVisible(true); + menu.findItem(R.id.menu_refresh).setActionView(null); + } else { + menu.findItem(R.id.menu_stop).setVisible(true); + menu.findItem(R.id.menu_scan).setVisible(false); + menu.findItem(R.id.menu_refresh).setActionView(R.layout.actionbar_progress_indeterminate); + } + return true; + } + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + switch (item.getItemId()) { + case R.id.menu_scan: + startScan(); + break; + case R.id.menu_stop: + mScanner.scanLeDevice(-1, false); + invalidateOptionsMenu(); + break; + } + return true; + } + + @Override + protected void onPause() { + super.onPause(); + mScanner.scanLeDevice(-1, false); + mLeDeviceListAdapter.clear(); + } + + @Override public void onResume(){ super.onResume(); final boolean mIsBluetoothOn = mBluetoothUtils.isBluetoothOn(); @@ -114,14 +123,14 @@ public class MainActivity extends ListActivity { } else { mTvBluetoothLeStatus.setText(R.string.not_supported); } - + invalidateOptionsMenu(); } - + private void startScan(){ final boolean mIsBluetoothOn = mBluetoothUtils.isBluetoothOn(); final boolean mIsBluetoothLePresent = mBluetoothUtils.isBluetoothLeSupported(); - + mLeDeviceListAdapter = new LeDeviceListAdapter(this); setListAdapter(mLeDeviceListAdapter); @@ -129,7 +138,7 @@ public class MainActivity extends ListActivity { if(mIsBluetoothOn && mIsBluetoothLePresent){ mScanner.scanLeDevice(-1, true); invalidateOptionsMenu(); - } - } + } + } }