自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

HarmonyOS基于LYEVK-3861開發(fā)火焰報警系統(tǒng)

開發(fā) 前端 OpenHarmony
本文內(nèi)容主要講述基于LYEVK-3861物聯(lián)網(wǎng)開發(fā)板套件的火焰?zhèn)鞲衅?,開發(fā)一個具有火焰感應報警功能的HarmonyOS應用,主要實現(xiàn)藍牙設(shè)備掃描,連接,檢測火焰,設(shè)置報警閾值。

[[433369]]

想了解更多內(nèi)容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

前言

在各種災害中,火災是最經(jīng)常、最普遍地威脅公眾安全和社會發(fā)展的主要災害之一?;鸾o人類帶來文明進步、光明和溫暖。但是,有時它是人類的朋友,有時是人類的敵人。失去控制的火,就會給人類造成災難。說到火災的控制,一套火焰感應報警系統(tǒng)就有其價值了。那我們?nèi)绾稳z測火焰呢?

本文內(nèi)容主要講述基于LYEVK-3861物聯(lián)網(wǎng)開發(fā)板套件的火焰?zhèn)鞲衅?,開發(fā)一個具有火焰感應報警功能的HarmonyOS應用,主要實現(xiàn)藍牙設(shè)備掃描,連接,檢測火焰,設(shè)置報警閾值。

1.效果演示

#星光計劃1.0# HarmonyOS 基于LYEVK-3861開發(fā)火焰報警系統(tǒng)-鴻蒙HarmonyOS技術(shù)社區(qū)

2.環(huán)境準備

本貼不對實驗環(huán)境搭建做詳細說明。具體準備實驗環(huán)境請參考:

  • 《HarmonyOS 官方文檔》
  • LYEVK-3861 物聯(lián)網(wǎng)開發(fā)板套件

3.藍牙通信說明

3.1 藍牙通信協(xié)議:

3.2 藍牙通信流程:

#星光計劃1.0# HarmonyOS 基于LYEVK-3861開發(fā)火焰報警系統(tǒng)-鴻蒙HarmonyOS技術(shù)社區(qū)

3.3 數(shù)據(jù)透傳協(xié)議:

3.3.1 串口協(xié)議:

3.3.2 數(shù)據(jù)協(xié)議:

(permission P:APP下發(fā);G:設(shè)備請求;R:設(shè)備上報)

4.開發(fā)調(diào)試

藍牙交互封裝BleHelper工具類,通過BLE掃描和廣播提供的開放能力,可以根據(jù)指定狀態(tài)獲取外圍設(shè)備、啟動或停止BLE掃描、廣播。

4.1 進行BLE掃描

  • MyBleCentralManagerCallback繼承BleCentralManagerCallback類實現(xiàn)scanResultEvent和scanFailedEvent回調(diào)函數(shù),用于接收掃描結(jié)果。
  • BleCentralManager(BleCentralManagerCallback callback)接口獲取中心設(shè)備管理對象。
  • 調(diào)用startScan()掃描藍牙設(shè)備。
  1. /** 
  2.    * 掃描設(shè)備 
  3.    * @param filters 設(shè)備過濾器 
  4.    * @since 2021-10-09 
  5.    */ 
  6.   public void startScan(List<BleScanFilter> filters) { 
  7.       centralManager = new BleCentralManager(context, new MyBleCentralManagerCallback()); 
  8.       centralManager.startScan(filters); 
  9.   } 
  10.  
  11.   /** 
  12.    * 掃描設(shè)備回調(diào) 
  13.    * 
  14.    * @since 2021-10-09 
  15.    */ 
  16.   private class MyBleCentralManagerCallback implements BleCentralManagerCallback { 
  17.       // 掃描結(jié)果的回調(diào) 
  18.       @Override 
  19.       public void scanResultEvent(BleScanResult bleScanResult) { 
  20.           if (mBleManagerCallback != null) { 
  21.               mBleManagerCallback.scanResultCallback(bleScanResult); 
  22.           } 
  23.           // 獲取廣播數(shù)據(jù)中的服務(wù)uuids 
  24.           List<UUID> uuids = bleScanResult.getServiceUuids(); 
  25.           for (UUID uuid : uuids) { 
  26.               if (SERVICE_UUID.equals(uuid.toString())) { 
  27.                   peripheralDevice = bleScanResult.getPeripheralDevice(); 
  28.                   int length = peripheralDevice.toString().length(); 
  29.                   String deviceId = peripheralDevice.toString().substring(length - CUT_LENGTH, length); 
  30.                   stopScan(); 
  31.                   bleConnect(); 
  32.               } 
  33.           } 
  34.       } 
  35.  
  36.       // 掃描失敗回調(diào) 
  37.       @Override 
  38.       public void scanFailedEvent(int event) { 
  39.           HiLog.debug(loglabel, "掃描失敗 scanFailedEvent()"); 
  40.       } 
  41.  
  42.       // 組掃描成功回調(diào) 
  43.       @Override 
  44.       public void groupScanResultsEvent(List<BleScanResult> list) { 
  45.           // 使用組掃描時在此對掃描結(jié)果進行處理 
  46.       } 
  47.   } 

4.2 建立連接

  • 掃描成功,匹配服務(wù)UUID FFB0,調(diào)用bleConnect()連接開發(fā)板藍牙。
  • 觸發(fā)connectionStateChangedEvent(int connectionState)回調(diào),connectionState=2連接成功,然后調(diào)用discoverServices()接口發(fā)現(xiàn)服務(wù)。
  • 在回調(diào)servicesDiscoveredEvent(int status)中獲取外圍設(shè)備支持的服務(wù)和特征值,此時才能調(diào)用read和write方法讀取或者寫入對應特征值數(shù)據(jù)。
  • characteristicChangedEvent(GattCharacteristic characteristic)特征變更的回調(diào)中,解析傳感器上報數(shù)據(jù)、校驗等。具體數(shù)據(jù)解析邏輯在ProtocolEntity中parseCharacteristic(String hexStr)方法。
  1. /** 
  2.    * 連接到BLE外圍設(shè)備 
  3.    * 
  4.    * @since 2021-10-09 
  5.    */ 
  6.   public void bleConnect() { 
  7.       peripheralDevice.connect(false, new BlePeripheralCallback() { 
  8.           // 在外圍設(shè)備上發(fā)現(xiàn)服務(wù)的回調(diào) 
  9.           @Override 
  10.           public void servicesDiscoveredEvent(int status) { 
  11.               super.servicesDiscoveredEvent(status); 
  12.               if (status == BlePeripheralDevice.OPERATION_SUCC) { 
  13.                   HiLog.debug(loglabel, "發(fā)現(xiàn)服務(wù)成功 servicesDiscoveredEvent()"); 
  14.                   for (GattService service : peripheralDevice.getServices()) { 
  15.                       checkGattCharacteristic(service); 
  16.                   } 
  17.                   if (mBleManagerCallback != null) { 
  18.                       mBleManagerCallback.connectCallback(status); 
  19.                   } 
  20.               } 
  21.           } 
  22.  
  23.           private void checkGattCharacteristic(GattService service) { 
  24.               for (GattCharacteristic tmpChara : service.getCharacteristics()) { 
  25.                   if (tmpChara.getUuid().equals(UUID.fromString(NOTIFY_CHARACTER_UUID))) { 
  26.                       // 啟用特征通知 
  27.                       peripheralDevice.setNotifyCharacteristic(tmpChara, true); 
  28.                   } 
  29.                   if (tmpChara.getUuid().equals(UUID.fromString(WRITE_CHARACTER_UUID))) { 
  30.                       // 獲取GattCharacteristic 
  31.                       writeCharacteristic = tmpChara; 
  32.                   } 
  33.               } 
  34.           } 
  35.  
  36.           // 連接狀態(tài)變更的回調(diào) 
  37.           @Override 
  38.           public void connectionStateChangeEvent(int connectionState) { 
  39.               super.connectionStateChangeEvent(connectionState); 
  40.               if (connectionState == ProfileBase.STATE_CONNECTED && !isConnected) { 
  41.                   HiLog.debug(loglabel, "連接成功 connectionStateChangeEvent() connectionState:" + connectionState); 
  42.                   isConnected = true
  43.                   // 連接成功在外圍設(shè)備上發(fā)現(xiàn)GATT服務(wù),部分手機發(fā)現(xiàn)服務(wù)失敗,需要延遲調(diào)用discoverServices() 
  44.                   peripheralDevice.discoverServices(); 
  45.               } 
  46.           } 
  47.  
  48.           // 特征變更的回調(diào) 
  49.           @Override 
  50.           public void characteristicChangedEvent(GattCharacteristic characteristic) { 
  51.               super.characteristicChangedEvent(characteristic); 
  52.               byte[] value = characteristic.getValue(); 
  53.               if (value == nullreturn
  54.               String toHexStr = DataUtils.toHex(value); 
  55.               boolean isVerify = BleHelper.verifyProtocol(toHexStr);//校驗 
  56.               if (isVerify) { 
  57.                   if (protocolEntity == null) { 
  58.                       protocolEntity = new ProtocolEntity(); 
  59.                   } 
  60.                   protocolEntity.parseCharacteristic(toHexStr); 
  61.                   if (mBleManagerCallback != null) { 
  62.                       mBleManagerCallback.characteristicChangedCallback(protocolEntity, toHexStr); 
  63.                   } 
  64.               } 
  65.  
  66.           } 
  67.       }); 
  68.   } 

4.3 預警閾值下發(fā)

  • 設(shè)置火焰報警距離閾值,tagId為0002,當火焰?zhèn)鞲衅靼l(fā)現(xiàn)火焰,并小于此設(shè)置的閾值時,設(shè)備上報預警。
  • 通過發(fā)現(xiàn)服務(wù)servicesDiscoveredEvent()回調(diào)獲取的writeCharacteristic特征,寫入數(shù)據(jù)。數(shù)據(jù)下發(fā)格式按照3.3數(shù)據(jù)透傳協(xié)議。
  1. /** 
  2.      * 主動去獲取所Tag設(shè)備數(shù)據(jù),通過Write(消息類型0x01), Notify接收數(shù)據(jù) 
  3.      */ 
  4.     public void readInitiativeByTags(List<String> tagIds) { 
  5.         String hex = getTagsCommandHexStr(tagIds); 
  6.         bleManagerWrite(hex); 
  7.     } 
  8.  
  9.     /** 
  10.      * 寫Tag設(shè)備數(shù)據(jù),通過Write(消息類型0x01), Notify接收數(shù)據(jù) 
  11.      */ 
  12.     public void writeBleByTag(String tagId, String value) { 
  13.         String hex = getTagCommandHexStr(tagId, Integer.parseInt(value)); 
  14.         bleManagerWrite(hex); 
  15.     } 
  16.  
  17.     private void bleManagerWrite(String hex) { 
  18.         if (peripheralDevice == null) { 
  19.             return
  20.         } 
  21.         writeCharacteristic.setValue(hex.getBytes(StandardCharsets.UTF_8)); 
  22.         peripheralDevice.writeCharacteristic(writeCharacteristic); 
  23.     } 
  24.  
  25.     /** 
  26.      * 獲取所有Tag數(shù)據(jù)的Write指令 
  27.      * 
  28.      * @param tagIds tag集 
  29.      */ 
  30.     private String getTagsCommandHexStr(List<String> tagIds) { 
  31.         try { 
  32.             StringBuilder sb = new StringBuilder(); 
  33.             String byte1 = PROTOCOL_ID; //串口協(xié)議標識 
  34.             String byte2 = PROTOCOL_VERSION; 
  35.             String byte3 = TYPE_OBTAIN; 
  36.             int dataLen = 8 * tagIds.size(); 
  37.             String byte4 = DataUtils.encodeHex(dataLen, 4); 
  38.  
  39.             String byteTagLen = DataUtils.encodeHex(4, 4); 
  40.             String byteTagValue = "00000000"
  41.             StringBuilder sbTag = new StringBuilder(); 
  42.             for (String it : tagIds) { 
  43.                 sbTag.append(it).append(byteTagLen).append(byteTagValue); 
  44.             } 
  45.  
  46.             sb.append(byte1).append(byte2).append(byte3).append(byte4).append(sbTag); 
  47.             String hexStrSum = DataUtils.makeChecksum(sb.toString()); 
  48.             int protocolVerify = DataUtils.decodeHEX(hexStrSum) % 256; 
  49.             String byteLast = DataUtils.encodeHex(protocolVerify); 
  50.             sb.append(byteLast); 
  51.             return sb.toString(); 
  52.         } catch (Exception e) { 
  53.             e.printStackTrace(); 
  54.         } 
  55.         return ""
  56.     } 
  57.  
  58.     /** 
  59.      * 獲取單個Tag數(shù)據(jù)的Write指令 
  60.      * 
  61.      * @param tagId  0001 
  62.      * @Param value  寫入值 
  63.      */ 
  64.     private String getTagCommandHexStr(String tagId, int value) { 
  65.         try { 
  66.             StringBuilder sb = new StringBuilder(); 
  67.             String byte1 = PROTOCOL_ID; //串口協(xié)議標識 
  68.             String byte2 = PROTOCOL_VERSION; 
  69.             String byte3 = TYPE_ISSUED; 
  70.             int dataLen = 8; 
  71.             String byte4 = DataUtils.encodeHex(dataLen, 4); 
  72.  
  73.             String byteTagId = tagId; 
  74.             String byteTagLen = DataUtils.encodeHex(4, 4); 
  75.             String byteTagValue = DataUtils.encodeHex(value, 8); 
  76.  
  77.             sb.append(byte1).append(byte2).append(byte3).append(byte4) 
  78.                    .append(byteTagId).append(byteTagLen).append(byteTagValue); 
  79.  
  80.             String hexStrSum = DataUtils.makeChecksum(sb.toString()); 
  81.             int protocolVerify = DataUtils.decodeHEX(hexStrSum) % 256; 
  82.             String byteLast = DataUtils.encodeHex(protocolVerify); 
  83.             sb.append(byteLast); 
  84.             return sb.toString(); 
  85.         } catch (Exception e) { 
  86.             e.printStackTrace(); 
  87.         } 
  88.         return ""
  89.     } 

4.4 火焰距離上報

  • 火焰距離上報,通知應用,開始預警。
  • 通過3.3數(shù)據(jù)透傳協(xié)議,解析設(shè)備上報的火焰距離。
  1. /** 
  2.   * 協(xié)議校驗 (從協(xié)議標識首節(jié)至協(xié)議內(nèi)容尾字節(jié)求累加和后再對 256 取余) 
  3.   * 
  4.   * @param hexStr 帶空格的 A5 5A 01 00 00 08 00 02 00 04 00 00 00 8C 
  5.   */ 
  6.  public static boolean verifyProtocol(String hexStr) { 
  7.      if (hexStr.isEmpty()) return false
  8.      String checkHex = hexStr.substring(0, hexStr.lastIndexOf(" ")); 
  9.      String lastHex = hexStr.substring(hexStr.lastIndexOf(" ") + 1); 
  10.      String hexStrSum = DataUtils.makeChecksum(checkHex); 
  11.      return DataUtils.decodeHEX(hexStrSum) % 256 == DataUtils.decodeHEX(lastHex); 
  12.  } 
  1. /** 
  2.    * 根據(jù)串口協(xié)議解析 
  3.    */ 
  4.   public boolean parseCharacteristic(String hexStr) { 
  5.       try { 
  6.           String[] hexs = hexStr.split(" "); 
  7.           version = DataUtils.decodeHEX(hexs[2]); 
  8.           messageType = DataUtils.decodeHEX(hexs[3]); 
  9.           dataLen = DataUtils.decodeHEX(hexs[4] + hexs[5]); 
  10.           for (int i = 0; i < dataLen / 8; i++) { 
  11.               int startIndex = 6 + (i * 8); 
  12.               DeviceData deviceData = new DeviceData(); 
  13.               deviceData.tagId = DataUtils.decodeHEX(hexs[startIndex] + hexs[startIndex + 1]); 
  14.               deviceData.len = DataUtils.decodeHEX(hexs[startIndex + 2] + hexs[startIndex + 3]); 
  15.               deviceData.value = DataUtils.decodeHEX(hexs[startIndex + 4] + hexs[startIndex + 5] + 
  16.                       hexs[startIndex + 6] + hexs[startIndex + 7]); 
  17.               deviceListMap.put(deviceData.tagId, deviceData); 
  18.           } 
  19.           protocolVerify = DataUtils.decodeHEX(hexs[6 + dataLen]); 
  20.       } catch (Exception e) { 
  21.           e.printStackTrace(); 
  22.           return false
  23.       } 
  24.       return true
  25.   } 

5.結(jié)語

以上就是LYEVK-3861物聯(lián)網(wǎng)開發(fā)板火焰?zhèn)鞲衅鞯念A警功能,和應用程序交互的一個相對簡單的流程。場景的交互還有很多種,比如在此基礎(chǔ)上搭建遠程云端系統(tǒng),實現(xiàn)遠程火焰監(jiān)控實時預警。有興趣的伙伴也可以根據(jù)開發(fā)板其他傳感器組合成不同的智能場景。

想了解更多內(nèi)容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區(qū)
相關(guān)推薦

2021-08-27 17:02:56

鴻蒙HarmonyOS應用

2021-10-11 10:07:09

鴻蒙HarmonyOS應用

2021-09-02 15:25:53

鴻蒙HarmonyOS應用

2021-08-17 14:40:43

鴻蒙HarmonyOS應用

2009-11-20 09:17:20

Firefox操作系統(tǒng)計劃

2020-12-15 11:57:49

Hi3861 HarmonyOS開發(fā)板

2021-12-06 15:05:41

鴻蒙HarmonyOS應用

2021-09-16 10:03:39

鴻蒙HarmonyOS應用

2020-11-03 11:39:22

wifi小車

2020-11-30 13:57:48

Hi3861

2020-10-30 09:41:44

鴻蒙Hi3861WiFi小車

2010-03-24 09:07:17

FirefoxWindows Mob

2024-05-09 08:14:52

2021-09-09 10:06:09

鴻蒙HarmonyOS應用

2022-06-28 08:40:16

LokiPromtail日志報警

2016-12-20 14:35:52

監(jiān)控報警系統(tǒng)經(jīng)驗

2014-07-17 15:01:21

zabbix監(jiān)控開發(fā)

2021-12-31 15:07:00

鴻蒙HarmonyOS應用

2023-05-26 16:07:14

Hi3861Wifi模塊

2020-10-28 10:00:09

海思Hi3861CentOS鴻蒙LiteOS
點贊
收藏

51CTO技術(shù)棧公眾號