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

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

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

鴻蒙語(yǔ)言基礎(chǔ)類庫(kù):system.bluetooth 藍(lán)牙

jf_46214456 ? 來(lái)源:jf_46214456 ? 作者:jf_46214456 ? 2024-07-15 17:28 ? 次閱讀

藍(lán)牙

說(shuō)明:
開(kāi)發(fā)前請(qǐng)熟悉鴻蒙開(kāi)發(fā)指導(dǎo)文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

  • 從API Version 7 開(kāi)始,該接口不再維護(hù),推薦使用新接口[@ohos.bluetooth]。
  • 本模塊首批接口從API version 6開(kāi)始支持。后續(xù)版本的新增接口,采用上角標(biāo)單獨(dú)標(biāo)記接口的起始版本。

導(dǎo)入模塊

import bluetooth from '@system.bluetooth';

bluetooth.startBLEScan(OBJECT)

開(kāi)始搜尋附近的低功耗藍(lán)牙外圍設(shè)備。此操作比較耗費(fèi)系統(tǒng)資源,請(qǐng)?jiān)谒阉鞑⑦B接到設(shè)備后調(diào)用[bluetooth.stopBLEScan]方法停止搜索。

需要權(quán)限: ohos.permission.DISCOVER_BLUETOOTH、ohos.permission.LOCATION

系統(tǒng)能力: SystemCapability.Communication.Bluetooth.Lite

參數(shù)表1 StartBLEScanOptions

參數(shù)名類型必填說(shuō)明
intervalnumber上報(bào)設(shè)備的間隔,單位毫秒,默認(rèn)值為0。0表示找到新設(shè)備立即上報(bào),其他數(shù)值根據(jù)傳入的間隔上報(bào)。
successFunction接口調(diào)用成功的回調(diào)函數(shù)。
failFunction接口調(diào)用失敗的回調(diào)函數(shù)。
completeFunction接口調(diào)用結(jié)束的回調(diào)函數(shù)。

示例:

bluetooth.startBLEScan({
  interval:0,
  success() {
    console.log('call bluetooth.startBLEScan success.');
  },
  fail(code, data) {
    console.log('call bluetooth.startBLEScan failed, code: ${code}, data: ${data}.');
  },
  complete() {
    console.log('call bluetooth.startBLEScan complete.');
  }
});

bluetooth.stopBLEScan(OBJECT)

停止搜尋附近的低功耗藍(lán)牙外圍設(shè)備。與[bluetooth.startBLEScan(OBJECT)]接口配套使用。

需要權(quán)限: ohos.permission.DISCOVER_BLUETOOTH、ohos.permission.LOCATION

系統(tǒng)能力: SystemCapability.Communication.Bluetooth.Lite

參數(shù):表2 StopBLEScanOptions

參數(shù)名類型必填說(shuō)明
successFunction接口調(diào)用成功的回調(diào)函數(shù)。
failFunction接口調(diào)用失敗的回調(diào)函數(shù)。
completeFunction接口調(diào)用結(jié)束的回調(diào)函數(shù)。

示例:

bluetooth.stopBLEScan({
  success() {
    console.log('call bluetooth.stopBLEScan success.');
  },
  fail(data, code) {
    console.log('call bluethooth.stopBLEScan fail, code: ${code}, data: ${data}.');
  },
  complete() {
    console.log('call bluethooth.stopBLEScan complete.');
  }
});

bluetooth.subscribeBLEFound(OBJECT)

訂閱尋找到新設(shè)備。再次調(diào)用時(shí),會(huì)覆蓋前一次調(diào)用效果,即僅最后一次調(diào)用生效。

需要權(quán)限: ohos.permission.DISCOVER_BLUETOOTH、ohos.permission.LOCATION

系統(tǒng)能力: SystemCapability.Communication.Bluetooth.Lite

參數(shù):表3 SubscribeBLEFoundOptions

參數(shù)類型必填說(shuō)明
successFunction尋找到新設(shè)備上報(bào)時(shí)調(diào)用的回調(diào)函數(shù)。
failFunction接口調(diào)用失敗的回調(diào)函數(shù)。

表4 success返回值:

參數(shù)名類型說(shuō)明
devicesArray新搜索到的設(shè)備列表。

表5 BluethoothDevice

搜狗高速瀏覽器截圖20240326151547.png

參數(shù)名類型說(shuō)明HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789是v直接拿
addrTypestring設(shè)備地址類型,可能值有: - public: 公共地址 - random: 隨機(jī)地址
addrstring設(shè)備MAC地址。
rssinumber設(shè)備藍(lán)牙的信號(hào)強(qiáng)弱指標(biāo)。
txpowerstring廣播數(shù)據(jù)中的txpower字段。
datahex string廣播數(shù)據(jù)(包含廣播數(shù)據(jù)和掃描響應(yīng)數(shù)據(jù)),十六進(jìn)制字符串。

示例:

bluetooth.subscribeBLEFound({
  success(data) {
    console.log('call bluetooth.subscribeBLEFound success, data: ${data}.');
  },
  fail(data, code) {
    console.log('call bluetooth.startBLEScan failed, data: ${data}, code: ${code}.');
  }
});

bluetooth.unsubscribeBLEFound()

解除訂閱尋找到新設(shè)備。

需要權(quán)限: ohos.permission.DISCOVER_BLUETOOTH、ohos.permission.LOCATION

系統(tǒng)能力: SystemCapability.Communication.Bluetooth.Lite

示例:

bluetooth.unsubscribeBLEFound();

常見(jiàn)錯(cuò)誤碼

錯(cuò)誤碼說(shuō)明
1100是否處于已連接狀態(tài)。
1101當(dāng)前藍(lán)牙適配器不可用。
1102沒(méi)有找到指定設(shè)備。
1103連接失敗。
1104沒(méi)有找到指定服務(wù)。
1105沒(méi)有找到指定特征值。
1106當(dāng)前連接已斷開(kāi)。
1107當(dāng)前特征值不支持此操作。
1108其余所有系統(tǒng)上報(bào)的異常。
1109系統(tǒng)版本不支持 BLE。

審核編輯 黃宇

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

    關(guān)注

    114

    文章

    5684

    瀏覽量

    168082
  • 鴻蒙
    +關(guān)注

    關(guān)注

    56

    文章

    2267

    瀏覽量

    42489
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    鴻蒙語(yǔ)言TypeScript學(xué)習(xí)第16天:【

    TypeScript 支持面向?qū)ο蟮乃刑匦?,比?、接口等。
    的頭像 發(fā)表于 04-15 09:29 ?811次閱讀
    <b class='flag-5'>鴻蒙語(yǔ)言</b>TypeScript學(xué)習(xí)第16天:【<b class='flag-5'>類</b>】

    ArkTS語(yǔ)言基礎(chǔ)庫(kù)-解析

    ArkTS語(yǔ)言基礎(chǔ)庫(kù)是HarmonyOS系統(tǒng)上為應(yīng)用開(kāi)發(fā)者提供的常用基礎(chǔ)能力,主要包含能力如下圖所示。 圖1 ArkTS語(yǔ)言基礎(chǔ)
    發(fā)表于 02-20 16:44

    鴻蒙原生應(yīng)用開(kāi)發(fā)-ArkTS語(yǔ)言基礎(chǔ)庫(kù)概述

    ArkTS語(yǔ)言基礎(chǔ)庫(kù)是HarmonyOS系統(tǒng)上為應(yīng)用開(kāi)發(fā)者提供的常用基礎(chǔ)能力,主要包含能力如下圖所示。 1.提供異步并發(fā)和多線程并發(fā)的能力。 支持Promise和async/await等標(biāo)準(zhǔn)
    發(fā)表于 03-05 15:42

    如何在鴻蒙2.0系統(tǒng)上移植增加藍(lán)牙驅(qū)動(dòng)?

    bluetooth_hdi_adapter庫(kù)),藍(lán)牙頭文件bluetooth_hdi.h名字和一些名字都和2.0的名字不一樣,有更新,直接而且我看3.1子系統(tǒng)通信
    發(fā)表于 05-13 10:13

    藍(lán)牙(Bluetooth)技術(shù)

    藍(lán)牙(Bluetooth)技術(shù)  所謂藍(lán)牙(Bluetooth)技術(shù),實(shí)際上是一種短距離無(wú)線電技術(shù),利用"藍(lán)牙"技術(shù),能夠有效
    發(fā)表于 01-06 11:08 ?725次閱讀

    HarmonyOS語(yǔ)言基礎(chǔ)庫(kù)開(kāi)發(fā)指南上線啦!

    語(yǔ)言基礎(chǔ)庫(kù)提供哪些功能?多線程并發(fā)如何實(shí)現(xiàn)?TaskPool(任務(wù)池)和Worker在實(shí)現(xiàn)和使用場(chǎng)景上有何不同? 針對(duì)開(kāi)發(fā)者關(guān)注的并發(fā)等語(yǔ)言基礎(chǔ)
    的頭像 發(fā)表于 10-18 16:20 ?428次閱讀
    HarmonyOS<b class='flag-5'>語(yǔ)言</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫(kù)</b>開(kāi)發(fā)指南上線啦!

    鴻蒙OpenHarmony大合集:【語(yǔ)言基礎(chǔ)庫(kù)

    本示例集合語(yǔ)言基礎(chǔ)庫(kù)的各個(gè)子模塊,展示了各個(gè)模塊的基礎(chǔ)功能
    的頭像 發(fā)表于 04-29 16:38 ?404次閱讀
    <b class='flag-5'>鴻蒙</b>OpenHarmony大合集:【<b class='flag-5'>語(yǔ)言</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫(kù)</b>】

    鴻蒙語(yǔ)言基礎(chǔ)庫(kù):ohos.bytrace 性能打點(diǎn)

    用來(lái)標(biāo)記一個(gè)預(yù)追蹤的數(shù)值變量,該變量的數(shù)值會(huì)不斷變化。
    的頭像 發(fā)表于 07-18 15:41 ?172次閱讀

    鴻蒙語(yǔ)言基礎(chǔ)庫(kù)system.brightness 屏幕亮度

    獲得設(shè)備當(dāng)前的屏幕亮度值。
    的頭像 發(fā)表于 07-15 17:56 ?632次閱讀
    <b class='flag-5'>鴻蒙語(yǔ)言</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫(kù)</b>:<b class='flag-5'>system</b>.brightness 屏幕亮度

    鴻蒙語(yǔ)言基礎(chǔ)庫(kù)system.configuration 應(yīng)用配置

    獲取應(yīng)用當(dāng)前的語(yǔ)言和地區(qū)。默認(rèn)與系統(tǒng)的語(yǔ)言和地區(qū)同步。
    的頭像 發(fā)表于 07-16 09:34 ?199次閱讀

    鴻蒙語(yǔ)言基礎(chǔ)庫(kù)system.device 設(shè)備信息

    在首頁(yè)的onShow生命周期之前不建議調(diào)用device.getInfo接口。
    的頭像 發(fā)表于 07-16 09:17 ?243次閱讀

    鴻蒙語(yǔ)言基礎(chǔ)庫(kù)system.file 文件存儲(chǔ)

    將指定文件移動(dòng)到其他指定位置。
    的頭像 發(fā)表于 07-17 10:41 ?264次閱讀
    <b class='flag-5'>鴻蒙語(yǔ)言</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫(kù)</b>:<b class='flag-5'>system</b>.file  文件存儲(chǔ)

    鴻蒙語(yǔ)言基礎(chǔ)庫(kù)system.mediaquery 媒體查詢

    根據(jù)媒體查詢條件,創(chuàng)建MediaQueryList對(duì)象。
    的頭像 發(fā)表于 07-17 16:50 ?213次閱讀
    <b class='flag-5'>鴻蒙語(yǔ)言</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫(kù)</b>:<b class='flag-5'>system</b>.mediaquery  媒體查詢

    鴻蒙語(yǔ)言基礎(chǔ)庫(kù)system.network 網(wǎng)絡(luò)狀態(tài)

    獲取當(dāng)前設(shè)備的網(wǎng)絡(luò)類型。
    的頭像 發(fā)表于 07-18 09:37 ?163次閱讀

    鴻蒙語(yǔ)言基礎(chǔ)庫(kù)system.notification 通知消息

    以下各項(xiàng)對(duì)應(yīng)的系統(tǒng)能力均為SystemCapability.Notification.Notification
    的頭像 發(fā)表于 07-18 09:23 ?202次閱讀