【问题标题】:Ble Scanning Devices AndroidBle 扫描设备 Android
【发布时间】:2017-03-06 05:26:17
【问题描述】:

我正在扫描 BLE 设备。 这是我的代码;

public class MainActivity extends AppCompatActivity {



private boolean mScanning;Button ara ;
ListView lw;
private BluetoothAdapter mBluetoothAdapter;
private int REQUEST_ENABLE_BT = 1;
private Handler mHandler;
private static final long SCAN_PERIOD = 10000;
private BluetoothLeScanner mLEScanner;
private ScanSettings settings;
private List<ScanFilter> filters;
private BluetoothGatt mGatt;
private ArrayList<String> deviceListesi = new ArrayList<String>();
private ArrayList<String> mDeviceStore = new ArrayList<String>();
private ArrayAdapter<String> deviceAdapter ;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mHandler = new Handler();
    if (!getPackageManager().hasSystemFeature(PackageManager.FEATURE_BLUETOOTH_LE)) {
        Toast.makeText(this, "BLE Not Supported",
                Toast.LENGTH_SHORT).show();
        finish();
    }
    final BluetoothManager bluetoothManager =
            (BluetoothManager) getSystemService(Context.BLUETOOTH_SERVICE);
    mBluetoothAdapter = bluetoothManager.getAdapter();
    lw = (ListView) findViewById(R.id.listview);
    ara = (Button) findViewById(R.id.button2);
    deviceAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, android.R.id.text1, deviceListesi);
    mBluetoothAdapter.startDiscovery();
    ara.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            scanLeDevice(true);
        }
    });
}
private final BluetoothAdapter.LeScanCallback mLeScanCallback = new BluetoothAdapter.LeScanCallback() {
    @Override
    public void onLeScan(final BluetoothDevice device, final int rssi, final byte[] scanRecord) {
        System.out.println("Buradayım mmmmmmmmmmmm");
        final String deviceIsim = device.getName()+" "+device.getAddress();
        Toast.makeText(getApplicationContext(),deviceIsim,Toast.LENGTH_SHORT).show();
        mDeviceStore.add(deviceIsim);


        for (final String leDevice : mDeviceStore) {
                deviceListesi.add(leDevice);

        }

        runOnUiThread(new Runnable() {
            @Override
            public void run() {
               lw.setAdapter(deviceAdapter);

            }
        });
    }
};
public void scanLeDevice( final boolean enable) {
    if (enable) {
        if (mScanning) {
            return;
        }
        Log.d("TAG", "~ Starting Scan");
        // Stops scanning after a pre-defined scan period.

            mHandler.postDelayed(new Runnable() {
                @Override
                public void run() {
                    Log.d("TAG", "~ Stopping Scan (timeout)");
                    mScanning = false;
                    mBluetoothAdapter.stopLeScan(mLeScanCallback);
                }
            }, SCAN_PERIOD);

        mScanning = true;
        mBluetoothAdapter.startLeScan(mLeScanCallback);
    } else {
        Log.d("TAG", "~ Stopping Scan");
        mScanning = false;
        mBluetoothAdapter.stopLeScan(mLeScanCallback);
    }
}

}

我有列表视图但没有任何事情发生?这是安卓监视器打印出来的;

D/TAG:~开始扫描 D/TAG:~停止扫描(超时) D/BluetoothAdapter:stopLeScan() D/BluetoothAdapter:扫描未开始 还

我哪里做错了?

【问题讨论】:

  • 欢迎来到 Stack Overflow!看来您需要学习使用调试器。请帮助自己一些complementary debugging techniques。如果之后仍有问题,请随时回来提供更多详细信息。
  • 我正在调试我的代码,没有错误,没有不起作用的功能。我无法解决我的问题。
  • 你的调试课程教会了你什么?
  • 我设置了断点scanLeDevice,该功能正常工作。我在 LeScanCallBack 中设置了 LeScan 函数的断点。代码永远不会到达这个函数。我有 BLE 设备,我用一个 playstore 应用程序测试了我的设备,我发现了它,所以我的设备可以正常工作。

标签: java android bluetooth-lowenergy


【解决方案1】:

删除线

mBluetoothAdapter.startDiscovery();

蓝牙 LE 和“旧”蓝牙是不同的东西。你不能把两者混在一起。

【讨论】:

  • 我删除它但仍然继续