Android开发之蓝牙(Bluetooth)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android开发之蓝牙(Bluetooth)相关的知识,希望对你有一定的参考价值。

参考技术A

在上一篇中有介绍了Wifi与网络连接处理
android开发之WiFi与网络连接处理
下面,来继续说说Android中蓝牙的基本使用。

Bluetooth是目前使用的最广泛的无线通讯协议之一,主要针对短距离设备通讯(10米),常用于连接耳机、鼠标和移动通讯设备等。

值得一提的是:
android4.2新增了部分新功能,但是对于Bluetooth熟悉的人或许开始头疼了,那就是Android4.2引入了一个新的蓝牙协议栈针BLE。谷歌和Broadcom之间的合作,开发新的蓝牙协议栈,取代了基于堆栈的Bluez。因此市场上出现了老设备的兼容问题,很多蓝牙设备在android4.2手机上不能正常使用。

BluetoothAdapter简单点来说就是代表了本设备(手机、电脑等)的蓝牙适配器对象。

first:we need permission
要操作蓝牙,先要在AndroidManifest.xml里加入权限

**下面来看看如何使用蓝牙。 **↓↓↓****
Demo已就绪:

返回值:如果设备具备蓝牙功能,返回BluetoothAdapter 实例;否则,返回null对象。

打开蓝牙设备的方式:
1.直接调用函数enable()去打开蓝牙设备 ;
2.系统API去打开蓝牙设备,该方式会弹出一个对话框样式的Activity供用户选择是否打开蓝牙设备。

注意: 1.如果蓝牙已经开启,不会弹出该Activity界面。2.在目前大多数Android手机中,是不支持在飞行模式下开启蓝牙的。如果蓝牙已经开启,那么蓝牙的开关 ,状态会随着飞行模式的状态而发生改变。

1. 搜索蓝牙设备
使用BluetoothAdapter的startDiscovery()方法来搜索蓝牙设备
startDiscovery()方法是一个异步方法,调用后会立即返回。该方法会进行对其他蓝牙设备的搜索,该过程会持续12秒。该方法调用后,搜索过程实际上是在一个System Service中进行的,所以可以调用cancelDiscovery()方法来停止搜索(该方法可以在未执行discovery请求时调用)。

系统开始搜索蓝牙设备
^( *  ̄(oo) ̄ ) ^ 系统会发送以下三个广播:

2.扫描设备

3.定义广播接收器接收搜索结果

4.注册广播

获取附近的蓝牙设备

第一步建立连接:首先Android sdk(2.0以上版本)支持的蓝牙连接是通过BluetoothSocket建立连接,服务端BluetoothServerSocket和客户端(BluetoothSocket)需指定同样的UUID,才能建立连接,因为建立连接的方法会阻塞线程,所以服务器端和客户端都应启动新线程连接。

(这里的服务端和客户端是相对来说的)
两个蓝牙设备之间的连接,则必须实现服务端与客户端的机制。
当两个设备在同一个RFCOMM channel下分别拥有一个连接的BluetoothSocket,这两个设备才可以说是建立了连接。

服务端设备与客户端设备获取BluetoothSocket的途径是不同的。
1,服务端设备是通过accepted一个incoming connection来获取的,
2,客户端设备则是通过打开一个到服务端的RFCOMM channel来获取的。

服务端
通过调用BluetoothAdapter的listenUsingRfcommWithServiceRecord(String, UUID)方法来获取BluetoothServerSocket(UUID用于客户端与服务端之间的配对)

客户端
调用BluetoothService的createRfcommSocketToServiceRecord(UUID)方法获取BluetoothSocket(该UUID应该同于服务端的UUID)。
调用BluetoothSocket的connect()方法(该方法为block方法),如果UUID同服务端的UUID匹配,并且连接被服务端accept,则connect()方法返回。

数据传递,通过以上操作,就已经建立的BluetoothSocket连接了,数据传递无非是通过流的形式
获取流

该类就是关于远程蓝牙设备的一个描述。通过它可以和本地蓝牙设备---BluetoothAdapter连接通信。

好多东西我也不知道怎么描述,下面给出Demo:
刚好有刚学习的小伙伴问我ListView怎么用,那我就用ListView。

源码:
RairDemo
GitHub: https://github.com/Rairmmd/android-demo
Coding: https://coding.net/u/Rair/p/RairDemo/git

Android开发之蓝牙(Bluetooth)操作--修改本机蓝牙设备的可见性,并扫描周围可用的蓝牙设备

一. 修改本机蓝牙设备的可见性

二. 扫描周围可用的蓝牙设备

 

 

Eg:

一.  清单文件AdroidManifest.xml:

[java] view plain copy
 
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"  
  3.       package="com.se7en"  
  4.       android:versionCode="1"  
  5.       android:versionName="1.0">  
  6.     <uses-sdk android:minSdkVersion="8" />  
  7.   
  8.     <application android:icon="@drawable/icon" android:label="@string/app_name">  
  9.         <activity android:name=".MainActivity"  
  10.                   android:label="@string/app_name">  
  11.             <intent-filter>  
  12.                 <action android:name="android.intent.action.MAIN" />  
  13.                 <category android:name="android.intent.category.LAUNCHER" />  
  14.             </intent-filter>  
  15.         </activity>  
  16.     </application>  
  17.     <uses-permission android:name="android.permission.BLUETOOTH"/>  
  18.       
  19.     <!-若需要管理蓝牙设备,如修改可见性,则需以下的权限->  
  20.     <uses-permission android:name="android.permission.BLUETOOTH_ADMIN"/>  
  21. </manifest>  

二. 布局文件: main.xml:

 

[java] view plain copy
 
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:orientation="vertical"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="fill_parent"  
  6.     >  
  7.     <TextView    
  8.         android:layout_width="fill_parent"   
  9.         android:layout_height="wrap_content"   
  10.         android:text="@string/hello"  
  11.         />  
  12.     <Button   
  13.         android:id="@+id/discoverButton"  
  14.         android:layout_width="fill_parent"  
  15.         android:layout_height="wrap_content"  
  16.         android:text="设置可见性"/>  
  17.     <Button   
  18.         android:id="@+id/scanButton"  
  19.         android:layout_width="fill_parent"  
  20.         android:layout_height="wrap_content"  
  21.         android:text="开始扫描"/>  
  22. </LinearLayout>  

三. MainActivity:

 

 

[java] view plain copy
 
  1. import android.app.Activity;  
  2. import android.bluetooth.BluetoothAdapter;  
  3. import android.bluetooth.BluetoothDevice;  
  4. import android.content.BroadcastReceiver;  
  5. import android.content.Context;  
  6. import android.content.Intent;  
  7. import android.content.IntentFilter;  
  8. import android.os.Bundle;  
  9. import android.view.View;  
  10. import android.view.View.OnClickListener;  
  11. import android.widget.Button;  
  12.   
  13. public class MainActivity extends Activity {  
  14.     private Button discoverButton = null;  
  15.     private Button scanButton = null;  
  16.     private BluetoothAdapter adapter = null;  
  17.     private BluetoothReceiver bluetoothReceiver = null;  
  18.     /** Called when the activity is first created. */  
  19.     @Override  
  20.     public void onCreate(Bundle savedInstanceState) {  
  21.         super.onCreate(savedInstanceState);  
  22.         setContentView(R.layout.main);  
  23.           
  24.         adapter = BluetoothAdapter.getDefaultAdapter();  
  25.           
  26.         discoverButton = (Button)findViewById(R.id.discoverButton);  
  27.         scanButton = (Button)findViewById(R.id.scanButton);  
  28.         //修改蓝牙设备的可见性  
  29.         discoverButton.setOnClickListener(new OnClickListener(){  
  30.             @Override  
  31.             public void onClick(View view) {  
  32.             Intent discoverIntent = new Intent(BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE);  
  33.   
  34. //设置蓝牙可见性,500表示可见时间(单位:秒),当值大于300时默认为300  
  35. discoverIntent.putExtra(BluetoothAdapter.EXTRA_DISCOVERABLE_DURATION,500);  
  36. startActivity(discoverIntent);  
  37.             }  
  38.         });  
  39.           
  40.         scanButton.setOnClickListener(new OnClickListener(){  
  41.             @Override  
  42.             public void onClick(View v) {  
  43.         //开始扫描周围蓝牙设备,该方法是异步调用并以广播的机制返回,所以需要创建一个BroadcastReceiver来获取信息  
  44.                 adapter.startDiscovery();  
  45.             }  
  46.         });  
  47.           
  48.         //设定广播接收的filter  
  49.         IntentFilter intentFilter = new IntentFilter(BluetoothDevice.ACTION_FOUND);  
  50.         //创建蓝牙广播信息的receiver  
  51.         bluetoothReceiver = new BluetoothReceiver ();  
  52.         //注册广播接收器  
  53.         registerReceiver(bluetoothReceiver,intentFilter);  
  54.               
  55.     }  
  56.       
  57.     private class BluetoothReceiver extends BroadcastReceiver{  
  58.         @Override  
  59.         public void onReceive(Context context, Intent intent) {  
  60.             //获得扫描到的远程蓝牙设备  
  61.             BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);  
  62.             System.out.println(device.getAddress());  
  63.         }  
  64.           
  65.     }  
  66. }  

以上是关于Android开发之蓝牙(Bluetooth)的主要内容,如果未能解决你的问题,请参考以下文章

Android开发之蓝牙(Bluetooth)操作--修改本机蓝牙设备的可见性,并扫描周围可用的蓝牙设备

Android Developer -- Bluetooth篇 开发实例之六 蓝牙RSSI计算距离

Android4.42-Setting源码分析之蓝牙模块Bluetooth(下)

Android4.42-Settings源代码分析之蓝牙模块Bluetooth总体实现(总)

Android开发之蓝牙通信

Android4.42-Settings源码分析之蓝牙模块Bluetooth(上)