- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是应用程序中 BLE 实现的新手,但我能够连接到应用程序中的 BLE 设备。
当应用程序关闭时,连接断开,但即使应用程序关闭,我也需要能够连接,因为我将从微 Controller 接收数据。
任何人都可以给我建议或帮助我解决问题吗?
是否只是因为它正在等待发送数据而被连接而当应用程序关闭时我遇到了问题?
package com.example.Pillwoah;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
import android.app.Activity;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice;
import android.bluetooth.BluetoothGatt;
import android.bluetooth.BluetoothGattCallback;
import android.bluetooth.BluetoothGattCharacteristic;
import android.bluetooth.BluetoothGattService;
import android.bluetooth.BluetoothManager;
import android.bluetooth.BluetoothProfile;
import android.bluetooth.BluetoothSocket;
import android.bluetooth.le.BluetoothLeScanner;
import android.bluetooth.le.ScanCallback;
import android.bluetooth.le.ScanResult;
import android.bluetooth.le.ScanSettings;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.content.pm.PackageManager;
import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
import android.os.Message;
import android.util.Log;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.AdapterView;
import android.widget.Button;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import java.io.IOException;
import java.lang.reflect.Method;
import java.util.List;
import java.util.Set;
import java.util.UUID;
import static android.bluetooth.BluetoothDevice.ACTION_BOND_STATE_CHANGED;
import static android.bluetooth.BluetoothDevice.BOND_BONDED;
import static android.bluetooth.BluetoothDevice.BOND_BONDING;
import static android.bluetooth.BluetoothDevice.BOND_NONE;
import static android.bluetooth.BluetoothDevice.EXTRA_BOND_STATE;
public class MainActivity4 extends AppCompatActivity {
protected static final String TAG = "TAG";
TextView phoneName, deviceList;
private Handler mHandler;
private BluetoothAdapter bluetoothAdapter;
private Set<BluetoothDevice> pairedDevices;
private ArrayAdapter<String> BAarray, BANewArray;
private ListView DeviceList, NewDevice;
private boolean mScanning;
private BluetoothGatt mGatt;
private BluetoothLeScanner bluetoothLeScanner = BluetoothAdapter.getDefaultAdapter().getBluetoothLeScanner();
private BluetoothSocket BTSocket = null;
private BluetoothDevice device = null;
private final static UUID BTMODULEUUID = UUID.fromString("00001101-0000-1000-8000-00805F9B34FB");
private final static int REQUEST_ENABLE_BT = 1;
private final static int REQUEST_CONNECT_DEVICE = 2;
private final static int REQUEST_COARSE_LOCATION = 1;
private static final long SCAN_PERIOD = 10000;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main4);
Button mEnable = (Button) findViewById(R.id.enable);
Button mOff = (Button) findViewById(R.id.off);
Button mPaired = (Button) findViewById(R.id.paired);
Button mDiscover = (Button) findViewById(R.id.discover);
deviceList = findViewById(R.id.deviceTitle);
deviceList.setText(null);
phoneName = findViewById(R.id.name);
phoneName.setText(getLocalBtName());
mHandler = new Handler();
//BA = BluetoothAdapter.getDefaultAdapter();
// Initializes Bluetooth adapter.
final BluetoothManager bluetoothManager = (BluetoothManager) getSystemService(Context.BLUETOOTH_SERVICE);
bluetoothAdapter = bluetoothManager.getAdapter();
// Ensures Bluetooth is available on the device and it is enabled. If not,
// displays a dialog requesting user permission to enable Bluetooth.
if (bluetoothAdapter == null || !bluetoothAdapter.isEnabled()) {
Intent enableBtIntent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);
startActivityForResult(enableBtIntent, REQUEST_ENABLE_BT);
}
// Build ScanSetting
ScanSettings.Builder scanSetting = new ScanSettings.Builder()
.setScanMode(ScanSettings.SCAN_MODE_LOW_POWER)
.setReportDelay(5000);
scanSetting.build();
BAarray = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1);
BANewArray = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1);
DeviceList = (ListView)findViewById(R.id.deviceListView);
DeviceList.setAdapter(BAarray);
DeviceList.setOnItemClickListener(DeviceClickListener);
NewDevice = (ListView)findViewById(R.id.newDeviceView);
NewDevice.setAdapter(BANewArray);
NewDevice.setOnItemClickListener(DeviceClickListener);
if (bluetoothAdapter == null) {
Toast.makeText(this, "Bluetooth not supported", Toast.LENGTH_SHORT).show();
finish();
} else {
mEnable.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
checkLocationPermission();
bluetoothOn(v);
}
});
mOff.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
bluetoothOff(v);
}
});
mPaired.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
checkLocationPermission();
listPairedDevices(v);
}
});
mDiscover.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
checkLocationPermission();
discover(v);
}
});
}
};
protected void checkLocationPermission() {
if (ContextCompat.checkSelfPermission(this, android.Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
ActivityCompat.requestPermissions(this, new String[]{android.Manifest.permission.ACCESS_FINE_LOCATION}, REQUEST_COARSE_LOCATION);
}
}
@Override
public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) {
switch (requestCode) {
case REQUEST_COARSE_LOCATION: {
if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
Toast.makeText(getApplicationContext(), "Permission on", Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(getApplicationContext(), "Permission off", Toast.LENGTH_SHORT).show();
}
break;
}
}
}
public String getLocalBtName(){
if(bluetoothAdapter == null){
bluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
}
String name = bluetoothAdapter.getName();
if(name == null){
name = bluetoothAdapter.getAddress();
}
return name;
}
@Override
protected void onResume() {
super.onResume();
// Ensures Bluetooth is enabled on the device. If Bluetooth is not currently enabled,
// fire an intent to display a dialog asking the user to grant permission to enable it.
if (!bluetoothAdapter.isEnabled()) {
if (!bluetoothAdapter.isEnabled()) {
Intent enableBtIntent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);
startActivityForResult(enableBtIntent, REQUEST_ENABLE_BT);
}
}else {
if (Build.VERSION.SDK_INT >= 21) {
bluetoothLeScanner = bluetoothAdapter.getBluetoothLeScanner();
ScanSettings scanSetting = new ScanSettings.Builder()
.setScanMode(ScanSettings.SCAN_MODE_LOW_POWER)
.build();
}
//scanLeDevice(true);
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
// User chose not to enable Bluetooth.
if (requestCode == REQUEST_ENABLE_BT && resultCode == Activity.RESULT_CANCELED) {
finish();
return;
}
super.onActivityResult(requestCode, resultCode, data);
}
@Override
protected void onPause() {
super.onPause();
scanLeDevice(false);
BANewArray.clear();
BAarray.clear();
}
@Override
public void onDestroy() {
if (mGatt == null) {
return;
}
Log.i("destroy ", "ble destroy");
BANewArray.clear();
BAarray.clear();
mGatt.close();
mGatt = null;
super.onDestroy();
System.out.println("BLE// destroy");
}
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;
bluetoothLeScanner.stopScan(leScanCallback);
System.out.println("BLE// bluetoothLeScanner.stopScan(leScanCallback)");
}
}, SCAN_PERIOD);
mScanning = true;
bluetoothLeScanner.startScan(leScanCallback);
System.out.println("BLE// bluetoothLeScanner.startScan(leScanCallback)");
} else {
mScanning = false;
bluetoothLeScanner.stopScan(leScanCallback);
System.out.println("BLE// bluetoothLeScanner.stopScan(leScanCallback)");
}
}
// Device scan callback.
private ScanCallback leScanCallback = new ScanCallback() {
@Override
public void onScanResult(int callbackType, ScanResult result) {
super.onScanResult(callbackType, result);
Log.i("callbackType", String.valueOf(callbackType));
Log.i("result", result.toString());
//Log.i("Device Name: ", result.getDevice().getName());
System.out.println("Signal: " + result.getRssi());
BluetoothDevice btDevice = result.getDevice();
System.out.println("name: " + btDevice);
BANewArray.add(btDevice.getName() + "\n" + btDevice.getAddress());
}
@Override
public void onBatchScanResults(List<ScanResult> results) {
System.out.println("BLE// onBatchScanResults");
for (ScanResult sr : results) {
Log.i("ScanResult - Results", sr.toString());
}
}
@Override
public void onScanFailed(int errorCode) {
System.out.println("BLE// onScanFailed");
Log.e("Scan Failed", "Error Code: " + errorCode);
}
};
private void bluetoothOn(View view){
if(!bluetoothAdapter.isEnabled()){
Intent enableIntent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);
startActivityForResult(enableIntent, REQUEST_ENABLE_BT);
Toast.makeText(getApplicationContext(), "Bluetooth turned on", Toast.LENGTH_SHORT).show();
}
else{
Toast.makeText(getApplicationContext(), "Bluetooth is already on", Toast.LENGTH_SHORT).show();
}
}
private void bluetoothOff(View view){
bluetoothAdapter.disable();
BAarray.clear();
BANewArray.clear();
Toast.makeText(getApplicationContext(), "Bluetooth turned off", Toast.LENGTH_SHORT).show();
}
public void connectToDevice(BluetoothDevice device) {
Toast.makeText(getApplicationContext(), "BLE// connectToDevice()", Toast.LENGTH_SHORT).show();
//System.out.println("BLE// connectToDevice()");
bluetoothAdapter.cancelDiscovery();
if (mGatt == null) {
mGatt = device.connectGatt(this, true, gattCallback); //Connect to a GATT Server
scanLeDevice(false);// will stop after first device detection
}
else{
//mGatt.discoverServices();
Toast.makeText(getApplicationContext(), "Error", Toast.LENGTH_SHORT).show();
}
}
private final BluetoothGattCallback gattCallback = new BluetoothGattCallback() {
@Override
public void onConnectionStateChange(BluetoothGatt gatt, int status, int newState) {
System.out.println("BLE// BluetoothGattCallback");
Log.i("onConnectionStateChange", "Status: " + status);
switch (newState) {
case BluetoothProfile.STATE_CONNECTED:
Log.i("gattCallback", "STATE_CONNECTED");
gatt.discoverServices();
break;
case BluetoothProfile.STATE_CONNECTING:
Log.i("gattCallback", "STATE_CONNECTING");
break;
case BluetoothProfile.STATE_DISCONNECTED:
Log.e("gattCallback", "STATE_DISCONNECTED");
//gatt.close();
break;
default:
Log.e("gattCallback", "STATE_OTHER");
}
}
@Override
//New services discovered
public void onServicesDiscovered(BluetoothGatt gatt, int status) {
List<BluetoothGattService> services = gatt.getServices();
Log.i("onServicesDiscovered", services.toString());
gatt.readCharacteristic(services.get(1).getCharacteristics().get(0));
}
@Override
//Result of a characteristic read operation
public void onCharacteristicRead(BluetoothGatt gatt, BluetoothGattCharacteristic characteristic, int status) {
Log.i("onCharacteristicRead", characteristic.toString());
gatt.disconnect();
}
};
private void listPairedDevices(View view){
BANewArray.clear();
BAarray.clear();
deviceList.setText("Previously Connected Devices");
pairedDevices = bluetoothAdapter.getBondedDevices();
if(bluetoothAdapter.isEnabled()){
BANewArray.clear();
BAarray.clear();
for(BluetoothDevice device : pairedDevices)
BAarray.add(device.getName() + "\n" + device.getAddress());
Toast.makeText(getApplicationContext(), "Show paired devices", Toast.LENGTH_SHORT).show();
}
else{
Toast.makeText(getApplicationContext(), "Bluetooth not on", Toast.LENGTH_SHORT).show();
}
}
private void discover(View view) {
deviceList.setText("Available Devices");
BANewArray.clear();
BAarray.clear();
scanLeDevice(true);
}
private AdapterView.OnItemClickListener DeviceClickListener = new AdapterView.OnItemClickListener() {
public void onItemClick(AdapterView<?> av, View v, int arg2, long arg3) {
//BTSocket = null;
String info = ((TextView) v).getText().toString();
final String address = info.substring(info.length() - 17);
final String name = info.substring(0, info.length() - 17);
device = bluetoothAdapter.getRemoteDevice(address);
Log.d(TAG, "You clicked");
Log.d(TAG, "Device name" + name);
Log.d(TAG, "Address" + address);
Toast.makeText(getApplicationContext(), address, Toast.LENGTH_SHORT).show();
connectToDevice(device);
}
};
}
最佳答案
您可以使用FroegroundService
在后台工作,你的应用程序被关闭后,所以会出现不可关闭的通知,您的应用程序将继续工作。这是在新的Android版本的最佳解决方案,因为简单的服务将搭载Android被杀死。您可以找到有关this article与FroegroundService
的更多信息。
关于android - 应用程序关闭时蓝牙设备断开连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66253404/
我是 C 语言新手,我编写了这个 C 程序,让用户输入一年中的某一天,作为返回,程序将输出月份以及该月的哪一天。该程序运行良好,但我现在想简化该程序。我知道我需要一个循环,但我不知道如何去做。这是程序
我一直在努力找出我的代码有什么问题。这个想法是创建一个小的画图程序,并有红色、绿色、蓝色和清除按钮。我有我能想到的一切让它工作,但无法弄清楚代码有什么问题。程序打开,然后立即关闭。 import ja
我想安装screen,但是接下来我应该做什么? $ brew search screen imgur-screenshot screen
我有一个在服务器端工作的 UDP 套接字应用程序。为了测试服务器端,我编写了一个简单的 python 客户端程序,它发送消息“hello world how are you”。服务器随后应接收消息,将
我有一个 shell 脚本,它运行一个 Python 程序来预处理一些数据,然后运行一个 R 程序来执行一些长时间运行的任务。我正在学习使用 Docker 并且我一直在运行 FROM r-base:l
在 Linux 中。我有一个 c 程序,它读取一个 2048 字节的文本文件作为输入。我想从 Python 脚本启动 c 程序。我希望 Python 脚本将文本字符串作为参数传递给 c 程序,而不是将
前言 最近开始整理笔记里的库存草稿,本文是 23 年 5 月创建的了(因为中途转移到 onedrive,可能还不止) 网页调起电脑程序是经常用到的场景,比如百度网盘下载,加入 QQ 群之类的 我
对于一个类,我被要求编写一个 VHDL 程序,该程序接受两个整数输入 A 和 B,并用 A+B 替换 A,用 A-B 替换 B。我编写了以下程序和测试平台。它完成了实现和行为语法检查,但它不会模拟。尽
module Algorithm where import System.Random import Data.Maybe import Data.List type Atom = String ty
我想找到两个以上数字的最小公倍数 求给定N个数的最小公倍数的C++程序 最佳答案 int lcm(int a, int b) { return (a/gcd(a,b))*b; } 对于gcd,请查看
这个程序有错误。谁能解决这个问题? Error is :TempRecord already defines a member called 'this' with the same paramete
当我运行下面的程序时,我在 str1 和 str2 中得到了垃圾值。所以 #include #include #include using namespace std; int main() {
这是我的作业: 一对刚出生的兔子(一公一母)被放在田里。兔子在一个月大时可以交配,因此在第二个月的月底,每对兔子都会生出两对新兔子,然后死去。 注:在第0个月,有0对兔子。第 1 个月,有 1 对兔子
我编写了一个程序,通过对字母使用 switch 命令将十进制字符串转换为十六进制,但是如果我使用 char,该程序无法正常工作!没有 switch 我无法处理 9 以上的数字。我希望你能理解我,因为我
我是 C++ 新手(虽然我有一些 C 语言经验)和 MySQL,我正在尝试制作一个从 MySQL 读取数据库的程序,我一直在关注这个 tutorial但当我尝试“构建”解决方案时出现错误。 (我正在使
仍然是一个初学者,只是尝试使用 swift 中的一些基本函数。 有人能告诉我这段代码有什么问题吗? import UIKit var guessInt: Int var randomNum = arc
我正在用 C++11 编写一个函数,它采用 constant1 + constant2 形式的表达式并将它们折叠起来。 constant1 和 constant2 存储在 std::string 中,
我用 C++ 编写了这段代码,使用运算符重载对 2 个矩阵进行加法和乘法运算。当我执行代码时,它会在第 57 行和第 59 行产生错误,非法结构操作(两行都出现相同的错误)。请解释我的错误。提前致谢:
我是 C++ 的初学者,我想编写一个简单的程序来交换字符串中的两个字符。 例如;我们输入这个字符串:“EXAMPLE”,我们给它交换这两个字符:“E”和“A”,输出应该类似于“AXEMPLA”。 我在
我需要以下代码的帮助: 声明 3 个 double 类型变量,每个代表三角形的三个边中的一个。 提示用户为第一面输入一个值,然后 将用户的输入设置为您创建的代表三角形第一条边的变量。 将最后 2 个步
我是一名优秀的程序员,十分优秀!