0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

OpenHarmony BLE藍(lán)牙連接教程

OpenHarmony技術(shù)社區(qū) ? 來源:OST開源開發(fā)者 ? 2023-04-17 10:11 ? 次閱讀

OpenHarmony 藍(lán)牙模塊提供了基礎(chǔ)的傳統(tǒng)藍(lán)牙能力以及 BLE 的掃描、廣播等功能。

這里將介紹如何通過 OpenHarmony 提供的 @ohos.bluetooth (藍(lán)牙接口)打開當(dāng)前設(shè)備的藍(lán)牙,關(guān)閉藍(lán)牙,以及連接 BLE 藍(lán)牙設(shè)備。

設(shè)備與環(huán)境:

設(shè)備:九聯(lián) s905l3a 機(jī)頂盒、開鴻智谷學(xué)生卡 BLE 藍(lán)牙設(shè)備

系統(tǒng):OpenHarmony 3.2 beta2

SDK:9

邏輯流程

首先機(jī)頂盒在開始的時(shí)候獲取藍(lán)牙相關(guān)權(quán)限,然后通過 OpenHarmony 提供的藍(lán)牙接口打開藍(lán)牙。

3b736820-dc25-11ed-bfe3-dac502259ad0.png

接著訂閱發(fā)現(xiàn) BLE 設(shè)備發(fā)現(xiàn)事件,然后通過 OpenHarmony 提供的藍(lán)牙接口開啟 BLE 設(shè)備掃描。

當(dāng)發(fā)現(xiàn)到了 BLE 藍(lán)牙設(shè)備后,進(jìn)行上報(bào),BLE 設(shè)備發(fā)現(xiàn)事件觸發(fā),獲取到來自 BLE 設(shè)備的廣播信息包,然后進(jìn)行 BLE 藍(lán)牙連接。

實(shí)現(xiàn)過程

①獲取藍(lán)牙相關(guān)權(quán)限

在使用藍(lán)牙接口之前,首先要讓設(shè)備獲取一下權(quán)限:

ohos.permission.USE_BLUETOOTH //:允許應(yīng)用查看藍(lán)牙的配置。

ohos.permission.DISCOVER_BLUETOOTH //:允許應(yīng)用配置本地藍(lán)牙,查找遠(yuǎn)端設(shè)備且與之配對連接。

ohos.permission.LOCATION //:允許應(yīng)用獲取設(shè)備位置信息。

ohos.permission.MANAGE_BLUETOOTH //:允許應(yīng)用配對藍(lán)牙設(shè)備,并對設(shè)備的電話簿或消息進(jìn)行訪問。

打開 DevEco Studio 3.1.0.200,創(chuàng)建新的 Stage 項(xiàng)目,在項(xiàng)目中的 module.json 文件中添加相關(guān)權(quán)限:

"requestPermissions":[
{
"name":"ohos.permission.USE_BLUETOOTH",
"reason":"$string:grant_use_bluetooth",
"usedScene":{
"abilities":[
"MainAbility"
],
"when":"inuse"
}
},
{
"name":"ohos.permission.DISCOVER_BLUETOOTH",
"reason":"$string:grant_discovery_bluetooth",
"usedScene":{
"abilities":[
"MainAbility"
],
"when":"inuse"
}
},
{
"name":"ohos.permission.LOCATION",
"reason":"$string:grant_location",
"usedScene":{
"abilities":[
"MainAbility"
],
"when":"inuse"
}
},
{
"name":"ohos.permission.MANAGE_BLUETOOTH",
"reason":"$string:grant_manage_bluetooth",
"usedScene":{
"abilities":[
"MainAbility"
],
"when":"inuse"
}
}
]

②打開設(shè)備的藍(lán)牙

首先,通過調(diào)用 bluetooth.getState()藍(lán)牙接口來獲取當(dāng)前設(shè)備藍(lán)牙是否打開,并設(shè)置藍(lán)牙開關(guān)的標(biāo)識位 isOn。

asyncaboutToAppear(){
//等待獲取藍(lán)牙權(quán)限
awaitglobalThis.abilityContext.requestPermissionsFromUser(['ohos.permission.USE_BLUETOOTH','ohos.permission.DISCOVER_BLUETOOTH','ohos.permission.LOCATION','ohos.permission.MANAGE_BLUETOOTH'])
logger.info(TAG,`獲取權(quán)限grantPermission,requestPermissionsFromUser,PermissionRequestResult`)
//獲取藍(lán)牙狀態(tài)
letstate=bluetooth.getState()
//判斷當(dāng)前設(shè)備藍(lán)牙是否打開
if(state===bluetooth.BluetoothState.STATE_ON){
this.isOn=true
}
if(state===bluetooth.BluetoothState.STATE_OFF){
this.isOn=false
}
}

如果當(dāng)前設(shè)備藍(lán)牙未打開,則通過調(diào)用 bluetooth.enableBluetooth()藍(lán)牙接口來打開藍(lán)牙。

//打開藍(lán)牙函數(shù)
initBluetooth(){
this.enable=bluetooth.enableBluetooth()
//判斷藍(lán)牙是否成功打開
if(this.enable==true){
prompt.showToast({
message:'Openbluetooth'+this.enable,
duration:2000,
});
}
}

③注冊發(fā)現(xiàn) BLE 設(shè)備監(jiān)聽器

在設(shè)備打開藍(lán)牙之后,通過調(diào)用 bluetooth.BLE.on('BLEDeviceFind')藍(lán)牙接口來訂閱 BLE 設(shè)備發(fā)現(xiàn)上報(bào)事件。 該接口參數(shù)如下:

3b83a37a-dc25-11ed-bfe3-dac502259ad0.png

通過注冊發(fā)現(xiàn) BLE 設(shè)備監(jiān)聽器,可以得到發(fā)現(xiàn)設(shè)備的集合,BLE 設(shè)備的廣播包、地址、信號強(qiáng)度 rssi。

在這里發(fā)現(xiàn)獲取連接 BLE 設(shè)備名字的接口 getDeviceName 無法成功調(diào)用,所以自己通過解析廣播包來獲取設(shè)備名字。

//訂閱BLE設(shè)備發(fā)現(xiàn)上報(bào)事件
//獲取到的data包括BLE設(shè)備的廣播包、地址、信號強(qiáng)度rssi
bluetooth.BLE.on('BLEDeviceFind',(data)=>{
logger.info(TAG,`enteronbluetoothBLEDeviceFind`)
logger.info("rgytl 開始掃描設(shè)備地址! 1")
if(data!==null&&data.length>0){
logger.info("rgytl 開始掃描設(shè)備地址! 2")
if(this.discoveryBleList.indexOf(data[0])===-1){
//把發(fā)現(xiàn)的設(shè)備地址存入列表
this.discoveryBleList.push(data[0].deviceId)
logger.info("rgytl----discoveryBleList="+JSON.stringify(this.discoveryBleList))
//讀取廣播包,解析廣播包,得到設(shè)備名字,并存入設(shè)備列表
vari=0;
varx=data[0].data[i]
vary=data[0].data[i+1]
while(y!=0x09&&i+x+2
 

④開啟 BLE 設(shè)備掃描

在完成訂閱 BLE 設(shè)備發(fā)現(xiàn)上報(bào)事件后,通過調(diào)用 bluetooth.BLE.startBLEScan 接口去開啟 BLE 設(shè)備掃描。 通過該接口,可以對掃描 BLE 設(shè)備進(jìn)行過濾,可以過濾的參數(shù)有:BLE 設(shè)備的地址、名字、以及服務(wù)的 UUID 等。

3b9886e6-dc25-11ed-bfe3-dac502259ad0.png

在這里,我設(shè)置只掃描包含我 BLE 設(shè)備名字的 BLE 設(shè)備,這樣子就不會(huì)說掃描到一大堆其他的 BLE 設(shè)備,影響使用,只需要開啟一次掃描和訂閱一次 BLE 設(shè)備發(fā)現(xiàn)上報(bào)事件就可以了,使用的時(shí)候只要沒有關(guān)閉,就不需要重復(fù)調(diào)用。

//設(shè)置藍(lán)牙BLE掃描模式(根據(jù)名字掃描)
bluetooth.BLE.startBLEScan(
[{
deviceId:null,
name:"bleslavetest",
serviceUuid:null
}],
{
interval:0,
dutyMode:bluetooth.ScanDuty.SCAN_MODE_LOW_POWER,
matchMode:bluetooth.MatchMode.MATCH_MODE_AGGRESSIVE,
}
)

⑤連接 BLE 設(shè)備

在掃描到 BLE 設(shè)備之后,可以通過 on(‘BLEConnectionStateChange’)來訂閱獲取 BLE 設(shè)備的連接狀態(tài)變化事件。 在使用該接口之前,要先通過 bluetooth.BLE.createGattClientDevice('XXXXXX:XX')接口創(chuàng)建一個(gè)可使用的 GattClientDevice 實(shí)例。

3bafac36-dc25-11ed-bfe3-dac502259ad0.png

//訂閱BEL狀態(tài)變化
if(this.BleOnflag){
//只創(chuàng)建一個(gè)GattClient對象
this.BleOnflag=false
this.BLEDevice=bluetooth.BLE.createGattClientDevice(item);
//訂閱獲取BLE設(shè)備的連接狀態(tài)變化事件
this.BLEDevice.on('BLEConnectionStateChange',(data)=>{
console.log('bluetoothconnectStatestatechanged');
letconnectState=data.state;
//根據(jù)不通的連接狀態(tài),提示不同的信息
if(JSON.stringify(connectState)==0){
logger.info(`connectState=${JSON.stringify(connectState)},斷開連接`)
prompt.showToast({
message:'斷開連接',
duration:2000,
});
}elseif(JSON.stringify(connectState)==2){
logger.info(`connectState=${JSON.stringify(connectState)},連接成功`)
prompt.showToast({
message:'連接成功',
duration:2000,
});
}elseif(JSON.stringify(connectState)==1){
logger.info(`connectState=${JSON.stringify(connectState)},正在連接`)
}else{
logger.info(`connectState=${JSON.stringify(connectState)},正在斷連`)
}
logger.info(`connectState=${JSON.stringify(connectState)}`);
})
}
在前面通過 bluetooth.BLE.createGattClientDevice(item)創(chuàng)建一個(gè) GattClientDevice 實(shí)例 BLEDevice 后,我們可以通過該實(shí)例去調(diào)用 connect()方法連接 BLE 設(shè)備。

注意,GattClientDevice 實(shí)例只需要?jiǎng)?chuàng)建一個(gè)就可以。

3bc0a270-dc25-11ed-bfe3-dac502259ad0.png

//連接藍(lán)牙
letBLEConnect=this.BLEDevice.connect()
//如果連接成功,則把BLE設(shè)備存入連接成功列表
if(BLEConnect){
this.deviceBleList.push(item)
}

⑥結(jié)尾處理

當(dāng)不連接 BLE 設(shè)備的時(shí)候,要記得關(guān)閉 BLE 設(shè)備掃描,取消訂閱設(shè)備發(fā)現(xiàn)事件。

取消 BLE 設(shè)備連接,通過之前創(chuàng)建的 GattClientDevice 實(shí)例 BLEDevice 調(diào)用 disconnect()方法斷開連接 BLE 設(shè)備。

Button("斷開")
.alignSelf(ItemAlign.Center)
.onClick(()=>{
AlertDialog.show({
title:$r('app.string.disconnect'),
message:'此操作將會(huì)斷開該設(shè)備的連接',
primaryButton:{
value:$r('app.string.cancel'),
action:()=>{
}
},
secondaryButton:{
value:$r('app.string.confirm'),
action:()=>{
//斷開連接BLE設(shè)備
letBLEdisConnect=this.BLEDevice.disconnect()
if(BLEdisConnect){
logger.info(`connectStateBLEdisConnect=${JSON.stringify(BLEdisConnect)},斷開連接`)
//移出BLE設(shè)備連接列表
this.deviceBleList.pop(item)
}
}
}
})
})
在斷開連接、關(guān)閉藍(lán)牙之后,可以通過 off(‘connectStateChange’)取消訂閱 BLE 連接狀態(tài)變化事件、bluetooth.BLE.stopBLEScan 停止 BLE 掃描、以及 bluetooth.BLE.off(‘BLEDeviceFind’)取消訂閱 BLE 設(shè)備發(fā)現(xiàn)上報(bào)事件。

最后通過 bluetooth.disableBluetooth()關(guān)閉藍(lán)牙:

.onChange((isOn:boolean)=>{
if(isOn){
this.isOn=true
this.initBluetooth()
}else{
this.isOn=false
bluetooth.BLE.off('BLEDeviceFind',()=>{
logger.info("rgytl 取消BLE設(shè)備發(fā)現(xiàn)訂閱!")
})
bluetooth.BLE.stopBLEScan()
this.disable=bluetooth.disableBluetooth()
this.discoveryList=[]
this.BleInfo=[]
this.BleRssi=[]
if(this.disable==true){
prompt.showToast({
message:'Closebluetooth'+this.disable,
duration:2000,
});
}
}
})

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 接口
    +關(guān)注

    關(guān)注

    33

    文章

    8598

    瀏覽量

    151153
  • BLE
    BLE
    +關(guān)注

    關(guān)注

    12

    文章

    660

    瀏覽量

    59410
  • 藍(lán)牙模塊
    +關(guān)注

    關(guān)注

    30

    文章

    575

    瀏覽量

    55738
  • SDK
    SDK
    +關(guān)注

    關(guān)注

    3

    文章

    1036

    瀏覽量

    45940
  • OpenHarmony
    +關(guān)注

    關(guān)注

    25

    文章

    3722

    瀏覽量

    16317

原文標(biāo)題:OpenHarmony BLE藍(lán)牙連接

文章出處:【微信號:gh_834c4b3d87fe,微信公眾號:OpenHarmony技術(shù)社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    BLE連接技術(shù)對比與應(yīng)用

    BLE連接技術(shù)在現(xiàn)實(shí)生活場景中其實(shí)有很多應(yīng)用,例如在電表中,藍(lán)牙支持多主多從的工作模式,能被采集器、自動(dòng)化終端設(shè)備、手持設(shè)備主機(jī)連接的同時(shí),與多個(gè)從機(jī)(外置負(fù)荷開關(guān)、報(bào)警裝置、各類傳
    的頭像 發(fā)表于 04-27 00:24 ?4518次閱讀

    電腦端BLE藍(lán)牙助手

    電腦端BLE藍(lán)牙助手
    的頭像 發(fā)表于 06-14 10:34 ?2719次閱讀
    電腦端<b class='flag-5'>BLE</b><b class='flag-5'>藍(lán)牙</b>助手

    FCC & CE認(rèn)證 藍(lán)牙5.1協(xié)議 主從并存 低功耗藍(lán)牙模塊BLE5101# 藍(lán)牙

    BLE藍(lán)牙模塊
    思為無線
    發(fā)布于 :2023年10月12日 09:31:13

    BLE低功耗藍(lán)牙模塊為何如此受歡迎?

    BLE低功耗藍(lán)牙模塊為何如此受歡迎? BLE 低功耗藍(lán)牙模塊一般是指藍(lán)牙4.0模塊,BLE
    發(fā)表于 12-01 15:11 ?18次下載

    經(jīng)驗(yàn)分享:如何選擇適合的BLE藍(lán)牙模塊

    物聯(lián)網(wǎng)應(yīng)用中,成功連接設(shè)備的過程,連接性的角色至關(guān)重要,選擇范圍也很廣:如Wi-Fi、低功耗藍(lán)牙BLE)、RFID、NFC等等。根據(jù)市占率估計(jì),在2021年前,將有60%的無線裝置使
    的頭像 發(fā)表于 06-11 15:26 ?1.1w次閱讀

    如何利用API增加BLE連接

    本視頻中,我們將回顧API如何配合低功耗藍(lán)牙(BLE)設(shè)備工作。我們將了解如何利用API方便、快捷地為應(yīng)用增加BLE連接性。
    的頭像 發(fā)表于 10-09 04:04 ?3322次閱讀

    BLE藍(lán)牙的角色功能

    藍(lán)牙設(shè)備之間進(jìn)行通訊時(shí),必須有一個(gè)為主機(jī),一個(gè)為從機(jī),才能進(jìn)行通信。通信時(shí),也必須由主機(jī)進(jìn)行查找,并發(fā)起配對,建立連接后,雙方即可收發(fā)數(shù)據(jù)。BLE藍(lán)牙的角色主要包括:主機(jī)、從機(jī)、主從一
    的頭像 發(fā)表于 10-30 18:45 ?3803次閱讀

    盤點(diǎn)BLE低功耗藍(lán)牙和傳統(tǒng)藍(lán)牙之間的五大區(qū)別

    下兼容。相較于傳統(tǒng)的藍(lán)牙,BLE藍(lán)牙的優(yōu)點(diǎn)就是快速搜索、快速連接、超低功耗、保持連接和傳輸數(shù)據(jù),弱點(diǎn)就是傳輸速率低,物理寬帶只有1M,而實(shí)際
    發(fā)表于 07-24 14:42 ?6262次閱讀

    BLE藍(lán)牙模塊選型表介紹

    BLE藍(lán)牙模塊的功能著手,簡單介紹藍(lán)牙模塊的物聯(lián)網(wǎng)應(yīng)用。 SKYLAB的藍(lán)牙模塊根據(jù)支持的藍(lán)牙協(xié)議分為B
    的頭像 發(fā)表于 07-27 16:39 ?4880次閱讀
    <b class='flag-5'>BLE</b><b class='flag-5'>藍(lán)牙</b>模塊選型表介紹

    BLE藍(lán)牙的具體優(yōu)勢以及BLE藍(lán)牙智能門鎖的應(yīng)用

    一、BLE藍(lán)牙的具體優(yōu)勢: 1、BLE藍(lán)牙的待機(jī)時(shí)間超長, 市面上的藍(lán)牙智能鎖基本都是使用干電池供電,而
    發(fā)表于 08-17 14:03 ?3101次閱讀
    <b class='flag-5'>BLE</b><b class='flag-5'>藍(lán)牙</b>的具體優(yōu)勢以及<b class='flag-5'>BLE</b><b class='flag-5'>藍(lán)牙</b>智能門鎖的應(yīng)用

    藍(lán)牙BLE(低功耗藍(lán)牙)的區(qū)別是什么

    來源:羅姆半導(dǎo)體社區(qū)? 藍(lán)牙BLE藍(lán)牙低功耗)是無線個(gè)人局域網(wǎng)(WPAN)標(biāo)準(zhǔn)。藍(lán)牙低功耗藍(lán)牙旨在處理發(fā)送小塊數(shù)據(jù)的問題。它旨在使用紐扣
    的頭像 發(fā)表于 02-02 17:54 ?6562次閱讀

    藍(lán)牙模塊有哪些種類?BLE低功耗藍(lán)牙模塊有什么特點(diǎn)?

    Ble藍(lán)牙模塊是專為物聯(lián)網(wǎng)無線數(shù)據(jù)傳輸而生,ble藍(lán)牙模塊以其超低功耗、快速連接、容易交互等特點(diǎn),已廣泛應(yīng)用于物聯(lián)網(wǎng)
    的頭像 發(fā)表于 08-09 13:49 ?5945次閱讀
    <b class='flag-5'>藍(lán)牙</b>模塊有哪些種類?<b class='flag-5'>BLE</b>低功耗<b class='flag-5'>藍(lán)牙</b>模塊有什么特點(diǎn)?

    Telink BLE連接應(yīng)用的SDK簡介

    本系列的幾篇文章主要講述"Bluetooth LE Multiple Connection",此SDK是Telink BLE連接應(yīng)用的SDK,所謂的BLE連接就是
    的頭像 發(fā)表于 09-22 14:41 ?3931次閱讀

    BLE藍(lán)牙模塊功能應(yīng)用②——定位功能

    藍(lán)牙定位是BLE藍(lán)牙模塊的重要功能,可以彌補(bǔ)GPS無法覆蓋室內(nèi)定位的場景。本文將從iBeacon概述、定位技術(shù)原理以及行業(yè)應(yīng)用來展開介紹,帶大家熟悉了解BLE
    的頭像 發(fā)表于 10-18 08:25 ?844次閱讀
    <b class='flag-5'>BLE</b><b class='flag-5'>藍(lán)牙</b>模塊功能應(yīng)用②——定位功能

    帶你深入了解BLE藍(lán)牙模塊工作模式

    藍(lán)牙是一種新興無線通訊技術(shù)是一個(gè)標(biāo)準(zhǔn)的無線通訊協(xié)議,可實(shí)現(xiàn)無線數(shù)據(jù)和語音通信?;诘统杀驹O(shè)備的收發(fā)器芯片,可做近距離的無線連接,為固定和移動(dòng)設(shè)備監(jiān)理通信環(huán)境的一種近距離無線連接技術(shù)。其中,BL
    的頭像 發(fā)表于 07-16 13:54 ?875次閱讀
    帶你深入了解<b class='flag-5'>BLE</b><b class='flag-5'>藍(lán)牙</b>模塊工作模式