Android 蓝牙设备的查找和连接

1.权限
使用蓝牙设备需要先在Manifest中开放权限,位置如下。

[html] view plaincopy

  1. <manifest ...>
  2. <application ...>
  3. ...
  4. </application>
  5. // 使用蓝牙设备的权限
  6. <uses-permission android:name="android.permission.BLUETOOTH" />
  7. // 管理蓝牙设备的权限
  8. <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
  9. </manifest>

2.打开蓝牙
获得蓝牙适配器(android.bluetooth.BluetoothAdapter),检查该设备是否支持蓝牙,如果支持,就打开蓝牙。

[java] view plaincopy

  1. // 检查设备是否支持蓝牙
  2. adapter = BluetoothAdapter.getDefaultAdapter();
  3. if (adapter == null)
  4. {
  5. // 设备不支持蓝牙
  6. }
  7. // 打开蓝牙
  8. if (!adapter.isEnabled())
  9. {
  10. Intent intent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);
  11. // 设置蓝牙可见性,最多300秒
  12. intent.putExtra(BluetoothAdapter.EXTRA_DISCOVERABLE_DURATION, 300);
  13. context.startActivity(intent);
  14. }

3.获取已配对的蓝牙设备(android.bluetooth.BluetoothDevice)
首次连接某蓝牙设备需要先配对,一旦配对成功,该设备的信息会被保存,以后连接时无需再配对,所以已配对的设备不一定是能连接的。

[java] view plaincopy

  1. BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
  2. Set<BluetoothDevice> devices = adapter.getBondedDevices();
  3. for(int i=0; i<devices.size(); i++)
  4. {
  5. BluetoothDevice device = (BluetoothDevice) devices.iterator().next();
  6. System.out.println(device.getName());
  7. }

4.搜索周围的蓝牙设备
适配器搜索蓝牙设备后将结果以广播形式传出去,所以需要自定义一个继承广播的类,在onReceive方法中获得并处理蓝牙设备的搜索结果。

[java] view plaincopy

  1. // 设置广播信息过滤
  2. IntentFilter intentFilter = new IntentFilter();
  3. intentFilter.addAction(BluetoothDevice.ACTION_FOUND);
  4. intentFilter.addAction(BluetoothDevice.ACTION_BOND_STATE_CHANGED);
  5. intentFilter.addAction(BluetoothAdapter.ACTION_SCAN_MODE_CHANGED);
  6. intentFilter.addAction(BluetoothAdapter.ACTION_STATE_CHANGED);
  7. // 注册广播接收器,接收并处理搜索结果
  8. context.registerReceiver(receiver, intentFilter);
  9. // 寻找蓝牙设备,android会将查找到的设备以广播形式发出去
  10. adapter.startDiscovery();

自定义广播类

[java] view plaincopy

  1. private BroadcastReceiver receiver = new BroadcastReceiver() {
  2. @Override
  3. public void onReceive(Context context, Intent intent) {
  4. String action = intent.getAction();
  5. if (BluetoothDevice.ACTION_FOUND.equals(action)) {
  6. BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
  7. System.out.println(device.getName());
  8. }
  9. }
  10. }

5.蓝牙设备的配对和状态监视

[java] view plaincopy

  1. private BroadcastReceiver receiver = new BroadcastReceiver() {
  2. @Override
  3. public void onReceive(Context context, Intent intent) {
  4. String action = intent.getAction();
  5. if (BluetoothDevice.ACTION_FOUND.equals(action)) {
  6. // 获取查找到的蓝牙设备
  7. BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
  8. System.out.println(device.getName());
  9. // 如果查找到的设备符合要连接的设备,处理
  10. if (device.getName().equalsIgnoreCase(name)) {
  11. // 搜索蓝牙设备的过程占用资源比较多,一旦找到需要连接的设备后需要及时关闭搜索
  12. adapter.cancelDiscovery();
  13. // 获取蓝牙设备的连接状态
  14. connectState = device.getBondState();
  15. switch (connectState) {
  16. // 未配对
  17. case BluetoothDevice.BOND_NONE:
  18. // 配对
  19. try {
  20. Method createBondMethod = BluetoothDevice.class.getMethod("createBond");
  21. createBondMethod.invoke(device);
  22. } catch (Exception e) {
  23. e.printStackTrace();
  24. }
  25. break;
  26. // 已配对
  27. case BluetoothDevice.BOND_BONDED:
  28. try {
  29. // 连接
  30. connect(device);
  31. } catch (IOException e) {
  32. e.printStackTrace();
  33. }
  34. break;
  35. }
  36. }
  37. } else if(BluetoothDevice.ACTION_BOND_STATE_CHANGED.equals(action)) {
  38. // 状态改变的广播
  39. BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
  40. if (device.getName().equalsIgnoreCase(name)) {
  41. connectState = device.getBondState();
  42. switch (connectState) {
  43. case BluetoothDevice.BOND_NONE:
  44. break;
  45. case BluetoothDevice.BOND_BONDING:
  46. break;
  47. case BluetoothDevice.BOND_BONDED:
  48. try {
  49. // 连接
  50. connect(device);
  51. } catch (IOException e) {
  52. e.printStackTrace();
  53. }
  54. break;
  55. }
  56. }
  57. }
  58. }
  59. }

6.蓝牙设备的连接

[java] view plaincopy

    1. private void connect(BluetoothDevice device) throws IOException {
    2. // 固定的UUID
    3. final String SPP_UUID = "00001101-0000-1000-8000-00805F9B34FB";
    4. UUID uuid = UUID.fromString(SPP_UUID);
    5. BluetoothSocket socket = device.createRfcommSocketToServiceRecord(uuid);
    6. socket.connect();
    7. }
时间: 2024-10-08 22:09:05

Android 蓝牙设备的查找和连接的相关文章

【转】android蓝牙开发 蓝牙设备的查找和连接

1.  首先,要操作蓝牙,先要在AndroidManifest.xml里加入权限 // 管理蓝牙设备的权限 <uses-permissionandroid:name="android.permission.BLUETOOTH_ADMIN" /> // 使用蓝牙设备的权限 <uses-permissionandroid:name="android.permission.BLUETOOTH" /> 2.打开蓝牙获得蓝牙适配器(android.bl

Android - 设置adb的usb连接配置

设置adb的usb连接配置 本文地址: http://blog.csdn.net/caroline_wendy 把须要測试的手机连接入电脑.通过系统查找USB连接配置,找到厂商ID: 把ID加入进adb_usb.ini; 使用命令: vi ~/.android/adb_usb.ini 如: 0x2717 0x9bb5 使用adb命令: adb kill-server adb start-server 能够方便Android Studio查找USB连接设备.

如何实现android蓝牙开发 自动配对连接,并不弹出提示框

如何实现android蓝牙开发 自动配对连接,并不弹出提示框 之前做一个android版的蓝牙,遇到最大的难题就是自动配对. 上网查资料说是用反射createBond()和setPin(),但测试时进行配对还是会出现提示,但配对是成功了 我就开始查找怎么关闭这个蓝牙配对提示框,后面还是伟大的android源码帮助了我. 在源码 BluetoothDevice 类中还有两个隐藏方法 cancelBondProcess()和cancelPairingUserInput() 这两个方法一个是取消配对进

Android开发实践:WIFI连接功能的封装

在上一篇文章<Android开发实践:WIFI扫描功能的封装>介绍了如何利用Andriod的API实现WIFI的扫描,本文则重点讲述一下如何连接WIFI吧,在此,也给出一个封装WIFI连接过程的类,提供简单的接口以供在各个代码工程中复用. 与WIFI扫描类似,WIFI的连接同样是一个耗时的过程,所以需要放到线程中执行,通过回调来通知调用者连接结果.该回调接口的定义如下: public interface WifiConnectListener { public void OnWifiConne

Android利用广播监听设备网络连接(断网)的变化情况

MainActivity如下: package cc.testnetworkchange; import android.os.Bundle; import android.app.Activity; /** * Demo描述: * 利用广播监听设备网络连接的变化情况 * 亦可借此监测到设备是否已经断开网络 */ public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedI

Android 蓝牙设备的开启与关闭功能的实现

本文主要是关于Android蓝牙设备的开启与关闭,很简单,详细请看代码. 1.MainActivity.java public class MainActivity extends Activity { private String TAG="MainActivity"; private Button startBtn; private Button stopBtn; BluetoothAdapter mBluetoothAdapter; @Override protected voi

Android内存泄漏查找和解决

Android内存泄漏查找和解决 目录: 内存泄漏的概念 一个内存泄漏的例子 Java中"失效"的private修饰符 回头看内存泄漏例子泄漏的重点 强引用与弱引用 解决内部类的内存泄漏 Context造成的泄漏 使用LeakCanary工具查找内存泄漏 总结 一.内存泄漏概念 1.什么是内存泄漏? 用动态存储分配函数动态开辟的空间,在使用完毕后未释放,结果导致一直占据该内存单元.直到程序结束.即所谓的内存泄漏. 其实说白了就是该内存空间使用完毕之后未回收 2.内存泄漏会导致的问题 内

python字符串的操作(去掉空格strip(),切片,查找,连接join(),分割split(),转换首字母大写, 转换字母大小写...)

#可变变量:list, 字典#不可变变量:元祖,字符串字符串的操作(去掉空格, 切片, 查找, 连接, 分割, 转换首字母大写, 转换字母大小写, 判断是否是数字字母, 成员运算符(in / not in))字符串使用时用单引号或者双引号括起来: var1 = 'hello' var2 ="world" 字符串不能修改值, 如下例所示: 以下是字符串常用的一些操作. 1. 去掉空格str.strip() # 去掉两边的空格和换行符str.strip('a') # 去掉两边指定的字符st

有关如何修复Android手机上的SSL连接错误的快速指南

"您的连接不是私人的",对于这个问题相信不少朋友在Android设备上都出现过,其实这个问题是Android设备最常见的问题之一,这可能会让您感到困惑,因为它甚至出现在最新的操作系统和最新的设备上,但这不是什么大问题,但是还是让我们来看看如何修复Android手机上的SSL连接错误吧. 让我们从SSL/TLS证书开始吧 首先是一点背景知识.正如你可能知道的,SSL证书旨在对你即将进行访问的网站进行身份验证——过去这是由证书机构进行的,证书机构能够签发证书,确保你知道谁在你的连接的另一端