成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

HarmonyOS基于LYEVK-3861開發火焰報警系統

開發 前端 OpenHarmony
本文內容主要講述基于LYEVK-3861物聯網開發板套件的火焰傳感器,開發一個具有火焰感應報警功能的HarmonyOS應用,主要實現藍牙設備掃描,連接,檢測火焰,設置報警閾值。

[[433369]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

前言

在各種災害中,火災是最經常、最普遍地威脅公眾安全和社會發展的主要災害之一。火給人類帶來文明進步、光明和溫暖。但是,有時它是人類的朋友,有時是人類的敵人。失去控制的火,就會給人類造成災難。說到火災的控制,一套火焰感應報警系統就有其價值了。那我們如何去檢測火焰呢?

本文內容主要講述基于LYEVK-3861物聯網開發板套件的火焰傳感器,開發一個具有火焰感應報警功能的HarmonyOS應用,主要實現藍牙設備掃描,連接,檢測火焰,設置報警閾值。

1.效果演示

#星光計劃1.0# HarmonyOS 基于LYEVK-3861開發火焰報警系統-鴻蒙HarmonyOS技術社區

2.環境準備

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

  • 《HarmonyOS 官方文檔》
  • LYEVK-3861 物聯網開發板套件

3.藍牙通信說明

3.1 藍牙通信協議:

3.2 藍牙通信流程:

#星光計劃1.0# HarmonyOS 基于LYEVK-3861開發火焰報警系統-鴻蒙HarmonyOS技術社區

3.3 數據透傳協議:

3.3.1 串口協議:

3.3.2 數據協議:

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

4.開發調試

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

4.1 進行BLE掃描

  • MyBleCentralManagerCallback繼承BleCentralManagerCallback類實現scanResultEvent和scanFailedEvent回調函數,用于接收掃描結果。
  • BleCentralManager(BleCentralManagerCallback callback)接口獲取中心設備管理對象。
  • 調用startScan()掃描藍牙設備。
  1. /** 
  2.    * 掃描設備 
  3.    * @param filters 設備過濾器 
  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.    * 掃描設備回調 
  13.    * 
  14.    * @since 2021-10-09 
  15.    */ 
  16.   private class MyBleCentralManagerCallback implements BleCentralManagerCallback { 
  17.       // 掃描結果的回調 
  18.       @Override 
  19.       public void scanResultEvent(BleScanResult bleScanResult) { 
  20.           if (mBleManagerCallback != null) { 
  21.               mBleManagerCallback.scanResultCallback(bleScanResult); 
  22.           } 
  23.           // 獲取廣播數據中的服務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.       // 掃描失敗回調 
  37.       @Override 
  38.       public void scanFailedEvent(int event) { 
  39.           HiLog.debug(loglabel, "掃描失敗 scanFailedEvent()"); 
  40.       } 
  41.  
  42.       // 組掃描成功回調 
  43.       @Override 
  44.       public void groupScanResultsEvent(List<BleScanResult> list) { 
  45.           // 使用組掃描時在此對掃描結果進行處理 
  46.       } 
  47.   } 

4.2 建立連接

  • 掃描成功,匹配服務UUID FFB0,調用bleConnect()連接開發板藍牙。
  • 觸發connectionStateChangedEvent(int connectionState)回調,connectionState=2連接成功,然后調用discoverServices()接口發現服務。
  • 在回調servicesDiscoveredEvent(int status)中獲取外圍設備支持的服務和特征值,此時才能調用read和write方法讀取或者寫入對應特征值數據。
  • characteristicChangedEvent(GattCharacteristic characteristic)特征變更的回調中,解析傳感器上報數據、校驗等。具體數據解析邏輯在ProtocolEntity中parseCharacteristic(String hexStr)方法。
  1. /** 
  2.    * 連接到BLE外圍設備 
  3.    * 
  4.    * @since 2021-10-09 
  5.    */ 
  6.   public void bleConnect() { 
  7.       peripheralDevice.connect(false, new BlePeripheralCallback() { 
  8.           // 在外圍設備上發現服務的回調 
  9.           @Override 
  10.           public void servicesDiscoveredEvent(int status) { 
  11.               super.servicesDiscoveredEvent(status); 
  12.               if (status == BlePeripheralDevice.OPERATION_SUCC) { 
  13.                   HiLog.debug(loglabel, "發現服務成功 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.           // 連接狀態變更的回調 
  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.                   // 連接成功在外圍設備上發現GATT服務,部分手機發現服務失敗,需要延遲調用discoverServices() 
  44.                   peripheralDevice.discoverServices(); 
  45.               } 
  46.           } 
  47.  
  48.           // 特征變更的回調 
  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 預警閾值下發

  • 設置火焰報警距離閾值,tagId為0002,當火焰傳感器發現火焰,并小于此設置的閾值時,設備上報預警。
  • 通過發現服務servicesDiscoveredEvent()回調獲取的writeCharacteristic特征,寫入數據。數據下發格式按照3.3數據透傳協議。
  1. /** 
  2.      * 主動去獲取所Tag設備數據,通過Write(消息類型0x01), Notify接收數據 
  3.      */ 
  4.     public void readInitiativeByTags(List<String> tagIds) { 
  5.         String hex = getTagsCommandHexStr(tagIds); 
  6.         bleManagerWrite(hex); 
  7.     } 
  8.  
  9.     /** 
  10.      * 寫Tag設備數據,通過Write(消息類型0x01), Notify接收數據 
  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數據的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; //串口協議標識 
  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數據的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; //串口協議標識 
  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數據透傳協議,解析設備上報的火焰距離。
  1. /** 
  2.   * 協議校驗 (從協議標識首節至協議內容尾字節求累加和后再對 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.    * 根據串口協議解析 
  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.結語

以上就是LYEVK-3861物聯網開發板火焰傳感器的預警功能,和應用程序交互的一個相對簡單的流程。場景的交互還有很多種,比如在此基礎上搭建遠程云端系統,實現遠程火焰監控實時預警。有興趣的伙伴也可以根據開發板其他傳感器組合成不同的智能場景。

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

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操作系統計劃

2020-12-15 11:57:49

Hi3861 HarmonyOS開發板

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

2021-09-09 10:06:09

鴻蒙HarmonyOS應用

2024-05-09 08:14:52

2021-12-31 15:07:00

鴻蒙HarmonyOS應用

2022-06-28 08:40:16

LokiPromtail日志報警

2016-12-20 14:35:52

監控報警系統經驗

2014-07-17 15:01:21

zabbix監控開發

2023-05-26 16:07:14

Hi3861Wifi模塊

2020-11-06 10:15:16

HiBurn
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美日韩精品久久久免费观看 | 欧美一区二区三区四区五区无卡码 | 2一3sex性hd| 国产一区二区三区在线观看免费 | 亚洲第一视频网站 | 成人av影院| 国产成人福利在线观看 | 日韩一级免费电影 | 欧美日韩国产一区二区三区不卡 | 91伊人| 伊人色综合久久久天天蜜桃 | 中文字幕国产精品 | 中文字幕av一区二区三区 | 99久久婷婷国产综合精品 | 久久久国产一区二区三区 | 国产一区二区三区 | 在线一区二区三区 | 超碰97免费观看 | 久久精品二区亚洲w码 | 亚洲天堂999 | 国产高清一区二区三区 | 伊人免费视频二 | 久久精品欧美电影 | 日韩成人影院 | xxxxx黄色片 欧美一区免费 | 久久99精品久久久久久狂牛 | 成人av网站在线观看 | 欧美日韩国产精品激情在线播放 | 中国黄色在线视频 | 亚洲一区综合 | 一区二区三区亚洲 | 亚洲一二三区不卡 | 亚洲第一天堂 | 亚洲欧美日韩中文在线 | 91精品国产一区二区三区 | 国产精品久久久久久久一区探花 | 日本一区二区三区精品视频 | 在线播放一区 | 国产91久久精品一区二区 | 成人在线一区二区三区 | 欧美一区日韩一区 |