ANDROID蓝牙编程.docx

上传人:b****6 文档编号:6836247 上传时间:2023-01-11 格式:DOCX 页数:24 大小:120.58KB
下载 相关 举报
ANDROID蓝牙编程.docx_第1页
第1页 / 共24页
ANDROID蓝牙编程.docx_第2页
第2页 / 共24页
ANDROID蓝牙编程.docx_第3页
第3页 / 共24页
ANDROID蓝牙编程.docx_第4页
第4页 / 共24页
ANDROID蓝牙编程.docx_第5页
第5页 / 共24页
点击查看更多>>
下载资源
资源描述

ANDROID蓝牙编程.docx

《ANDROID蓝牙编程.docx》由会员分享,可在线阅读,更多相关《ANDROID蓝牙编程.docx(24页珍藏版)》请在冰豆网上搜索。

ANDROID蓝牙编程.docx

ANDROID蓝牙编程

ANDROID蓝牙编程

用BluetoothAdapter类,你能够在Android设备上查找周边的蓝牙设备然后配对(绑定),蓝牙通讯是基于唯一地址MAC来相互传输的,考虑到安全问题Bluetooth通讯时需要先配对。

然后开始相互连接,连接后设备将会共享同一个RFCOMM通道以便相互传输数据,目前这些实现在Android2.0或更高版本SDK上实现。

 一、查找发现findding/discoveringdevices

 对于Android查找发现蓝牙设备使用BluetoothAdapter类的startDiscovery()方法就可以执行一个异步方式获取周边的蓝牙设备,因为是一个异步的方法所以我们不需要考虑线程被阻塞问题,整个过程大约需要12秒时间,这时我们紧接着注册一个BroadcastReceiver对象来接收查找到的蓝牙设备信息,我们过滤ACTION_FOUND这个Intent动作来获取每个远程设备的详细信息,通过附加参数在Intent字段EXTRA_DEVICE和EXTRA_CLASS,中包含了每个BluetoothDevice对象和对象的该设备类型BluetoothClass,示例代码

privatefinalBroadcastReceivercwjReceiver=newBroadcastReceiver(){

   publicvoidonReceive(Contextcontext,Intentintent){

       Stringaction=intent.getAction(); 

          if(BluetoothDevice.ACTION_FOUND.equals(action)){ 

            BluetoothDevicedevice=intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE); 

            myArrayAdapter.add(device.getName()+"android123"+device.getAddress());//获取设备名称和mac地址

       }

   }

};

// 注册这个BroadcastReceiver

IntentFilterfilter=newIntentFilter(BluetoothDevice.ACTION_FOUND);

registerReceiver(cwjReceiver,filter);

 最后android123提醒大家需要注意的是,记住在Service或Activity中重写onDestory()方法,使用unregisterReceiver方法反注册这个BroadcastReceiver对象保证资源被正确回收。

 一些其他的状态变化有ACTION_SCAN_MODE_CHANGED额外参数EXTRA_SCAN_MODE 和EXTRA_PREVIOUS_SCAN_MODE以及SCAN_MODE_CONNECTABLE_DISCOVERABLE、SCAN_MODE_CONNECTABLE和SCAN_MODE_NONE,蓝牙模块

  二、配对绑定bnded/paireddevice

 在Android中配对一个蓝牙设备可以调用BluetoothAdapter类的getBondedDevices()方法可以获取已经配对的设备,该方法将会返回一个BluetoothDevice数组来区分每个已经配对的设备,示例代码如下:

SetpairedDevices=cwjBluetoothAdapter.getBondedDevices();

if(pairedDevices.size()>0) //如果获取的结果大于0,则开始逐个解析

 {

    

   for(BluetoothDevicedevice:

pairedDevices){

 

       myArrayAdapter.add(device.getName()+"android123"+device.getAddress()); //获取每个设备的名称和MAC地址添加到数组适配器myArrayAdapter中。

   }

}

蓝牙模块 

很多网友不明白如何让自己的手机被其他蓝牙设备发现如何设置,下面我们就一起来说说

 三、允许发现enablingdiscoverability

 如果需要用户确认操作,不需要获取底层蓝牙服务实例,可以通过一个Intent来传递ACTION_REQUEST_DISCOVERABLE参数,这里通过startActivityForResult来强制获取一个结果,重写startActivityForResult()方法获取执行结果,返回结果有RESULT_OK和RESULT_CANCELLED分别代表开启和取消(失败),当然最简单的方法是直接执行,示例代码如下

IntentcwjIntent=newIntent(BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE);

cwjIntent.putExtra(BluetoothAdapter.EXTRA_DISCOVERABLE_DURATION,300);

startActivity(cwjIntent);

 接下来系统会提示用户是否允许,对话框如下

 

 

从Android2.0开始提供最全面的蓝牙开发接口,APILevel为5的系统才能调用,目前AndroidBluetoothAPI包含了主要以下几类:

BluetoothAdapter

BluetoothDevice、BluetoothSocket、BluetoothServerSocket和BluetoothClass它们均在android.bluetooth这个包中出现。

 我们调用时除了需要考虑APILevel至少为5外,还需注意添加相应的权限,比如使用通讯需要在androidmanifest.xml加入

name="android.permission.BLUETOOTH"/>,而开关蓝牙需要android.permission.BLUETOOTH_ADMIN权限。

 三、建立通讯establishing

  对于建立一个蓝牙通讯,必须经过以下四个步骤:

获取本地蓝牙设备、查找远程设备、配对(已配对设备将会忽略这步的细节)、连接设备和传输数据.

 在Android平台中首先我们需要查找本地活动的蓝牙适配器,通过BluetoothAdapter类的getDefaultAdapter()方法获得一个系统默认可用的蓝牙设备,示例代码如下

 BluetoothAdaptercwjBluetoothAdapter=BluetoothAdapter.getDefaultAdapter();

 if(cwjBluetoothAdapter==null){

    //Android开发网提示大家本机没有找到蓝牙硬件或驱动存在问题

 }

 当然有了这步仍然不能建立连接,因为我们还不知道手机中的蓝牙功能是否被开启,可以通过cwjBluetoothAdapter的.isEnabled方法来判断,如果没有开启,我们可以通过下面的代码提醒用户启用:

 if(!

cwjBluetoothAdapter.isEnabled()){

   IntentTurnOnBtIntent=newIntent(BluetoothAdapter.ACTION_REQUEST_ENABLE);

   startActivityForResult(TurnOnBtIntent,REQUEST_ENABLE_BT);

}

这时用户会收到类似下面的窗口:

 

 我们通过startActivityForResult()方法发起的Intent将会在onActivityResult()回调方法中获取用户的选择,比如用户单击了Yes开启,那么将会收到RESULT_OK的结果,如果RESULT_CANCELED则代表用户不愿意开启蓝牙,当然android123提醒大家还可以通过其他方式来开启,比如说用BluetoothDevice获取蓝牙服务接口对象,是用enable()方法来开启,无需询问用户,这时就需要用到android.permission.BLUETOOTH_ADMIN权限。

 如何判断系统蓝牙的状态呢?

建立BroadcastReceiver对象,接收ACTION_STATE_CHANGED动作,在EXTRA_STATE和EXTRA_PREVIOUS_STATE包含了现在状态和过去的状态,最终的结果定义是STATE_TURNING_ON正在开启,STATE_ON已经开启,STATE_TURNING_OFF正在关闭和STATE_OFF已经关闭,如果有什么不明白的可以在我们的论坛中交流。

Android蓝牙中的RFCOMM

一RFCOMM通道:

  RFCOMM协议

  一个基于欧洲电信标准协会ETSI07.10规程的串行线性仿真协议。

此协议提供RS232控制和状态信号,如基带上的损坏,CTS以及数据信号等,为上层业务(如传统的串行线缆应用)提供了传送能力。

  RFCOMM是一个简单传输协议,其目的是针对如何在两个不同设备上的应用之间保证一条完整的通信路径,并在它们之间保持一通信段。

  RFCOMM协议概述

  RFCOMM通信段

  RFCOMM是为了兼容传统的串口应用,同时取代有线的通信方式,蓝牙协议栈需要提供与有线串口一致的通信接口而开发出的协议。

RFCOMM协议提供对基于L2CAP协议的串口仿真,基于ETSI07.10。

可支持在两个BT设备之间同时保持高达60路的通信连接。

  目的:

  在两个不同设备(通信设备的两端)上的应用之间保证一条完整的通信路径,并在他们之间保持一通信段。

下图是一条完整的通信路径。

  RFCOMM只针对直接互连设备之间的连接,或者是设备与网络接入设备之间的互连。

通信两端设备必须兼容于RFCOMM协议,有两类设备:

DTE(DataTerminalEndpoint,通信终端,如PC,PRINTER)和DCE(DataCircuitEndpoint,通信段的一部分,如Modem)。

此两类设备不作区分。

  RFCOMM服务

  RFCOMM仿真RS232串口,仿真过程包括非数据通路状态的传输,RFCOMM内置空Modem仿真标准框架。

  RFCOMM中的仿真RS-232通路

  多串口仿真

  两个采用RFCOMM通信的BT设备有可能同时打开多个串口,RFCOMM支持同时打开60个端口。

  认识二:

MAC硬件地址

  MAC(Medium/MediaAccessControl,介质访问控制)MAC地址是烧录在NetworkInterfaceCard(网卡,NIC)里的.MAC地址,也叫硬件地址,是由48比特长(6字节),16进制的数字组成.0-23位叫做组织唯一标志符(organizationallyunique,是识别LAN(局域网)节点的标识.24-47位是由厂家自己分配。

其中第40位是组播地址标志位。

网卡的物理地址通常是由网卡生产厂家烧入网卡的EPROM(一种闪存芯片,通常可以通过程序擦写),它存储的是传输数据时真正赖以标识发出数据的电脑和接收数据的主机的地址。

  也就是说,在网络底层的物理传输过程中,是通过物理地址来识别主机的,它一般也是全球唯一的。

比如,著名的以太网卡,其物理地址是48bit(比特位)的整数,如:

44-45-53-54-00-00,以机器可读的方式存入主机接口中。

以太网地址管理机构(除了管这个外还管别的)

(IEEE)(IEEE:

电气和电子工程师协会)将以太网地址,也就是48比特的不同组合,分为若干独立的连续地址组,生产以太网网卡的厂家就购买其中一组,具体生产时,逐个将唯一地址赋予以太网卡。

  形象的说,MAC地址就如同我们身份证上的身份证号码,具有全球唯一性。

  步骤一:

SettingUpBluetooth

  通过BluetoothAdapter得到蓝牙的Activity

  发送蓝牙连接意图

  通过eonActivityResult()得到蓝牙连接意图

  步骤二:

FindingDevices

  通过得到开启蓝牙用户名和MAC地址

  配对蓝牙

  步骤三:

连接蓝牙

  就像java的聊天系统一样用一个蓝牙手机当服务器,一个当客户端,在用一个类当做连接的管理类就行了

Android蓝牙API介绍:

BluetoothAdapter类

 使用BluetoothAdapter类,你能够在Android设备上查找周边的蓝牙设备然后配对(绑定),蓝牙通讯是基于唯一地址MAC来相互传输的,考虑到安全问题Bluetooth通讯时需要先配对。

然后开始相互连接,连接后设备将会共享同一个RFCOMM通道以便相互传输数据,目前这些实现在Android2.0或更高版本SDK上实现。

  一、查找发现findding/discoveringdevices

  对于Android查找发现蓝牙设备使用BluetoothAdapter类的startDiscovery()方法就可以执行一个异步方式获取周边的蓝牙设备,因为是一个异步的方法所以我们不需要考虑线程被阻塞问题,整个过程大约需要12秒时间,这时我们紧接着注册一个BroadcastReceiver对象来接收查找到的蓝牙设备信息,我们过滤ACTION_FOUND这个Intent动作来获取每个远程设备的详细信息,通过附加参数在Intent字段EXTRA_DEVICE和EXTRA_CLASS,中包含了每个BluetoothDevice对象和对象的该设备类型BluetoothClass,示例代码

  privatefinalBroadcastReceivercwjReceiver=newBroadcastReceiver(){

  publicvoidonReceive(Contextcontext,Intentintent){

  Stringaction=intent.getAction();

  if(BluetoothDevice.ACTION_FOUND.equals(action)){

  BluetoothDevicedevice=intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);

  myArrayAdapter.add(device.getName()+"android123"+device.getAddress());//获取设备名称和mac地址

  }

  }

  };

  //注册这个BroadcastReceiver

  IntentFilterfilter=newIntentFilter(BluetoothDevice.ACTION_FOUND);

  registerReceiver(cwjReceiver,filter);

  最后android123提醒大家需要注意的是,记住在Service或Activity中重写onDestory()方法,使用unregisterReceiver方法反注册这个BroadcastReceiver对象保证资源被正确回收。

  一些其他的状态变化有ACTION_SCAN_MODE_CHANGED额外参数EXTRA_SCAN_MODE和EXTRA_PREVIOUS_SCAN_MODE以及SCAN_MODE_CONNECTABLE_DISCOVERABLE、SCAN_MODE_CONNECTABLE和SCAN_MODE_NONE,

  二、配对绑定bnded/paireddevice

  在Android中配对一个蓝牙设备可以调用BluetoothAdapter类的getBondedDevices()方法可以获取已经配对的设备,该方法将会返回一个BluetoothDevice数组来区分每个已经配对的设备,示例代码如下:

  SetpairedDevices=cwjBluetoothAdapter.getBondedDevices();

  if(pairedDevices.size()>0)//如果获取的结果大于0,则开始逐个解析

  {

  for(BluetoothDevicedevice:

pairedDevices){

  myArrayAdapter.add(device.getName()+"android123"+device.getAddress());//获取每个设备的名称和MAC地址添加到数组适配器myArrayAdapter中。

  }

  }

  很多网友不明白如何让自己的手机被其他蓝牙设备发现如何设置,下面我们就一起来说说

  三、允许发现enablingdiscoverability

  如果需要用户确认操作,不需要获取底层蓝牙服务实例,可以通过一个Intent来传递ACTION_REQUEST_DISCOVERABLE参数,这里通过startActivityForResult来强制获取一个结果,重写startActivityForResult()方法获取执行结果,返回结果有RESULT_OK和RESULT_CANCELLED分别代表开启和取消(失败),当然最简单的方法是直接执行,示例代码如下

  IntentcwjIntent=newIntent(BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE);

  cwjIntent.putExtra(BluetoothAdapter.EXTRA_DISCOVERABLE_DURATION,300);

  startActivity(cwjIntent);

  接下来系统会提示用户是否允许,对话框如下:

  从Android2.0开始提供最全面的蓝牙开发接口,APILevel为5的系统才能调用,目前AndroidBluetoothAPI包含了主要以下几类:

BluetoothAdapter

  BluetoothDevice、BluetoothSocket、BluetoothServerSocket和BluetoothClass它们均在android.bluetooth这个包中出现。

  我们调用时除了需要考虑APILevel至少为5外,还需注意添加相应的权限,比如使用通讯需要在androidmanifest.xml加入,而开关蓝牙需要android.permission.BLUETOOTH_ADMIN权限。

  三、建立通讯establishing

  对于建立一个蓝牙通讯,必须经过以下四个步骤:

获取本地蓝牙设备、查找远程设备、配对(已配对设备将会忽略这步的细节)、连接设备和传输数据.

  在Android平台中首先我们需要查找本地活动的蓝牙适配器,通过BluetoothAdapter类的getDefaultAdapter()方法获得一个系统默认可用的蓝牙设备,示例代码如下

  BluetoothAdaptercwjBluetoothAdapter=BluetoothAdapter.getDefaultAdapter();

  if(cwjBluetoothAdapter==null){

  //Android开发网提示大家本机没有找到蓝牙硬件或驱动存在问题

  }

  当然有了这步仍然不能建立连接,因为我们还不知道手机中的蓝牙功能是否被开启,可以通过cwjBluetoothAdapter的.isEnabled方法来判断,如果没有开启,我们可以通过下面的代码提醒用户启用:

  if(!

cwjBluetoothAdapter.isEnabled()){

  IntentTurnOnBtIntent=newIntent(BluetoothAdapter.ACTION_REQUEST_ENABLE);

  startActivityForResult(TurnOnBtIntent,REQUEST_ENABLE_BT);

  }

  这时用户会收到类似下面的窗口:

  

  我们通过startActivityForResult()方法发起的Intent将会在onActivityResult()回调方法中获取用户的选择,比如用户单击了Yes开启,那么将会收到RESULT_OK的结果,如果RESULT_CANCELED则代表用户不愿意开启蓝牙,当然android123提醒大家还可以通过其他方式来开启,比如说用BluetoothDevice获取蓝牙服务接口对象,是用enable()方法来开启,无需询问用户,这时就需要用到android.permission.BLUETOOTH_ADMIN权限。

  如何判断系统蓝牙的状态呢?

建立BroadcastReceiver对象,接收ACTION_STATE_CHANGED动作,在EXTRA_STATE和EXTRA_PREVIOUS_STATE包含了现在状态和过去的状态,最终的结果定义是STATE_TURNING_ON正在开启,STATE_ON已经开启,STATE_TURNING_OFF正在关闭和STATE_OFF已经关闭,如果有什么不明白的可以在我们的论坛中交流。

Android蓝牙技术

对于一般的软件开发人员来说,蓝牙是很少用到的,尤其是Android的蓝牙开发,国内的例子很少    Android对于蓝牙开发从2.0版本的sdk才开始支持,而且模拟器不支持,测试至少需要两部手机,所以制约了很多技术人员的开发,刚巧这段时间公司有蓝牙开发的需求,我看了很多国内、国外的资料,又研究了一下J2ME的蓝牙开发(为了找找思路),虽然我想要的功能还没实现(我曾经在很多论坛里问了很多遍,苦于没有高人解答..),我要实现的功能是连接一个硬件设备,凡是跟硬件沾上边的,都让软件人员开发头疼..

好了,废话不说了,鉴于很多开发人员现在也有蓝牙开发的需求,也为了大家少走些弯路,先将我积攒的一点点在Android蓝牙开发经验与大家分享一下!

首先,要操作蓝牙,先要在AndroidManifest.xml里加入权限

name="android.permission.BLUETOOTH_ADMIN"/>

name="android.permission.BLUETOOTH"/>

然后,看下api,Android所有关于蓝牙开发的类都在android.bluetooth包下,如下图,只有8个类

而我们需要用到了就只有几个而已:

  1.BluetoothAdapter顾名思义,蓝牙适配器,直到我们建立bluetoothSocket连接之

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 工程科技 > 冶金矿山地质

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1