Я включил Bluetooth на своем телефоне, и мой телефон - Galaxy S8 с последней версией.не понимаю, что я не могу получить устройство Bluetooth 4.0 при обратном вызове.
Ниже приведен фрагмент кода.
public class MainActivity extends AppCompatActivity {
private BluetoothLeScanner mBLEScanner;
BluetoothAdapter mBluetoothAdapter;
private static final long SCAN_PERIOD = 5000;
Handler mHandler=null;
Button btn;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
checkPermission();
BluetoothAdapter bluetoothAdapter =
BluetoothAdapter.getDefaultAdapter();
if(!bluetoothAdapter.isEnabled()){
bluetoothAdapter.enable();
}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
mBLEScanner=bluetoothAdapter.getBluetoothLeScanner();
}
mHandler = new Handler();
btn=(Button)findViewById(R.id.btn);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Log.e("main","now calling bluetooth low energy");
scanLeDevice(true);
}
});
}
void checkPermission(){
String[] permissions = {
Manifest.permission.INTERNET,
Manifest.permission.ACCESS_NETWORK_STATE,
Manifest.permission.BLUETOOTH_ADMIN,
Manifest.permission.BLUETOOTH,
Manifest.permission.ACCESS_COARSE_LOCATION,
Manifest.permission.ACCESS_FINE_LOCATION,
};
int permissionCheck = PackageManager.PERMISSION_GRANTED;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
requestPermissions(new String[].
{Manifest.permission.READ_PHONE_STATE}, 0);
requestPermissions(new String[]
{Manifest.permission.ACCESS_COARSE_LOCATION}, 1);
}
for (int i = 0; i < permissions.length; i++) {
permissionCheck = ContextCompat.checkSelfPermission(this,
permissions[i]);
if (permissionCheck == PackageManager.PERMISSION_DENIED) {
Log.e("main", "denied" + permissions[i]);
ActivityCompat.requestPermissions(this, permissions, i);
if
(ActivityCompat.shouldShowRequestPermissionRationale(this,
permissions[i])) {
Log.e("main", "shouldshow" + permissions[i]);
} else {
Log.e("main", "requesting" + permissions[i]);
ActivityCompat.requestPermissions(this, permissions, i);
}
break;
} else {
Log.e("main", "granted" + permissions[i]);
}
}
}
@TargetApi(21)
private void scanLeDevice(final boolean enable) {
if (enable) {
//stops scanning after a pre-defined scan period
mHandler.postDelayed(new Runnable() {
@Override
public void run() {
if (Build.VERSION.SDK_INT < 21) {
System.out.println("BLE// mBluetoothAdapter.stopLeScan(mLeScanCallback) ");
mBluetoothAdapter.stopLeScan(mLeScanCallback);
} else {
mBLEScanner.stopScan(mScanCallback);
System.out.println("BLE// mLEScanner.stopScan(mScanCallback) ");
}
}
}, SCAN_PERIOD);
if (Build.VERSION.SDK_INT < 21) {
System.out.println("BLE// mBluetoothAdapter.startLeScan(mLeScanCallback)");
mBluetoothAdapter.startLeScan(mLeScanCallback);
} else {
Log.e("main","starting scan for second"+mBLEScanner);
mBLEScanner.startScan(mScanCallback);
//mLEScanner.startScan(filters, settings, mScanCallback);
}
} else {
if (Build.VERSION.SDK_INT < 21) {
mBluetoothAdapter.stopLeScan(mLeScanCallback);
} else {
mBLEScanner.stopScan(mScanCallback);
}
}
}
private BluetoothAdapter.LeScanCallback mLeScanCallback = new BluetoothAdapter.LeScanCallback() {
@Override
public void onLeScan(final BluetoothDevice device, int rssi,
byte[] scanRecord) {
}
};
private ScanCallback mScanCallback = new ScanCallback() {
@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
@Override
public void onScanResult(int callbackType, ScanResult result) {
super.onScanResult(callbackType, result);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
Log.e("main","this name : "+result.getDevice().getName());
Log.e("main","this addr : "+result.getDevice().getAddress());
}
BluetoothDevice btDevice = result.getDevice();
}
@Override
public void onBatchScanResults(List<ScanResult> results) {
}
@Override
public void onScanFailed(int errorCode) {
Log.e("main", "Error Code: " + errorCode);
}
};
}
и сообщение журнала, как показано ниже.
3: 19: 59.167 3251-3251 / smartiot.ica.org.blelowtest E / main: grantandroid.permission.INTERNET 06-13 23: 19: 59.167 3251-3251 / smartiot.ica.org.blelowtestE / main: grantandroid.permission.ACCESS_NETWORK_STATE 06-13 23: 19: 59.167 3251-3251 / smartiot.ica.org.blelowtest E / main: grantandroid.permission.BLUETOOTH_ADMIN 06-13 23: 19: 59.168 3251-3251 / smartiot.ica.org.blelowtest E / main: grantandroid.permission.BLUETOOTH 06-13 23: 19: 59.168 3251-3251 / smartiot.ica.org.blelowtest E / main: deniedandroid.permission.ACCESS_COARSE_LOCATION 06-13 23:19:59.171 3251-3251 / smartiot.ica.org.blelowtest E / main: requesttingandroid.permission.ACCESS_COARSE_LOCATION 06-13 23: 20: 15.188 3251-3251 / smartiot.ica.org.blelowtest E / main: теперь вызывается Bluetooth с низким энергопотреблением 06-13 23: 20: 15.189 3251-3251 / smartiot.ica.org.blelowtest E / main: запуск сканирования для secondandroid.bluetooth.le.BluetoothLeScanner@e24e0e4 06-13 23: 20: 15.264 3251-3251 / smartiot.ica.org.blelowtest E / main: Код ошибки: 2
Код манифестаниже
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="smartiot.ica.org.mbluetooth">
<uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.BLUETOOTH" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.BLUETOOTH" />
<uses-feature android:name="android.hardware.bluetooth_le" android:required="true"/>
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<application