Java 如何将信标名称插入数据库?
我需要提取可扩展的设备名并将其放入sqlite中的一个表中。我使用了谷歌的示例代码,并对其进行了修改,以实现我的目标。除表中的设备名称外,所有部件都工作。我可以吐司的设备名称,这意味着该方法的工作,但我不知道我应该把插入命令:插入设备名称表Java 如何将信标名称插入数据库?,java,android,sqlite,bluetooth-lowenergy,beacon,Java,Android,Sqlite,Bluetooth Lowenergy,Beacon,我需要提取可扩展的设备名并将其放入sqlite中的一个表中。我使用了谷歌的示例代码,并对其进行了修改,以实现我的目标。除表中的设备名称外,所有部件都工作。我可以吐司的设备名称,这意味着该方法的工作,但我不知道我应该把插入命令:插入设备名称表 myDb.insertData("1",device.getName(),date); 这是我的扫描活动 package com.example.android.bluetoothlegatt; public class DeviceScanActiv
myDb.insertData("1",device.getName(),date);
这是我的扫描活动
package com.example.android.bluetoothlegatt;
public class DeviceScanActivity extends ListActivity {
DatabaseHelper myDb;
//String beaconName;
String date = new SimpleDateFormat("ddMMyyHHmmss").format(new Date());
private LeDeviceListAdapter mLeDeviceListAdapter;
private BluetoothAdapter mBluetoothAdapter;
private boolean mScanning;
private Handler mHandler;
private static final int REQUEST_ENABLE_BT = 1;
private static final long SCAN_PERIOD = 50000;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
getActionBar().setTitle(R.string.title_devices);
mHandler = new Handler();
myDb=new DatabaseHelper(this);
myDb.insertData("1", getName() , date);
if (!getPackageManager().hasSystemFeature(PackageManager.FEATURE_BLUETOOTH_LE)) {
Toast.makeText(this, R.string.ble_not_supported, Toast.LENGTH_SHORT).show();
finish();
}
final BluetoothManager bluetoothManager =
(BluetoothManager) getSystemService(Context.BLUETOOTH_SERVICE);
mBluetoothAdapter = bluetoothManager.getAdapter();
if (mBluetoothAdapter == null) {
Toast.makeText(this, R.string.error_bluetooth_not_supported, Toast.LENGTH_SHORT).show();
finish();
return;
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
if (!mScanning) {
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_indeterminate_progress);
}
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.menu_scan:
mLeDeviceListAdapter.clear();
scanLeDevice(true);
break;
case R.id.menu_stop:
scanLeDevice(false);
break;
}
return true;
}
@Override
protected void onResume() {
super.onResume();
currently enabled,
permission to enable it.
if (!mBluetoothAdapter.isEnabled()) {
if (!mBluetoothAdapter.isEnabled()) {
Intent enableBtIntent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);
startActivityForResult(enableBtIntent, REQUEST_ENABLE_BT);
}
}
mLeDeviceListAdapter = new LeDeviceListAdapter();
setListAdapter(mLeDeviceListAdapter);
scanLeDevice(true);
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == REQUEST_ENABLE_BT && resultCode == Activity.RESULT_CANCELED) {
finish();
return;
}
super.onActivityResult(requestCode, resultCode, data);
}
@Override
protected void onPause() {
super.onPause();
scanLeDevice(false);
mLeDeviceListAdapter.clear();
}
@Override
protected void onListItemClick(ListView l, View v, int position, long id) {
final BluetoothDevice device = mLeDeviceListAdapter.getDevice(position);
if (device == null) return;
final Intent intent = new Intent(this, DeviceControlActivity.class);
intent.putExtra(DeviceControlActivity.EXTRAS_DEVICE_NAME, device.getName());
intent.putExtra(DeviceControlActivity.EXTRAS_DEVICE_ADDRESS, device.getAddress());
if (mScanning) {
mBluetoothAdapter.stopLeScan(mLeScanCallback);
mScanning = false;
}
startActivity(intent);
}
private void scanLeDevice(final boolean enable) {
if (enable) {
// Stops scanning after a pre-defined scan period.
mHandler.postDelayed(new Runnable() {
@Override
public void run() {
mScanning = false;
mBluetoothAdapter.stopLeScan(mLeScanCallback);
invalidateOptionsMenu();
}
}, SCAN_PERIOD);
mScanning = true;
mBluetoothAdapter.startLeScan(mLeScanCallback);
} else {
mScanning = false;
mBluetoothAdapter.stopLeScan(mLeScanCallback);
}
invalidateOptionsMenu();
}
private class LeDeviceListAdapter extends BaseAdapter {
private ArrayList<BluetoothDevice> mLeDevices;
private LayoutInflater mInflator;
public LeDeviceListAdapter() {
super();
mLeDevices = new ArrayList<BluetoothDevice>();
mInflator = DeviceScanActivity.this.getLayoutInflater();
}
public void addDevice(BluetoothDevice device) {
if(!mLeDevices.contains(device)) {
mLeDevices.add(device);
}
}
public BluetoothDevice getDevice(int position) {
return mLeDevices.get(position);
}
public void clear() {
mLeDevices.clear();
}
@Override
public int getCount() {
return mLeDevices.size();
}
@Override
public Object getItem(int i) {
return mLeDevices.get(i);
}
@Override
public long getItemId(int i) {
return i;
}
@Override
public View getView(int i, View view, ViewGroup viewGroup) {
ViewHolder viewHolder;
if (view == null) {
view = mInflator.inflate(R.layout.listitem_device, null);
viewHolder = new ViewHolder();
viewHolder.deviceAddress = (TextView) view.findViewById(R.id.device_address);
viewHolder.deviceName = (TextView) view.findViewById(R.id.device_name);
view.setTag(viewHolder);
} else {
viewHolder = (ViewHolder) view.getTag();
}
BluetoothDevice device = mLeDevices.get(i);
final String deviceName = device.getName();
if (deviceName != null && deviceName.length() > 0)
viewHolder.deviceName.setText(deviceName);
else
viewHolder.deviceName.setText(R.string.unknown_device);
viewHolder.deviceAddress.setText(device.getAddress());
return view;
}
}
private BluetoothAdapter.LeScanCallback mLeScanCallback =
new BluetoothAdapter.LeScanCallback() {
@Override
public void onLeScan(final BluetoothDevice device, int rssi, byte[] scanRecord) {
runOnUiThread(new Runnable() {
@Override
public void run() {
mLeDeviceListAdapter.addDevice(device);
mLeDeviceListAdapter.notifyDataSetChanged();
}
});
}
};
static class ViewHolder {
TextView deviceName;
TextView deviceAddress;
}
}
插入命令是否可以像这样放置在
mLeScanCallback
中
...
private BluetoothAdapter.LeScanCallback mLeScanCallback =
new BluetoothAdapter.LeScanCallback() {
@Override
public void onLeScan(final BluetoothDevice device, int rssi, byte[] scanRecord) {
// insert the device into the SQLite database
String date = new SimpleDateFormat("ddMMyyHHmmss").format(new Date());
myDb.insertData(device.getAddress(), device.getName() , date);
// add device to list displayed on GUI
runOnUiThread(new Runnable() {
@Override
public void run() {
mLeDeviceListAdapter.addDevice(device);
mLeDeviceListAdapter.notifyDataSetChanged();
}
});
}
};
...
上面的代码使用传入回调的
BluetoothDevice设备的mac地址作为插入命令的MobileId
。Hello@ebi nadian,我对您的问题有几个问题。正在插入数据库的名称是通过蓝牙连接到的设备的名称,还是本地设备的名称?应用程序能否连接到多个其他设备?“myTable”表应该跟踪什么?如果能提供上述问题的答案,将有助于我们更好地理解您的问题。特别是最后一个。嗨,埃里克,第一个mytable在应用程序数据库中,所有数据都应该在那里。该应用程序假设通过GATT数据包扫描所有BLE设备(信标)。GATT数据包中有很多信息,比如设备(信标)名称、MAC地址…,我只需要获取设备名称(BeaconName)+时间+一个常量值(例如数字5)并传递给sqlite。但我的问题是变量device.getName();不要传播到所有方法(它仅在自己的方法中可访问,尽管不是私有的)。它可以工作,谢谢,关于主键,根据场景,特定移动电话中的每个记录的MobileID列必须相同,唯一的变量数据是信标名称和时间,因为有几部手机在不同的区域收集数据,最后所有的数据都应该合并到一个数据库中。哦,我明白了,好的。我将编辑我的答案以修复它。我很高兴能帮上忙!!
...
private BluetoothAdapter.LeScanCallback mLeScanCallback =
new BluetoothAdapter.LeScanCallback() {
@Override
public void onLeScan(final BluetoothDevice device, int rssi, byte[] scanRecord) {
// insert the device into the SQLite database
String date = new SimpleDateFormat("ddMMyyHHmmss").format(new Date());
myDb.insertData(device.getAddress(), device.getName() , date);
// add device to list displayed on GUI
runOnUiThread(new Runnable() {
@Override
public void run() {
mLeDeviceListAdapter.addDevice(device);
mLeDeviceListAdapter.notifyDataSetChanged();
}
});
}
};
...