2025 Yazar: John Day | [email protected]. Son düzenleme: 2025-01-13 06:58
Bu talimat, bir Raspberry Pi Zero W ile Bluetooth kullanarak bir RuuviTag'den sıcaklık ve nem verilerini okumak ve değerleri bir Pimoroni yanıp söndüğünde ikili sayılarda görüntülemek için bir yaklaşımı açıklar! pHAT. Ya da kısaca söylemek gerekirse: son teknoloji ürünü ve biraz inek termometresi nasıl oluşturulur.
RuuviTag, sıcaklık/nem/basınç ve hızlanma sensörleriyle birlikte gelen, ancak aynı zamanda standart bir Eddystone™ / iBeacon yakınlık işareti olarak da işlev görebilen açık kaynaklı bir sensör bluetooth işaretçisidir. Çok başarılı bir Kickstarter projesiydi ve benimkini birkaç hafta önce aldım. Bir ahududu kullanarak RuuviTag'i okumak için python yazılımına sahip bir Github var ve bazı eklemelerle örneklerinden birini kullandım.
Raspberry Pi Zero W, RPi ailesinin en son üyesidir, temelde Bluetooth ve WLAN eklenmiş bir Pi Zero.
Göz kırptı! Pimoroni'den pHAT, temel olarak Raspberry Pi için bir HAT olarak yapılandırılmış sekiz RBG LED'den oluşan bir şerittir. Kullanımı çok kolaydır ve bir python kütüphanesi ile birlikte gelir. Fikir, RuuviTag'den gelen verileri okumak ve yanıp sönerek görüntülemekti! ŞAPKA. Değerler, LED'lerin 7'si kullanılarak ikili sayılar olarak görüntülenirken, sekizi, nem veya sıcaklık (+/-/0) değerlerinin görüntülenip görüntülenmediğini belirtmek için kullanılır.
Adım 1: Sistemin Kurulması
Sistemin kurulumu kolaydır:- RuuviTag'i (RuuviTag sıcaklık sensörü versiyonu) açın.
- www.raspberrypi.org adresindeki talimatları izleyerek RPi Zero W, RPi3 veya bluetooth kapasitesi eklenmiş diğer herhangi bir RPi'nizi kurun.
- Bıçağı yerleştirin! RPi'de HAT (kapalıyken).
- Yanıp sönen yükleyin! ve ilgili GitHub sayfalarında belirtildiği gibi RuuviTag yazılımı.
- Artık RuuviTag'inizin MAC adresini tanımlamanız gerekiyor.
- ekli Python programını kopyalayın, IDLE for Python 3 ile açın
- RuuviTag'in MAC adresini kendinize göre değiştirin, ardından programı kaydedin ve çalıştırın.
- programı değiştirmek ve optimize etmekten çekinmeyin. Program olduğu gibi gelir, kendi sorumluluğunuzdadır, herhangi bir hasar için sorumluluk alınmaz.
Adım 2: Cihaz ve Program
Yukarıda bahsedildiği gibi, fikir, beacon'dan veri okumak ve yanıp sönmede sayısal değerleri görüntülemek için basit ve ucuz bir sistem kurmaktı! HAT veya benzeri bir LED şerit.
RPi tabanlı bir sistemle ölçülecek sıcaklık değerleri aralığı çoğu durumda -50°C ile +80°C arasında, nem için %0 ile %100 arasında olacaktır. Bu yüzden -100 ile +100 arasında değerler verebilen bir ekran çoğu uygulama için yeterli olacaktır. 128'den küçük ondalık sayılar, 7 bitlik (veya LED'li) ikili sayılar olarak görüntülenebilir. Böylece program RuuviTag'den sıcaklık ve nem değerlerini "kayan" sayılar olarak alır ve bunları ikili sayılara dönüştürür, bunlar daha sonra yanıp söndüğünde görüntülenir!.
İlk adım olarak, sayı yuvarlanır, pozitif, negatif veya sıfır olup olmadığı analiz edilir ve ardından "abs" kullanılarak pozitif bir sayıya dönüştürülür. Ardından, ondalık sayı 7 basamaklı bir ikili sayıya dönüştürülür, temelde 0'lar ve 1'lerden oluşan bir dizidir ve bu, yanıp sönmenin son 7 pikselinde analiz edilir ve görüntülenir.
Sıcaklık değerleri için ilk piksel, değerin pozitif (kırmızı), sıfır (macenta) veya negatif (mavi) olduğunu gösterir. Nem değerleri görüntülendiğinde yeşile ayarlanır. Sıcaklık ve nem değerleri arasındaki ayrımı basitleştirmek için ikili pikseller sıcaklık için beyaz ve nem için sarı olarak ayarlanır. İkili sayıların okunabilirliğini artırmak için "0" pikseli tamamen kapatılmaz, bunun yerine "1" durumundan çok daha zayıf ayarlanır. Göz kırptı olarak! pikseller çok parlak, "parlak" parametresini değiştirerek genel parlaklığı ayarlayabilirsiniz
Program, işlemin değerlerini ve kısımlarını ekranda da gösterir. Ek olarak, birkaç sessiz (#) yazdırma talimatı bulacaksınız. Sesi açılmamışsa süreci anlamada yardımcı olabileceğiniz için onları içeride bıraktım.
Değerler ayrıca bir günlük dosyasında saklanabilir.
Adım 3: Program Kodu
Kod biraz hata ayıklandı ve optimize edildi. Artık sürüm 3'ü (20_03_2017) bulabilirsiniz.
' Bu program bir RuuviTag'den sıcaklık, nem ve basınç değerlerini okumak ve sıcaklık ve nem değerlerini bir Pimorini yanıp sönmesi üzerinde ikili sayılar olarak görüntülemek için tasarlanmıştır! ŞAPKA. '' '' ' github'daki ruuvitag kitaplığındaki print_to_screen.py örneğine dayanmaktadır. ' ' Bir Pi Zero W, Pi 3 veya bluetooth ile donatılmış başka bir RPI ve tüm gerekli kitaplıkların kurulu olmasını gerektirir.'
ithalat zamanı
işletim sistemini tarih saatinden içe aktar tarih saatini içe aktar
ruuvitag_sensor.ruuvi'den RuuviTagSensor'ü içe aktarın
yanıp sönen import set_clear_on_exit, set_pixel, clear, show
def temp_blinkt(bt):
# bu rutin sıcaklık değerini alır ve yanıp söndüğünde ikili sayı olarak görüntüler!
açık ()
# "1" pikselin rengi ve yoğunluğu: beyaz
r1 = 64 g1 = 64 b1 = 64
"0" pikselin #renk ve yoğunluğu: beyaz
r0 = 5 g0 = 5 b0 = 5
# Yuvarla ve tam sayıya dönüştür
r = yuvarlak (bt)
# vz, gösterge pikseli için cebirsel işareti temsil eder
if (r>0): vz = 1 # pozitif elif (r<0): vz= 2 # negatif başka: vz= 0 # sıfır # print (vz) i = abs(r) #print (i)
# mutlak, 7 basamaklı ikili sayıya dönüştür
i1 = i + 128 # i için 1 # print (i1) ile başlayan 8 basamaklı bir ikili sayı ile sonuçlanır
b = "{0:b}".format(i1) # ikiliye dönüştür
# yazdır (b)
b0 = str (b) # dizgeye dönüştür
b1 = b0[1:8] #ilk biti kes
yazdır ("ikili sayı: ", b1)
# Yanıp sönen pikselleri ayarlayın!
# ikili sayı ayarla
(0, 7) aralığında h için: f = (h+1) if (b1[h] == "1"): set_pixel (f, r1, g1, b1) # print ("bit ", h, " is 1, pixel ", f) else: set_pixel (f, r0, g0, b0) # print("nil")
# Gösterge pikselini ayarla
if (vz==1): set_pixel (0, 64, 0, 0) # pozitif değerler için kırmızı elif (vz==2): set_pixel (0, 0, 0, 64) # negatif değerler için mavi başka: set_pixel (0, 64, 0, 64) # sıfır ise macenta
göstermek()
# temp_blinkt() sonu
tanım hum_blinkt(bh):
# bu nem değerini alır ve yanıp sönerken ikili sayı olarak görüntüler!
açık()
# "1" pikselin rengi ve yoğunluğu: sarı
r1 = 64 g1 = 64 b1 = 0
#"0" pikselin rengi ve yoğunluğu:
r0 = 5 g0 = 5 b0 = 0
# Yuvarla ve tam sayıya dönüştür
r = yuvarlak (bh)
# mutlak, 7 basamaklı ikili sayıya dönüştür i = abs(r) #print (i)
i1 = i + 128 # i için 1 ile başlayan 8 basamaklı bir ikili sayı verir
# yazdır (i1)
b = "{0:b}".format(i1)
# yazdır (b)
b0 = str (b)
b1 = b0[1:8] #ilk biti kes
yazdır ("ikili sayı: ", b1)
# Yanıp sönen pikselleri ayarlayın!
# ikili sayıyı piksel olarak ayarla
(0, 7) aralığında h için: f = (h+1) if (b1[h] == "1"): set_pixel (f, r1, g1, b1) else: # boş LED'leri sessize al set_pixel (f), r0, g0, b0) # boş LED'leri sessize al
# Gösterge pikselini ayarla
set_pixel (0, 0, 64, 0) # nem için yeşil
göstermek()
# hum_blinkt()'in sonu
set_clear_on_exit()
# RuuviTag'den veri okuma
mac = 'EC:6D:59:6D:01:1C' # Kendi cihazınızın mac adresini değiştirin
print('Başlangıç')
sensör = RuuviTagSensor(mac)
Doğru iken:
veri = sensör.güncelleme()
line_sen = str.format('Sensör - {0}', mac)
line_tem = str.format('Sıcaklık: {0} C', veri['sıcaklık']) line_hum = str.format('Nem: {0} %', veri['nem']) line_pre = str.format('Basınç: {0}', veri['basınç'])
Yazdır()
# yanıp söndüğünde sıcaklığı göster! ba = str.format('{0}', data['sıcaklık']) bt = kayan nokta (ba) print (bt, " °C") temp_blinkt (bt) print()
time.sleep (10) # sıcaklığı 10 saniye gösterir
# yanıp sönerken nemi göster!
bg = str.format('{0}', veri['nem']) bh = kayan nokta (bg) yazdır (bh, " %") hum_blinkt (bh) yazdır ()
# Ekranı temizle ve sensör verilerini ekrana yazdır
os.system('clear') print('Çıkmak için Ctrl+C'ye basın.\n\n') print(str(datetime.now())) print(line_sen) print(line_tem) print(line_hum) print(line_pre) print('\n\n\r…….')
# Birkaç saniye bekleyin ve yeniden başlayın
try: time.sleep(8) KeyboardInterrupt hariç: # Ctrl+C'ye basıldığında while döngüsünün yürütülmesi durdurulur print('Exit') clear() show () break