資料介紹
描述
在這個項目中,我們將建造一個供家庭使用的個人氣象站。我們將使用基于 ESP8266 的開發板,即 NodeMCU。我們將監測光線、溫度和濕度。為此,我們將使用 LDR 和 DHT11 傳感器。
本項目由三部分組成:
1.從傳感器收集數據。
2.將數據發送到在線數據庫(在我們的例子中是 Google Firebase)。
3.在 Web 應用程序上顯示存儲在數據庫中的數據。
-------------------------------------------------- -------------------------------------------------- -------------------------------------------------- ----------------------
1. 收集數據
我們將使用光檢測電阻器 (LDR) 來獲取大氣光的值。如圖所示,將 LDR 連接到 NodeMCU 的 A0 引腳。

我們將使用光檢測電阻器 (LDR) 來獲取大氣光的值。如圖所示,將 LDR 連接到 NodeMCU 的 A0 引腳。
DHT11 傳感器用于測量濕度和溫度。我們在這里使用 DHT.h 庫。進行以下連接:
VCC ==> 3v
接地 ==> 接地
數據 ==> D3

-------------------------------------------------- -------------------------------------------------- -------------------------------------------------- ----------------------
2. 向 Firebase 發送數據
要將數據上傳到 firebase,我們需要先連接到互聯網,然后再訪問 firebase。為此,我們需要使用以下兩個庫:
1.ESP8266WiFi.h
2. FirebaseArduino.h
根據代碼連接到 wifi 網絡后,我們現在可以使用 FirebaseArduino.h 庫的功能上傳數據。
傳感器數據存儲在float 類型的light、temp 和 hum變量中。
所以我們將使用setFloat()函數將值上傳到 firebase 的實時數據庫。查看代碼以更好地理解它。
Firebase.setFloat("light", light);
// handle error
if (Firebase.failed()) {
Serial.print("setting /light failed:");
Serial.println(Firebase.error());
return;
}
上傳數據后,我們可以將其實時顯示在網絡應用程序上,并可從世界任何地方訪問。
-------------------------------------------------- -------------------------------------------------- -------------------------------------------------- ----------------------
3. 在 Web App 上顯示數據
單擊此處查看我的網絡應用程序。
這是你可以真正發揮創造力的地方。如果您熟悉 HTML 和 CSS,那么您可以制作用戶自己的 UI。我使用 Bootstrap 來創建我的。對于那些剛接觸網絡的人來說,這里是一個非常基本的 UI 的代碼(我沒有在這里提供我的代碼,因為那將是勺子喂食,我希望你們構建自己的 UI。相信我,這很有趣!)
步驟1:
將此代碼粘貼到記事本中并將其另存為index.html的文件夾中,例如 在任何所需位置的網絡。
<html>
<head>
<script src="https://www.gstatic.com/firebasejs/5.8.4/firebase.js">script>
<script src="https://www.gstatic.com/firebasejs/5.8.5/firebase-app.js">script>
<script src="https://www.gstatic.com/firebasejs/5.8.5/firebase-database.js">script>
head>
<body style="background-color: #4d4d4d;">
<ul>
<li><h1>LIGHTh1>
<pre id="light" style="font-size:24px;">pre>li>
<li><h1>TEMPERATUREh1>
<pre id="temp" style="font-size:24px;">pre>li>
<li><h1>HUMIDITYh1>
<pre id="hum" style="font-size:24px;">pre>li>
ul>
<script src="app.js">script>
body>
html>
第2 步:
在 firebase 中創建一個數據庫。打開Firebase 網站。使用您的 Gmail 帳戶登錄。通過單擊數據庫創建一個實時數據庫。然后按照圖像中的方向獲取密鑰。

第 3 步:
將以下代碼復制并粘貼到記事本中,并將其作為app.js保存在您保存index.html文件的同一文件夾中。
(function() {
// Initialize Firebase
var config = {
firebase.initializeApp(config);
//Get element
const prelight= document.getElementById('light');
//Create refences
const dbReflight= firebase.database().ref().child('light');
// sync logs cahnges
dbReflight.on('value', snap => {
prelight.innerText=JSON.stringify(snap.val(),null,3);
});
const pretemp= document.getElementById('temp');
//Create refences
const dbReftemp= firebase.database().ref().child('temperature');
// sync logs cahnges
dbReftemp.on('value', snap => {
pretemp.innerText=JSON.stringify(snap.val(),null,3)+"° C";
});
const prehum= document.getElementById('hum');
//Create refences
const dbRefhum= firebase.database().ref().child('moisture');
// sync logs cahnges
dbRefhum.on('value', snap => {
prehum.innerText=JSON.stringify(snap.val(),null,3)+" %";
});
}());
您必須根據您的數據庫更改 var config 中的值。

完成此操作后,您就可以開始了。
將代碼上傳到您的 NodeMCU,建立連接并為電路板加電。它將開始將數據上傳到 Firebase。
-------------------------------------------------- ----------------------------------
注意:不要忘記在.ino 文件中更改您的 WIFI SSID、WIFI 密碼、密碼和主機名。
#define FIREBASE_HOST "YOUR DATABASE LINK"
#define FIREBASE_AUTH "SECRET CODE"
#define WIFI_SSID "YOUR SSID"
#define WIFI_PASSWORD "YOUR PASSWORD"
-------------------------------------------------- ----------------------------------
完成此操作后,只需打開index.html文件即可實時查看您的數據。
我希望你們理解這個項目。感謝您閱讀本教程。如果您有任何疑問或疑問,請在評論部分發表評論。
祝你好運!
- 設施農業實時氣象信息采集與發布系統的設計
- 在線氣象站開源分享
- Chaac氣象站開源項目
- 太陽能氣象站開源項目
- 辛迪的鬧鐘/錄音氣象站開源分享
- 使用Arduino和網絡技術制作實時氣象站
- 宙斯電子氣象站(ZeWS)開源分享
- 獨特的桌面氣象站開源設計
- WIFI氣象站開源分享
- 屏幕上的氣象站開源案例
- 便攜式氣象站開源分享
- 無人機氣象站開源分享
- Arduino氣象站的設置開源分享
- 微型互聯網氣象站開源項目
- Arduino Nano氣象站開源
- Nuttx RTOS入門知識簡介及開源代碼運行 5861次閱讀
- 基于幾何的泰森多邊形來生成形體骨架 1004次閱讀
- 前沿開源技術領域的開源大數據一一解讀 1180次閱讀
- 4G氣象站的設計與實現 991次閱讀
- 如何利用ESP8266實現防雨物聯網氣象站的設計 5136次閱讀
- 如何利用粒子光子把你的雨傘變成氣象站 1532次閱讀
- 如何使用ESP32創建一個氣象站 4040次閱讀
- 基于樹莓派組成的可隨身攜帶氣象站設計方案 2989次閱讀
- 如何使用兩個dht傳感器及HC12模塊制作遠程氣象站? 2977次閱讀
- 基于創建帶有空氣質量傳感器的室內氣象站 2358次閱讀
- dfrobotDIY智能氣象站套件簡介 1756次閱讀
- 阿米納隱形音響,將私人影院和高端養生會所結合,讓客戶享受綜合性服務 4191次閱讀
- 新興科技趨勢報告:20項最值得關注的科技發展趨勢 6377次閱讀
- 基于STM32的自動氣象站控制模塊設計 8676次閱讀
- FreeRTOS嵌入式開源實時操作系統介紹 4250次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數據手冊
- 1.06 MB | 532次下載 | 免費
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費
- 3TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費
- 5元宇宙深度解析—未來的未來-風口還是泡沫
- 6.40 MB | 227次下載 | 免費
- 6迪文DGUS開發指南
- 31.67 MB | 194次下載 | 免費
- 7元宇宙底層硬件系列報告
- 13.42 MB | 182次下載 | 免費
- 8FP5207XR-G1中文應用手冊
- 1.09 MB | 178次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33566次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21549次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動電路設計》 溫德爾著
- 0.00 MB | 6656次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537798次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191187次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183279次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論