電子發(fā)燒友App

硬聲App

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>在連接到STM32的LCD屏幕上顯示BLE傳感器讀數(shù)

在連接到STM32的LCD屏幕上顯示BLE傳感器讀數(shù)

2023-06-14 | zip | 0.00 MB | 次下載 | 3積分

資料介紹

描述

藍(lán)牙 LE 項(xiàng)目的目的是讀取空氣質(zhì)量傳感器數(shù)據(jù)并將其顯示在連接到 STM32 板的 LCD 顯示器上。Web 瀏覽器將讀取傳感器數(shù)據(jù)并使用 BleuIO 將其傳遞給 STM32 板。

一、簡(jiǎn)介

該項(xiàng)目基于STM32 Nucleo-144 ,它使用 BleuIO控制LCD 顯示。

對(duì)于這個(gè)項(xiàng)目,我們需要兩個(gè) BleuIO USB 加密狗,一個(gè)連接到 Nucleo 板,另一個(gè)連接到運(yùn)行 Web 腳本的計(jì)算機(jī)和HibouAir – 空氣質(zhì)量監(jiān)測(cè)設(shè)備。當(dāng) BleuIO Dongle 連接到 Nucleo 板的 USB 端口時(shí),STM32 將識(shí)別它并直接開(kāi)始廣播。這允許計(jì)算機(jī)端口上的加密狗與網(wǎng)絡(luò)腳本連接。

通過(guò)電腦上的網(wǎng)頁(yè)腳本,我們可以從 HibouAir 掃描并獲取空氣質(zhì)量傳感器數(shù)據(jù)。然后我們將這些數(shù)據(jù)發(fā)送到使用藍(lán)牙連接到 STM32 的 LCD 屏幕上。

在本示例中,我們使用了 STM32 Nucleo-144 開(kāi)發(fā)板和 STM32H743ZI MCU(支持 STM32H743ZI micro mbed 的開(kāi)發(fā) Nucleo-144 系列 ARM? Cortex?-M7 MCU 32 位嵌入式評(píng)估板)。該開(kāi)發(fā)板有一個(gè) USB 主機(jī),用于連接 BleuIO 加密狗。

如果要使用其他設(shè)置,則必須確保它支持 USB 主機(jī),并注意 GPIO 設(shè)置可能不同,可能需要在 .ioc 文件中重新配置。

關(guān)于守則

項(xiàng)目源代碼可在 Github 上獲得。

https://github.com/smart-sensor-devices-ab/stm32_ble_sensor_lcd.git

克隆項(xiàng)目,或?qū)⑵湎螺d為 zip 文件并解壓縮到您的 STM32CubeIDE 工作區(qū)。

如果您將項(xiàng)目下載為 zip 文件,則需要將項(xiàng)目文件夾從“stm32_bleuio_lcd-master”重命名為“stm32_bleuio_lcd”

poYBAGNYujGAHG3iAAA5lM86hos585.jpg
?

SDA 連接到 Nucleo 板上的 PF0,將 SCL 連接到 PF1。

然后在 STM32Cube ioc 文件中設(shè)置 I2C2,如下所示。(確保根據(jù) LCD 顯示要求將 I2C 速度頻率更改為 50 KHz。)

pYYBAGNYujSAJEhUAAAMP9SP5yI872.png
?
poYBAGNYujaAHKGmAAA1m3qD8Eg155.png
?
pYYBAGNYujiAC5AqAADEqDRQv9k945.jpg
?

在 USB_HOST\usb_host.c 中的 USBH_CDC_ReceiveCallback 函數(shù)中,我們將 CDC_RX_Buffer 復(fù)制到一個(gè)名為 dongle_response 的外部變量中,該變量可從 main.c 文件訪(fǎng)問(wèn)。

void USBH_CDC_ReceiveCallback(USBH_HandleTypeDef * phost) {
  if (phost == & hUsbHostFS) {
    // Handles the data recived from the USB CDC host, here just printing it out to UART
    rx_size = USBH_CDC_GetLastReceivedDataSize(phost);
    HAL_UART_Transmit( & huart3, CDC_RX_Buffer, rx_size, HAL_MAX_DELAY);

    // Copy buffer to external dongle_response buffer
    strcpy((char * ) dongle_response, (char * ) CDC_RX_Buffer);

    // Reset buffer and restart the callback function to receive more data
    memset(CDC_RX_Buffer, 0, RX_BUFF_SIZE);
    USBH_CDC_Receive(phost, CDC_RX_Buffer, RX_BUFF_SIZE);
  }

  return;
}

在 main.c 中,我們創(chuàng)建了一個(gè)簡(jiǎn)單的解釋器,這樣我們就可以對(duì)從加密狗收到的數(shù)據(jù)做出反應(yīng)。

void dongle_interpreter(uint8_t * input) {

  if (strlen((char * ) input) != 0) {
    if (strstr((char * ) input, "\r\nADVERTISING...") != NULL) {
      isAdvertising = true;
    }
    if (strstr((char * ) input, "\r\nADVERTISING STOPPED") != NULL) {
      isAdvertising = false;
    }
    if (strstr((char * ) input, "\r\nCONNECTED") != NULL) {
      isConnected = true;
      HAL_GPIO_WritePin(GPIOE, GPIO_PIN_1, GPIO_PIN_SET);
    }
    if (strstr((char * ) input, "\r\nDISCONNECTED") != NULL) {
      isConnected = false;
      HAL_GPIO_WritePin(GPIOE, GPIO_PIN_1, GPIO_PIN_RESET);
    }

    if (strstr((char * ) input, "L=0") != NULL) {

      isLightBulbOn = false;
      //HAL_GPIO_WritePin(Lightbulb_GPIO_Port, Lightbulb_Pin, GPIO_PIN_RESET);
      lcd_clear();

      writeToDongle((uint8_t * ) DONGLE_SEND_LIGHT_OFF);

      uart_buf_len = sprintf(uart_tx_buf, "\r\nClear screen\r\n");
      HAL_UART_Transmit( & huart3, (uint8_t * ) uart_tx_buf, uart_buf_len, HAL_MAX_DELAY);
    }

    if (strstr((char * ) input, "L=1") != NULL) {
      isLightBulbOn = true;
      writeToDongle((uint8_t * ) DONGLE_SEND_LIGHT_ON);

      lcd_clear();

      lcd_write(input);

    }

  }
  memset( & dongle_response, 0, RSP_SIZE);
}

我們將解釋器函數(shù)放在主循環(huán)中。

/* Infinite loop */
/* USER CODE BEGIN WHILE */
while (1) {
  /* USER CODE END WHILE */
  MX_USB_HOST_Process();

  /* USER CODE BEGIN 3 */
  // Simple handler for uart input
  handleUartInput(uartStatus);

  // Inteprets the dongle data
  dongle_interpreter(dongle_response);

  // Starts advertising as soon as the Dongle is ready.
  if (!isAdvertising && !isConnected && isBleuIOReady) {
    HAL_Delay(200);
    writeToDongle((uint8_t * ) DONGLE_CMD_AT_ADVSTART);
    isAdvertising = true;
  }
}
/* USER CODE END 3 */

使用示例項(xiàng)目

我們需要什么

作為現(xiàn)有項(xiàng)目導(dǎo)入

從 STM32CubeIDE 中選擇 File>Import…

pYYBAGNVlzGAOrdTAABTMPtN_vY766.png
?

然后選擇 General>Existing Projects into Workspace 然后點(diǎn)擊“Next >”

poYBAGNVlzOAbEAcAACCYdjUQ8w416.png
?

確保您在“選擇根目錄:”中選擇了您的工作區(qū)

您應(yīng)該會(huì)看到項(xiàng)目“stm32_bleuio_SHT85_example”,選中它并單擊“完成”。

pYYBAGNVlzWAF9eHAACaAb8Lb0g612.png
?

運(yùn)行示例

將代碼上傳到 STM32 并運(yùn)行示例。連接到 STM32 的 USB 加密狗將自動(dòng)開(kāi)始廣播。

從網(wǎng)絡(luò)瀏覽器將傳感器數(shù)據(jù)發(fā)送到 LCD 屏幕

將 BleuIO 加密狗連接到計(jì)算機(jī)。運(yùn)行 Web 腳本以連接到 STM32 上的另一個(gè) BleuIO 加密狗。現(xiàn)在您可以將傳感器數(shù)據(jù)發(fā)送到 LCD 屏幕。

為了讓這個(gè)腳本工作,我們需要

  • BleuIO USB 加密狗連接到計(jì)算機(jī)。
  • BleuIO JavaScript 庫(kù)
  • Chrome 78 或更高版本,您需要在 chrome://flags 中啟用#enable-experimental-web-platform-features標(biāo)志
  • 一個(gè)網(wǎng)絡(luò)捆綁器——(包裹 js)

創(chuàng)建一個(gè)名為 index.html 的簡(jiǎn)單 Html 文件,該文件將用作腳本的前端。這個(gè) Html 文件包含一些幫助連接的按鈕,從 HibouAir 讀取廣告數(shù)據(jù)以獲取空氣質(zhì)量傳感器數(shù)據(jù),并將此數(shù)據(jù)發(fā)送到連接到 stm32 的 LCD 屏幕。

html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <link
      href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css"
      rel="stylesheet"
      integrity="sha384-1BmE4kWBq78iYhFldvKuhfTAU6auU8tT94WrHftjDbrCEXSU1oBoqyl2QvZ6jIW3"
      crossorigin="anonymous"
    />
    <title>Bluetooth LE Air quality sensor data to LCD screentitle>
  head>
  <body class="mt-5">
    <div class="container mt-5">
      <img
        src="https://www.bleuio.com/blog/wp-content/themes/bleuio/images/logo.png"
      />
      <h1 class="mb-5">Bluetooth LE Air quality sensor data to LCD screenh1>

      <div class="row">
        <div class="col-md-4 pt-5">
          <button class="btn btn-success mb-2" id="connect">Connectbutton>
          <form method="post" id="sendDataForm" name="sendMsgForm" hidden>
            <div class="mb-3">
              <label for="sensorID" class="form-label">Sensor IDlabel>
              <input
                type="text"
                class="form-control"
                name="sensorID"
                id="sensorID"
                required
                maxlength="60"
                value="0578E0"
              />
            div>

            <button type="submit" class="btn btn-primary">Get Databutton>
          form>
          <br />
          <button class="btn btn-danger" id="clearScreen" disabled>
            Clear screen
          button>
        div>
        <div class="col-md-8">
          <img src="air_quality_lcd.jpg" class="img-fluid" />
        div>
      div>
    div>

    <script src="script.js">script>
  body>
html>

創(chuàng)建一個(gè)名為 script.js 的 js 文件并將其包含在 Html 文件的底部。這個(gè) js 文件使用 BleuIO js 庫(kù)來(lái)編寫(xiě) AT 命令并與其他加密狗進(jìn)行通信。

該腳本有一個(gè)按鈕可以連接到計(jì)算機(jī)上的 COM 端口。有一個(gè)文本字段,您可以在其中寫(xiě)入空氣質(zhì)量監(jiān)測(cè)設(shè)備的傳感器 ID。連接后,腳本將嘗試從傳感器獲取廣告數(shù)據(jù)并將其轉(zhuǎn)換為有意義的數(shù)據(jù)。之后,它將這些數(shù)據(jù)發(fā)送到 STM32 板,然后顯示在 LCD 屏幕上。

import * as my_dongle from 'bleuio'
import 'regenerator-runtime/runtime'

const dongleToConnect = '[0]40:48:FD:E5:2F:17'
//const sensorID = '0578E0'
document.getElementById('connect').addEventListener('click', function() {
	my_dongle.at_connect()
	document.getElementById("clearScreen").disabled = false;
	document.getElementById("connect").disabled = true;
	document.getElementById("sendDataForm").hidden = false;
})

document.getElementById("sendDataForm").addEventListener("submit", function(event) {
	event.preventDefault()
	const sensorID = document.getElementById('sensorID').value
	getSensorData(sensorID)
	setInterval(function() {
		getSensorData(sensorID)
	}, 10000);


});

const getSensorData = ((sensorID) => {
	my_dongle.ati().then((data) => {
			//make central if not
			if (JSON.stringify(data).includes("Peripheral")) {
				console.log('peripheral')
				my_dongle.at_dual().then((x) => {
					console.log('central now')
				})
			}
		})
		.then(() => {
			// connect to dongle
			my_dongle.at_getconn().then((y) => {
					if (JSON.stringify(y).includes(dongleToConnect)) {
						console.log('already connected')
					} else {
						my_dongle.at_gapconnect(dongleToConnect).then(() => {
							console.log('connected successfully')
						})
					}
				})
				.then(async () => {
					return my_dongle.at_findscandata(sensorID, 6).then((sd) => {
						console.log('scandata', sd)
						let advData = sd[sd.length - 1].split(" ").pop()
						let positionOfID = advData.indexOf(sensorID);
						let tempHex = advData.substring(positionOfID + 14, positionOfID + 18)
						let temp = parseInt('0x' + tempHex.match(/../g).reverse().join('')) / 10;

						let co2Hex = advData.substring(positionOfID + 38, positionOfID + 42)
						let co2 = parseInt('0x' + co2Hex);
						//console.log(temp,co2)
						return {
							'CO2': co2,
							'Temp': temp,
						}
					})
				})
				.then((x) => {
					console.log(x.CO2)
					console.log(x.Temp)
					var theVal = "L=1 SENSOR ID " + sensorID + "    TEMPERATURE " + x.Temp + ' °c    CO2 ' + x.CO2 + ' ppm';
					console.log('Message Send 1 ')
					// send command to show data
					my_dongle.at_spssend(theVal).then(() => {
						console.log('Message Send ' + theVal)
					})
				})

		})
})

document.getElementById('clearScreen').addEventListener('click', function() {
	my_dongle.ati().then((data) => {
			//make central if not
			if (JSON.stringify(data).includes("Peripheral")) {
				console.log('peripheral')
				my_dongle.at_central().then((x) => {
					console.log('central now')
				})
			}
		})
		.then(() => {
			// connect to dongle
			my_dongle.at_getconn().then((y) => {
					if (JSON.stringify(y).includes(dongleToConnect)) {
						console.log('already connected')
					} else {
						my_dongle.at_gapconnect(dongleToConnect).then(() => {
							console.log('connected successfully')
						})
					}
				})
				.then(() => {
					// send command to clear the screen
					my_dongle.at_spssend('L=0').then(() => {
						console.log('Screen Cleared')
					})
				})

		})
})

要連接到 STM32 上的 BleuIO 加密狗,請(qǐng)確保 STM32 已通電并連接了 BleuIO 加密狗。

獲取 MAC 地址

按照步驟獲取連接到STM32的加密狗的MAC地址

- Open this site https://bleuio.com/web_terminal.html and click connect to dongle.
- Select the appropriate port to connect.
- Once it says connected, type ATI. This will show dongle information and current status.
- If the dongle is on peripheral role, set it to central by typing AT+CENTRAL
- Now do a gap scan by typing AT+GAPSCAN
- Once you see your dongle on the list ,stop the scan by pressing control+c
- Copy the ID and paste it into the script (script.js) line #4
?

運(yùn)行網(wǎng)頁(yè)腳本

您將需要一個(gè)網(wǎng)絡(luò)捆綁程序。您可以使用parcel.js

安裝 parcel js 后,轉(zhuǎn)到 web 腳本的根目錄并輸入“parcel index.html” 這將啟動(dòng)您的開(kāi)發(fā)環(huán)境。

pYYBAGNYukOAZYK9AAA2QUu69rw587.jpg
?

在瀏覽器上打開(kāi)腳本。對(duì)于這個(gè)例子,我們打開(kāi)http://localhost:1234

您可以輕松連接到加密狗并在 LCD 屏幕上查看空氣質(zhì)量數(shù)據(jù)。響應(yīng)將顯示在瀏覽器控制臺(tái)屏幕上。

網(wǎng)絡(luò)腳本看起來(lái)像這樣

poYBAGNYukWAZVLXAACK0oepQis173.png
?

輸出

信息將顯示在液晶顯示屏上。

pYYBAGNYukiAByg3AACVI30HeJk214.png
?

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評(píng)論

查看更多

下載排行

本周

  1. 1山景DSP芯片AP8248A2數(shù)據(jù)手冊(cè)
  2. 1.06 MB  |  532次下載  |  免費(fèi)
  3. 2RK3399完整板原理圖(支持平板,盒子VR)
  4. 3.28 MB  |  339次下載  |  免費(fèi)
  5. 3TC358743XBG評(píng)估板參考手冊(cè)
  6. 1.36 MB  |  330次下載  |  免費(fèi)
  7. 4DFM軟件使用教程
  8. 0.84 MB  |  295次下載  |  免費(fèi)
  9. 5元宇宙深度解析—未來(lái)的未來(lái)-風(fēng)口還是泡沫
  10. 6.40 MB  |  227次下載  |  免費(fèi)
  11. 6迪文DGUS開(kāi)發(fā)指南
  12. 31.67 MB  |  194次下載  |  免費(fèi)
  13. 7元宇宙底層硬件系列報(bào)告
  14. 13.42 MB  |  182次下載  |  免費(fèi)
  15. 8FP5207XR-G1中文應(yīng)用手冊(cè)
  16. 1.09 MB  |  178次下載  |  免費(fèi)

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費(fèi)
  3. 2555集成電路應(yīng)用800例(新編版)
  4. 0.00 MB  |  33566次下載  |  免費(fèi)
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費(fèi)
  7. 4開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
  8. 未知  |  21549次下載  |  免費(fèi)
  9. 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書(shū))
  10. 0.00 MB  |  15349次下載  |  免費(fèi)
  11. 6數(shù)字電路基礎(chǔ)pdf(下載)
  12. 未知  |  13750次下載  |  免費(fèi)
  13. 7電子制作實(shí)例集錦 下載
  14. 未知  |  8113次下載  |  免費(fèi)
  15. 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德?tīng)栔?/a>
  16. 0.00 MB  |  6656次下載  |  免費(fèi)

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費(fèi)
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537798次下載  |  免費(fèi)
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420027次下載  |  免費(fèi)
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費(fèi)
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費(fèi)
  11. 6電路仿真軟件multisim 10.0免費(fèi)下載
  12. 340992  |  191187次下載  |  免費(fèi)
  13. 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
  14. 158M  |  183279次下載  |  免費(fèi)
  15. 8proe5.0野火版下載(中文版免費(fèi)下載)
  16. 未知  |  138040次下載  |  免費(fèi)