使用BleLib的轻松搞定Android低功耗蓝牙Ble 4.0开发具体解释
转载请注明来源: http://blog.csdn.net/kjunchen/article/details/50909410
使用BleLib的轻松搞定Android低功耗蓝牙Ble 4.0开发具体解释
- 演示样例源代码: https://github.com/junkchen/BleLib/tree/master/sample
- Android ble4.0开发基础篇:http://blog.csdn.net/kjunchen/article/details/50339549
BleLib是Android低功耗蓝牙4.0及以上开发的辅助库。一行代码解决Ble初始化、扫描、连接、特性读写、设置通知等操作。
BleLib支持单个Ble连接或多个Ble设备同一时候连接。
BleLib中的关键类:
- BleService是单个Ble连接操作的服务类
- GattAttributes类中包括了蓝牙联盟规定的服务和特征的UUID值
- MultipleBleService类是可多个蓝牙设备同一时候连接的服务类
用法
第一步:加入BleLib库依赖
因此。在你项目Module中的build.gradle文件里加入库依赖就可以。例如以下:
dependencies {
compile 'com.junkchen.blelib:blelib:1.0.4'
}
仅仅此一句就可以使用BleLib库,方便吧,要的就是这效果。
使用Android Studio时依照例如以下方式加入依赖比較好,获取的是最新的版本号,结果和上面是一样的,进入模块的库依赖设置。搜索blelib就可以获取:

第二步:绑定BleLib服务
BleLib库中的Ble服务类继承了Service,因此建议绑定服务进行使用。
(假设项目中须要同一时候连接多了Ble设备进行控制请绑定MultipleBleService)
private BleService mBleService;
private boolean mIsBind;
private ServiceConnection serviceConnection = new ServiceConnection() {
@Override
public void onServiceConnected(ComponentName name, IBinder service) {
mBleService = ((BleService.LocalBinder) service).getService();
if (mBleService.initialize()) {
if (mBleService.enableBluetooth(true)) {
mBleService.scanLeDevice(true);
Toast.makeText(BleScanActivity.this, "Bluetooth was opened", Toast.LENGTH_SHORT).show();
}
} else {
Toast.makeText(BleScanActivity.this, "not support Bluetooth", Toast.LENGTH_SHORT).show();
}
}
@Override
public void onServiceDisconnected(ComponentName name) {
mBleService = null;
mIsBind = false;
}
};
private void doBindService() {
Intent serviceIntent = new Intent(this, BleService.class);
bindService(serviceIntent, serviceConnection, Context.BIND_AUTO_CREATE);
}
private void doUnBindService() {
if (mIsBind) {
unbindService(serviceConnection);
mBleService = null;
mIsBind = false;
}
}
第三步:初始化操作
当服务绑定后可进行初始化操作,推断该机是否支持蓝牙。调用例如以下方法:
mBleService.initialize();//Ble初始化操作
该方法会返回一个boolean值。返回true表示初始化成功。支持蓝牙;返回false表示初始化操作失败。则兴许的全部操作都不能进行。
第四步:打开蓝牙
当初始化操作成功后就能够打开蓝牙了,调用例如以下方法:
mBleService.enableBluetooth(boolean enable);//打开或关闭蓝牙
该方法须要传入一个boolean类型的參数。true表示打开蓝牙,false表示关闭蓝牙;并返回boolean參数,返回true表示蓝牙打开,否则关闭。
第五步:扫描Ble设备
当蓝牙打开后能够进行Ble设备的扫描了,调用例如以下方法:
mBleService.scanLeDevice(boolean enable, long scanPeriod);//启动或停止扫描Ble设备
调用该方法须要传入一个boolean參数,true表示開始进行扫描Ble设备,false表示停止扫描,默认扫描10秒钟后停止,假设想要自己设定扫描的时间,能够输入一个long型參数,表示时间单位为毫秒,如3000表示3秒后停止扫描,扫描结束是会发出广播。
扫描的结果能够从扫描监听或者广播接收器两种方式获取,设置方法例如以下:
监听方式接收扫描到的Ble设备
//Ble扫描回调
mBleService.setOnLeScanListener(new BleService.OnLeScanListener() {
@Override
public void onLeScan(BluetoothDevice device, int rssi, byte[] scanRecord) {
//每当扫描到一个Ble设备时就会返回,(扫描结果反复的库中已处理)
}
});
(注意:设置监听一定要等到BleService服务绑定之后才进行,否则会造成空指针异常)
广播接收扫描到的Ble设备
private BroadcastReceiver bleReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(BleService.ACTION_BLUETOOTH_DEVICE)) {
String tmpDevName = intent.getStringExtra("name");
String tmpDevAddress = intent.getStringExtra("address");
Log.i(TAG, "name: " + tmpDevName + ", address: " + tmpDevAddress);
} else if (intent.getAction().equals(BleService.ACTION_SCAN_FINISHED)) {
//扫描Ble设备停止
}
}
};
两种方式获取都能够。可是监听方式获取的信息会多一些。可依据自己的需求进行选择使用那种方式。
第六步:连接Ble服务
当扫描到Ble设备后就能够进行连接操作了。调用例如以下方法:
mBleService.connect(String address);//连接Ble
mBleService.disconnect();//取消连接
连接须要传入要连接的Ble设备的地址。
连接状态能够从连接监听或者广播接收器两种方式获取。设置方法例如以下:
监听获取Ble连接状态
//Ble连接回调
mBleService.setOnConnectListener(new BleService.OnConnectListener() {
@Override
public void onConnect(BluetoothGatt gatt, int status, int newState) {
if (newState == BluetoothProfile.STATE_DISCONNECTED) {
//Ble连接已断开
} else if (newState == BluetoothProfile.STATE_CONNECTING) {
//Ble正在连接
} else if (newState == BluetoothProfile.STATE_CONNECTED) {
//Ble已连接
} else if (newState == BluetoothProfile.STATE_DISCONNECTING) {
//Ble正在断开连接
}
}
});
广播接收Ble连接状态
private BroadcastReceiver bleReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(BleService.ACTION_GATT_CONNECTED)) {
//Ble已连接
} else if (intent.getAction().equals(BleService.ACTION_GATT_DISCONNECTED)) {
//Ble连接已断开
}
}
};
当连接上Ble后会进行服务的获取。假设服务和特性不能发现,那么就不能进行特性的读写和设置GATT通知。
服务发现监听设置例如以下:
//Ble服务发现回调
mBleService.setOnServicesDiscoveredListener(new BleService.OnServicesDiscoveredListener() {
@Override
public void onServicesDiscovered(BluetoothGatt gatt, int status) {
}
});
第七步:读写Ble特性和接收GATT通知
连接上Ble并获取服务之后就能够对特性进行读写,设置GATT通知。操作例如以下:
mBleService.setCharacteristicNotification();//设置通知
mBleService.readCharacteristic();//读取数据
mBleService.writeCharacteristic();//写入数据
特性读取的数据和GATT通知接收数据设置OnDataAvailableListener监听获取。设置例如以下:
//Ble数据回调
mBleService.setOnDataAvailableListener(new BleService.OnDataAvailableListener() {
@Override
public void onCharacteristicRead(BluetoothGatt gatt, BluetoothGattCharacteristic characteristic, int status) {
//处理特性读取返回的数据
}
@Override
public void onCharacteristicChanged(BluetoothGatt gatt, BluetoothGattCharacteristic characteristic) {
//处理通知返回的数据
}
});
总结
最后小小总结下使用BleLib库进行Android低功耗蓝牙Ble的开发步骤:
- 加入BleLib库依赖
- 绑定BleLib服务
- 初始化操作
- 打开蓝牙
- 扫描Ble设备
- 连接Ble服务
- 读写Ble特性和接收GATT通知
Author
- Name: Junk Chen
- Github: https://github.com/junkchen
- Blog: http://blog.csdn.net/kjunchen
- Email: junkchen@vip.qq.com
- QQ群: 365532949
2016/3/16 21:49:15
使用BleLib的轻松搞定Android低功耗蓝牙Ble 4.0开发具体解释的更多相关文章
- Android低功耗蓝牙(BLE)开发的一点感受
最近一段时间,因为产品的需要我做了一个基于低功耗蓝牙设备的Android应用,其中碰到了一些困难,使我深深体会到Android开发的难处:不同品牌,不同型号和不同版本之间的差异使得Android应用适 ...
- Android 低功耗蓝牙BLE 开发注意事项
基本概念和问题 1.蓝牙设计范式? 当手机通过扫描低功耗蓝牙设备并连接上后,手机与蓝牙设备构成了客户端-服务端架构.手机通过连接蓝牙设备,可以读取蓝牙设备上的信息.手机就是客户端,蓝牙设备是服务端. ...
- Android零基础入门第7节:搞定Android模拟器,开启甜蜜之旅
原文:Android零基础入门第7节:搞定Android模拟器,开启甜蜜之旅 在前几期中总结分享了Android的前世今生.Android 系统架构和应用组件那些事.带你一起来聊一聊Android开发 ...
- 5分钟搞定android混淆(转)
转自:https://www.jianshu.com/p/f3455ecaa56e 前言 混淆是上线前挺重要的一个环节.android使用的ProGuard,可以起到压缩,混淆,预检,优化的作用.但是 ...
- 【转】轻松搞定FTP之FlashFxp全攻略
转载网址:http://www.newhua.com/2008/0603/39163.shtml 轻松搞定FTP之FlashFxp全攻略 导读: FlashFXP是一款功能强大的FXP/FTP软件,融 ...
- 轻松搞定javascript变量(闭包,预解析机制,变量在内存的分配 )
变量: 存储数据的容器 1.声明 var 2.作用域 全局变量. 局部变量. 闭包(相对的全局变量): 3.类型 a.基本类型(undefi ...
- Webcast / 技术小视频制作方法——自己动手录制video轻松搞定
Webcast / 技术小视频制作方法——自己动手录制video轻松搞定 http://blog.sina.com.cn/s/blog_67d387490100wdnh.html 最近申请加入MSP的 ...
- 【微服务】之二:从零开始,轻松搞定SpringCloud微服务系列--注册中心(一)
微服务体系,有效解决项目庞大.互相依赖的问题.目前SpringCloud体系有强大的一整套针对微服务的解决方案.本文中,重点对微服务体系中的服务发现注册中心进行详细说明.本篇中的注册中心,采用Netf ...
- 【微服务】之三:从零开始,轻松搞定SpringCloud微服务-配置中心
在整个微服务体系中,除了注册中心具有非常重要的意义之外,还有一个注册中心.注册中心作为管理在整个项目群的配置文件及动态参数的重要载体服务.Spring Cloud体系的子项目中,Spring Clou ...
随机推荐
- nio selector
为什么使用Selector? 仅用单个线程来处理多个Channels的好处是,只需要更少的线程来处理通道.事实上,可以只用一个线程处理所有的通道.对于操作系统来说,线程之间上下文切换的开销很大,而且每 ...
- mysql的存储目录
1.MySQL的数据存储目录为data,data目录通常在C:\Documents and Settings\All Users\Application Data\MySQL\MySQL Server ...
- PostgreSQL配置文件--日志和错误
6 错误操作和日志 ERROR REPORTING AND LOGGING 6.1 日志写到哪里 Where to Log 6.1.1 log_destination 字符串 默认: log_dest ...
- RMAN冗余备份概念与方法
冗余备份概念 RMAN提供了一种更谨慎的备份策略:duplexed方式备份,其实质就是在生成备份集的同时,向指定位置copy指定份数(最大不超过4)的备份集复制,以避免在灾难性事故时数据库损坏和备份丢 ...
- 有关ubuntu16.04进行sudo apt-get update更新时出现:‘。。。N: 无法安全地用该源进行更新,所以默认禁用该源。。。’等问题解决方案
关于ubuntu16.04在 sudo apt-get update 时出现如下错误: 针对这种情况,本人结合网上的解决方案总结出以下方案,三条命令搞定,希望有用. 1. 进入 sources.lis ...
- solr 高亮显示
官网:https://lucene.apache.org/solr/guide/6_6/highlighting.html#Highlighting-TheUnifiedHighlighter 前言 ...
- pip安装scrapy时报错:error: Unable to find vcvarsall.bat
网上一堆胡说八道的,请看微软官方文章: https://blogs.msdn.microsoft.com/pythonengineering/2016/04/11/unable-to-find-vcv ...
- RocketMQ 拉取消息-文件获取
看完了上一篇的<RocketMQ 拉取消息-通信模块>,请求进入PullMessageProcessor中,接着 PullMessageProcessor.processRequest(f ...
- HTML+JavaScript实现链式运动特效
在学习js的过程中,发现这家伙做特效真是不错,尽管说眼下水平还不够,只是也能写点简单的效果. 今天分享一个简单的运动框架.然后利用这个框架实现简单的链式运动特效. 1.move.js 在运动框架中.主 ...
- Spring之替换Bean的返回结果,替换Bean的方法实例
Spring是一个非常强悍的框架+容器,其中有代理模式(动态代理模式)的极致体现.下面是两个比较让人感觉精彩的代码使用,重点关注main方法中的ClassPathXMlApplicationConte ...