• Android中蓝牙设备的状态值管理


    Android中,蓝牙状态可以通过多种方式来描述,主要包括蓝牙适配器状态蓝牙设备连接状态以及蓝牙广播状态,其关键的蓝牙状态实现类有BluetoothAdapter、BluetoothDevicePairer、BluetoothDevice、BluetoothProfile,详细介绍如下:

    BluetoothAdapter

    • BluetoothAdapter 是蓝牙通信的入口点,代表本地蓝牙适配器(蓝牙设备),通过该类,可发现其他蓝牙设备,查询已绑定的设备列表,以及创建和管理蓝牙连接

    蓝牙适配器(BluetoothAdapter)的状态描述了本地蓝牙设备的功能状态:

    • 开启/关闭:使用 BluetoothAdapter.isEnabled() 来检查蓝牙是否开启
    • 正在开启/正在关闭:isDiscovering(),检查蓝牙适配器是否正处于发现模式
    • 获取蓝牙适配器的当前状态:在Android 4.2(API级别17)及以下版本中,可以使用 getState() 方法获取蓝牙适配器的当前状态,该方法返回一个int类型的枚举值,可以用来判断蓝牙是否正在开启或关闭
    • 连接状态:使用 BluetoothAdapter.getProfileConnectionState() 来获取特定蓝牙配置文件(如A2DP或HEADSET)的连接状态

    BluetoothDevice

    • BluetoothDevice类代表了一个远程蓝牙设备,包含了该设备的地址(MAC地址)、名称和其他一些基本信息的属性,可使用该类,请求与远程设备的配对和连接,或者查询关于设备的信息,如绑定状态等
    • 每个蓝牙设备都有一个唯一的地址,通过该地址,Android设备可以与之建立连接和通信

    蓝牙设备的连接状态检查方法:

    • 是否已连接:使用 BluetoothDevice.isConnected() 来检查特定设备是否已连接。
    • 绑定状态:使用 BluetoothDevice.getBondState() 来检查设备是否已绑定(配对)。

    BluetoothDevice中的状态值

    • BluetoothDevice.BOND_NONE:表示与远程设备没有绑定关系
    • BluetoothDevice.BOND_BONDING:表示正在与远程设备建立绑定关系
    • BluetoothDevice.BOND_BONDED:表示已经与远程设备建立了绑定关系
      连接状态广播:
    • BluetoothDevice.ACTION_ACL_CONNECTED:表示与远程设备的连接已建立
    • BluetoothDevice.ACTION_ACL_DISCONNECTED:表示与远程设备的连接已断开
    • BluetoothDevice.ACTION_ACL_DISCONNECT_REQUESTED:表示请求 断开和远程设备的连接

    BluetoothProfile

    • BluetoothProfile是一系列接口的集合,用于定义蓝牙通信的不同配置文件本身不是实现类,Android提供了许多实现该接口的内部类,如:BluetoothA2dp、BluetoothHeadset 等,用于处理特定类型的蓝牙通信

    • 配置文件中定义设备在特定类型通信中应遵循的行为和规则(如:蓝牙耳机使用的配置文件和蓝牙鼠标不同)

    • Android中定义了一些标准的蓝牙配置文件,如:HEADSET (耳机)、A2DP(高级音频分发配置文件)、HEALTH(健康设备)等。每个配置文件都有其特定的通信协议和用途,开发者可通过实现这些接口来创建和特定类型的蓝牙设备交互的应用程序
      BluetoothHeadset:实现蓝牙耳机配置文件的类,用于管理蓝牙耳机与Android设备的连接
      BluetoothA2dp:实现A2dp配置文件的类,用于管理高级音频分发
      BluetoothHealth:实现蓝牙健康设备配置文件的类,用于与蓝牙健康设备交互

    BluetoothProfile中的状态值

    • STATE_CONNECTED/STATE_DISCONNECTED:表示当前配置文件(如A2DP、HEADSET)已经与远程设备建立连接/没有建立连接
    • STATE_CONNECTING/STATE_DISCONNECTING:表示当前配置文件正在尝试与远程设备建立连接/正在尝试断开与远程设备的连接

    BluetoothDevicePairer

    是否已连接:使用 BluetoothDevice.isConnected() 来检查特定设备是否已连接。
    连接状态:使用 BluetoothAdapter.getProfileConnectionState() 来获取特定蓝牙配置文件(如A2DP或HEADSET)的连接状态。
    绑定状态:使用 BluetoothDevice.getBondState() 来检查设备是否已绑定(配对)。

    • 在某些情况下,BluetoothDevicePairer可能是一个第三方库或在某些定制Android系统中的类,用于简化蓝牙设备的配对(pairing)和绑定(bonding)过程
    • 配对是蓝牙设备之间建立安全连接的过程,通常需要用户输入一个配对码(通常是PIN码)来确保两个设备之间的通信是安全的
    • 如果BluetoothDevicePairer是某个特定实现,则可能提供了一系列方法来管理该过程,包括请求配对、确认配对请求、管理已配对的设备列表等
      由于Android系统的开放性,不同的设备或系统版本可能会提供不同的API或工具类,因此BluetoothDevicePairer可能并不是通用的Android开发术语

    获取和监听蓝牙状态

    • 蓝牙广播状态通常涉及到监听系统发出的广播,以便了解蓝牙状态的变化:
    • 状态改变:通过注册接收器(BroadcastReceiver)监听 ACTION_STATE_CHANGED广播,来得知蓝牙适配器的状态改变
    • 发现模式:通过 ACTION_DISCOVERY_STARTED 和ACTION_DISCOVERY_FINISHED广播来监听蓝牙发现模式的状态
    • 配对请求:通过ACTION_PAIRING_REQUEST 广播来处理配对请求
    • 这些状态帮助开发者理解和跟踪蓝牙设备在特定时刻的状态,以便于编写逻辑来处理不同的状态变化,获取和监听蓝牙状态的代码示例(使用BroadcastReceiver & BluetoothAdapter监听蓝牙状态变化):
    	// 获取蓝牙适配器
    BluetoothAdapter bluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
     
    // 检查蓝牙是否开启
    if (bluetoothAdapter.isEnabled()) {
       // 蓝牙已开启
    }
     
    // 注册广播接收器来监听蓝牙状态变化
    IntentFilter filter = new IntentFilter(BluetoothAdapter.ACTION_STATE_CHANGED);
    registerReceiver(mReceiver, filter);
     
    // 广播接收器内部类
    private final BroadcastReceiver mReceiver = new BroadcastReceiver() {
       @Override
       public void onReceive(Context context, Intent intent) {
           final String action = intent.getAction();
           if (action.equals(BluetoothAdapter.ACTION_STATE_CHANGED)) {
               int state = intent.getIntExtra(BluetoothAdapter.EXTRA_STATE, BluetoothAdapter.ERROR);
               switch (state) {
                   case BluetoothAdapter.STATE_OFF:
                       // 蓝牙已关闭
                       break;
                   case BluetoothAdapter.STATE_TURNING_ON:
                       // 蓝牙正在开启
                       break;
                   case BluetoothAdapter.STATE_ON:
                       // 蓝牙已开启
                       break;
                   case BluetoothAdapter.STATE_TURNING_OFF:
                       // 蓝牙正在关闭
                       break;
               }
           }
       }
    };
     
    // 在不需要时注销广播接收器
    @Override
    protected void onDestroy() {
       super.onDestroy();
       unregisterReceiver(mReceiver);
    }
    
    • 或使用BluetoothDevice监听蓝牙状态变化:
    // 假设你有一个BroadcastReceiver来监听蓝牙状态变化
    private BroadcastReceiver mReceiver = new BroadcastReceiver() {
       @Override
       public void onReceive(Context context, Intent intent) {
           String action = intent.getAction();
           if (BluetoothDevice.ACTION_BOND_STATE_CHANGED.equals(action)) {
               int bondState = intent.getIntExtra(BluetoothDevice.EXTRA_BOND_STATE, BluetoothDevice.ERROR);
               switch (bondState) {
                   case BluetoothDevice.BOND_NONE:
                       // 设备未绑定
                       break;
                   case BluetoothDevice.BOND_BONDING:
                       // 正在绑定
                       break;
                   case BluetoothDevice.BOND_BONDED:
                       // 设备已绑定
                       break;
               }
           } else if (BluetoothDevice.ACTION_ACL_CONNECTED.equals(action)) {
               // 设备已连接
           } else if (BluetoothDevice.ACTION_ACL_DISCONNECTED.equals(action)) {
               // 设备已断开
           }
           // 其他状态处理...
       }
    };
    

    小结

    • 从Android6.0(API 23)开始,Google引入了新的权限模型,要求应用程序在使用蓝牙功能时请求相应的权限,并且用户必须在运行时明确授权
    • 在Android蓝牙开发时,开发者通常使用BluetoothAdapter 发现其他蓝牙设备,查询已绑定的设备列表,以及创建和管理蓝牙连接;BluetoothAdapter来获取已配对的设备列表;使用BluetoothDevice来与单个设备交互;使用BluetoothProfile来处理特定类型的蓝牙通信
    • 蓝牙广播状态通常涉及到监听系统发出的广播,以便了解蓝牙状态的变化
  • 相关阅读:
    东南亚三国(新/马/菲)2022女装市场趋势解读及爆品指南
    java项目springboot医院固定资产检修管理系统
    @JsonDeserialize和@JsonSerialize注解的使用
    【Java】UnsupportedClassVersionError错误
    Python实现基于用户的协同过滤推荐算法构建电影推荐系统
    零基础学Java(12)静态字段与静态方法
    ASP.NET Core 在 IIS 下的两种部署模式
    Wakeup Source框架设计与实现
    谈了这么久的无代码到底是什么?
    Pytorch利用ddddocr辅助识别点选验证码
  • 原文地址:https://blog.csdn.net/FlyingFish868/article/details/139646318