2025 Autor: John Day | [email protected]. Naposledy zmenené: 2025-01-13 06:58
Tento návod popisuje prístup k čítaniu údajov o teplote a vlhkosti z RuuviTag pomocou Bluetooth s Raspberry Pi Zero W a k zobrazeniu hodnôt v binárnych číslach na Pimoroni blinkt! pHAT. Alebo stručne povedané: ako vytvoriť najmodernejší a trochu nerdový teplomer.
RuuviTag je bluetooth maják s otvoreným zdrojovým senzorom, ktorý je dodávaný so snímačmi teploty/vlhkosti/tlaku a akcelerácie, ale môže fungovať aj ako štandardný bezdotykový maják Eddystone ™/iBeacon. Bol to veľmi úspešný projekt Kickstarter a ja som ten svoj dostal pred niekoľkými týždňami. Existuje Github so softvérom python na čítanie RuuviTag pomocou maliny a ja som použil jeden z ich príkladov s niekoľkými dodatkami.
Raspberry Pi Zero W je najnovším členom rodiny RPi, v zásade ide o Pi Zero s pripojením Bluetooth a WLAN.
Blinkt! pHAT od Pimoroni je v podstate pásom ôsmich LED diód RBG nakonfigurovaných ako HAT pre Raspberry Pi. Jeho použitie je veľmi jednoduché a je dodávaný s knižnicou python. Cieľom bolo prečítať údaje z RuuviTag a zobraziť ich pomocou blinkt! Klobúk. Hodnoty sa zobrazujú ako binárne čísla pomocou 7 diód LED, zatiaľ čo osem číslic sa používa na označenie, či sú zobrazené hodnoty vlhkosti alebo teploty (+/-/0).
Krok 1: Nastavenie systému
Nastavenie systému je jednoduché:- Zapnite RuuviTag (verzia snímača teploty RuuviTag).
- Nastavte RPi Zero W, RPi3 alebo akékoľvek iné RPi s pridanou kapacitou bluetooth podľa pokynov na www.raspberrypi.org.
- Umiestnite blinkt! Klobúk na RPi (keď je vypnutý).
- Nainštalujte si blinkt! a softvér RuuviTag, ako je uvedené na príslušných stránkach GitHub.
- Teraz musíte identifikovať MAC adresu vášho RuuviTag
- skopírujte priložený program Python, otvorte ho pomocou IDLE pre Python 3
- zmeňte MAC adresu RuuviTag na svoju, potom uložte a spustite program.
- neváhajte program upraviť a optimalizovať. Program prichádza tak, ako je, je používaný na vlastné riziko, nepreberáme žiadnu zodpovednosť za žiadne škody.
Krok 2: Zariadenie a program
Ako bolo uvedené vyššie, myšlienkou bolo vytvoriť jednoduchý a lacný systém na čítanie údajov z majáku a zobrazovanie číselných hodnôt na zariadení blinkt! HAT, alebo podobný LED pásik.
Rozsah hodnôt teploty, ktoré sa majú merať systémom založeným na RPi, bude vo väčšine prípadov niekde medzi - 50 ° C a +80 ° C, pre vlhkosť medzi 0 a 100%. Displej, ktorý môže dávať hodnoty od -100 do +100, bude teda postačovať pre väčšinu aplikácií. Desatinné čísla menšie ako 128 je možné zobraziť ako binárne čísla so 7 bitmi (alebo diódami LED). Program teda vezme hodnoty teploty a vlhkosti z RuuviTag ako „plávajúce“čísla a transformuje ich na binárne čísla, ktoré sa potom zobrazia na blinkt !.
V prvom kroku sa číslo zaokrúhli, analyzuje sa, či je kladné, záporné alebo nulové, a potom sa pomocou „abs“transformuje na kladné číslo. Potom sa desatinné číslo prevedie na 7-miestne binárne číslo, v zásade na reťazec 0 s a 1 s, ktoré sa analyzuje a zobrazí na posledných 7 pixeloch blinkt !.
Pri hodnotách teploty prvý pixel označuje, či je hodnota kladná (červená), nula (purpurová) alebo záporná (modrá). Po zobrazení hodnôt vlhkosti je nastavený na zelenú. Na zjednodušenie rozlíšenia hodnôt teploty a vlhkosti sú binárne pixely nastavené na teplotu bielu a žltú na vlhkosť. Na zvýšenie čitateľnosti binárnych čísel nie sú pixely „0“úplne vypnuté, ale naopak sú nastavené oveľa slabšie ako v stave „1“. Ako blinkt! pixely sú veľmi svetlé, všeobecný jas môžete nastaviť zmenou parametra „jasný“
Program zobrazí hodnoty a časti procesu aj na obrazovke. Okrem toho nájdete niekoľko tlmených (#) pokynov na tlač. Nechal som ich tam, pretože vám môžu pomôcť pri porozumení postupu, ak nie sú ignorovaní.
Hodnoty môžu byť tiež uložené v protokolovom súbore.
Krok 3: Programový kód
Kód bol trochu odladený a optimalizovaný. Teraz môžete nájsť verziu 3 (20_03_2017).
„Tento program je určený na čítanie hodnôt teploty, vlhkosti a tlaku z RuuviTag“a na zobrazenie hodnôt teploty a vlhkosti ako binárnych čísel na blinkri Pimorini! Klobúk. '' '' Je založená na príklade print_to_screen.py z knižnice ruuvitag na github. '' Vyžaduje Pi Zero W, Pi 3 alebo akékoľvek iné RPi vybavené bluetooth a nainštalované všetky potrebné knižnice. '
čas importu
import os from datetime import datetime
z ruuvitag_sensor.ruuvi importovať RuuviTagSensor
z blinkt import set_clear_on_exit, set_pixel, clear, show
def temp_blinkt (bt):
# táto rutina zoberie hodnotu teploty a zobrazí ju ako binárne číslo na blinkt!
jasný ()
# farba a intenzita „1“pixelov: biela
r1 = 64 g1 = 64 b1 = 64
#farba a intenzita „0“pixelov: biela
r0 = 5 g0 = 5 b0 = 5
# Zaokrúhľujte a konvertujte na celé číslo
r = kolo (bt)
# vz predstavuje algebraický znak pre indikátorový pixel
ak (r> 0): vz = 1 # pozitívny elif (r <0): vz = 2 # negatívny ostatné: vz = 0 # nula # tlač (vz) i = abs (r) # tlač (i)
# transformovať na absolútne, 7-miestne binárne číslo
i1 = i + 128 # pre i má za následok 8-miestne binárne číslo začínajúce 1 # tlačou (i1)
b = "{0: b}". formát (i1) # previesť na binárne
# tlač (b)
b0 = str (b) # previesť na reťazec
b1 = b0 [1: 8] #skrátiť prvý bit
tlač ("binárne číslo:", b1)
# Nastavte pixely na blinkt!
# nastaviť binárne číslo
pre h v rozsahu (0, 7): f = (h+1) if (b1 [h] == "1"): set_pixel (f, r1, g1, b1) # print ("bit", h, " je 1, pixel ", f) else: set_pixel (f, r0, g0, b0) # print (" nula ")
# Nastavte indikátorový pixel
if (vz == 1): set_pixel (0, 64, 0, 0) # red for positive values elif (vz == 2): set_pixel (0, 0, 0, 64) # blue for negative values else: set_pixel (0, 64, 0, 64) # purpurová, ak je nula
šou()
# end of temp_blinkt ()
def hum_blinkt (bh):
# toto zoberie hodnotu vlhkosti a zobrazí ju ako binárne číslo na blinkt!
jasný()
# farba a intenzita „1“pixelov: žltá
r1 = 64 g1 = 64 b1 = 0
#farba a intenzita „0“pixelov:
r0 = 5 g0 = 5 b0 = 0
# Zaokrúhľujte a transformujte na celé číslo
r = kolo (bh)
# transformácia na absolútne, 7-miestne binárne číslo i = abs (r) #print (i)
i1 = i + 128 # pre i dáva 8-miestne binárne číslo začínajúce sa 1
# print (i1)
b = "{0: b}". formát (i1)
# tlač (b)
b0 = str (b)
b1 = b0 [1: 8] #skrátiť prvý bit
tlač ("binárne číslo:", b1)
# Nastavte pixely na blinkt!
# nastaviť binárne číslo na pixely
pre h v rozsahu (0, 7): f = (h+1) if (b1 [h] == "1"): set_pixel (f, r1, g1, b1) else: # mute to blank LEDs set_pixel (f, r0, g0, b0) # stlmenie na prázdne diódy LED
# Nastavte indikátorový pixel
set_pixel (0, 0, 64, 0) # zelená pre vlhkosť
šou()
# koniec hum_blinkt ()
set_clear_on_exit ()
# Čítanie údajov z RuuviTag
mac = 'EC: 6D: 59: 6D: 01: 1C' # Zmeňte adresu mac svojho zariadenia
tlač („Začína“)
senzor = RuuviTagSensor (mac)
kým je pravda:
data = sensor.update ()
line_sen = str.format ('Senzor - {0}', mac)
line_tem = str.format ('Teplota: {0} C', údaje ['teplota']) line_hum = str.format ('Vlhkosť: {0} %', údaje ['vlhkosť']) line_pre = str.format ('Tlak: {0}', údaje ['tlak'])
vytlačiť ()
# zobrazenie teploty na blinkt! ba = str.format ('{0}', data ['teplota']) bt = float (ba) print (bt, "Â ° C") temp_blinkt (bt) print ()
time.sleep (10) # teplota displeja na 10 sekúnd
# zobrazte vlhkosť na blinkt!
bg = str.format ('{0}', údaje ['vlhkosť']) bh = float (bg) print (bh, " %") hum_blinkt (bh) print ()
# Vymažte obrazovku a vytlačte údaje senzora na obrazovku
os.system ('clear') print ('Ukončite stlačením Ctrl+C. / n / n') print (str (datetime.now ())) print (line_sen) print (line_tem) print (line_hum) print (line_pre) vytlačiť ('\ n / n / r …….')
# Počkajte niekoľko sekúnd a začnite znova
skúste: time.sleep (8) okrem KeyboardInterrupt: # Keď stlačíte Ctrl+C, vykonanie cyklu while sa zastaví tlač ('Exit') clear () show () break