Tabla de contenido:
2025 Autor: John Day | [email protected]. Última modificación: 2025-01-13 06:57
Este instructivo describe un enfoque para leer datos de temperatura y humedad de un RuuviTag usando Bluetooth con una Raspberry Pi Zero W y para mostrar los valores en números binarios en un Pimoroni blinkt. pHAT. O, en pocas palabras: cómo construir un termómetro de vanguardia y un poco nerd.
El RuuviTag es una baliza bluetooth con sensor de código abierto que viene con sensores de temperatura / humedad / presión y de aceleración, pero también puede actuar como una baliza de proximidad estándar Eddystone ™ / iBeacon. Fue un proyecto de Kickstarter con mucho éxito y obtuve el mío hace unas semanas. Hay un Github con software python para leer el RuuviTag usando una frambuesa, y he usado uno de sus ejemplos, con algunas adiciones.
La Raspberry Pi Zero W es el último miembro de la familia RPi, básicamente un Pi Zero con Bluetooth y WLAN agregados.
¡El blinkt! pHAT de Pimoroni es básicamente una tira de ocho LED RBG configurados como HAT para Raspberry Pi. Es muy fácil de usar y viene con una biblioteca de Python. La idea era leer los datos del RuuviTag y mostrarlos usando el blinkt! SOMBRERO. Los valores se muestran como números binarios usando 7 de los LED, mientras que el ocho se usa para indicar si se muestran los valores de humedad o temperatura (+ / - / 0).
Paso 1: configurar el sistema
Configurar el sistema es fácil: - Encienda el RuuviTag (versión con sensor de temperatura RuuviTag).
- Configure su RPi Zero W, RPi3 o cualquier otro RPi con capacidad bluetooth agregada, siguiendo las instrucciones en www.raspberrypi.org.
- ¡Coloca el blinkt! SOMBRERO en el RPi (mientras está apagado).
- Instale el blinkt! y el software RuuviTag, como se indica en las páginas de GitHub correspondientes.
- Ahora tiene que identificar la dirección MAC de su RuuviTag
- copie el programa Python adjunto, ábralo con IDLE para Python 3
- cambie la dirección MAC del RuuviTag por la suya, luego guarde y ejecute el programa.
- no dude en modificar y optimizar el programa. El programa viene como está, para ser utilizado bajo su propio riesgo, no se asume ninguna responsabilidad por daños.
Paso 2: el dispositivo y el programa
Como se mencionó anteriormente, la idea era construir un sistema simple y económico para leer datos de la baliza y mostrar valores numéricos en el blinkt. HAT, o una tira de LED similar.
El rango de valores de temperatura a medir con un sistema basado en RPi estará en la mayoría de los casos entre - 50 ° C y + 80 ° C, para humedad entre 0 y 100%. Por tanto, una pantalla que pueda dar valores de -100 a +100 será suficiente para la mayoría de las aplicaciones. Los números decimales más pequeños como 128 se pueden mostrar como números binarios con 7 bits (o LED). Entonces, el programa toma los valores de temperatura y humedad del RuuviTag como números "flotantes" y los transforma en números binarios, que luego se muestran en el blinkt !.
Como primer paso, el número se redondea, se analiza si es positivo, negativo o cero, y luego se transforma en un número positivo usando "abs". Luego, el número decimal se convierte en un número binario de 7 dígitos, básicamente una cadena de 0 y 1, que se analiza y se muestra en los últimos 7 píxeles del blinkt !.
Para los valores de temperatura, el primer píxel indica si el valor es positivo (rojo), cero (magenta) o negativo (azul). Al mostrar los valores de humedad, se establece en verde. Para simplificar la discriminación entre los valores de temperatura y humedad, los píxeles binarios se establecen en blanco para la temperatura y en amarillo para la humedad. Para mejorar la legibilidad de los números binarios, los píxeles "0" no se desactivan por completo, sino que se configuran mucho más débiles que en el estado "1". ¡Como blinkt! los píxeles son muy brillantes, puede configurar el brillo general cambiando el parámetro "brillante"
El programa muestra los valores y partes del proceso también en pantalla. Además, encontrará varias instrucciones de impresión silenciadas (#). Los dejé, ya que pueden resultarle útiles para comprender el proceso si no están silenciados.
Los valores también pueden almacenarse en un archivo de registro.
Paso 3: Código de programa
El código fue un poco depurado y optimizado. Ahora puede encontrar la versión 3 (20_03_2017).
'¡Este programa está diseñado para leer los valores de temperatura, humedad y presión de un RuuviTag' 'y mostrar los valores de temperatura y humedad como números binarios en un parpadeo de Pimorini! SOMBRERO. '' '' Se basa en el ejemplo print_to_screen.py de la biblioteca ruuvitag en github. '' Requiere un Pi Zero W, Pi 3 o cualquier otro RPi equipado con bluetooth y todas las bibliotecas necesarias instaladas. '
tiempo de importación
importar sistema operativo desde fecha y hora importar fecha y hora
de ruuvitag_sensor.ruuvi importar RuuviTagSensor
de blinkt import set_clear_on_exit, set_pixel, clear, show
def temp_blinkt (bt):
# ¡esta rutina toma el valor de temperatura y lo muestra como un número binario en blinkt!
claro ()
# color e intensidad de "1" píxeles: blanco
r1 = 64 g1 = 64 b1 = 64
#color e intensidad de "0" píxeles: blanco
r0 = 5 g0 = 5 b0 = 5
# Redondea y convierte en entero
r = redondo (bt)
# vz representa el signo algebraico del píxel indicador
if (r> 0): vz = 1 # positivo elif (r <0): vz = 2 # negativo else: vz = 0 # cero # print (vz) i = abs (r) #print (i)
# transformar en número binario absoluto de 7 dígitos
i1 = i + 128 # para i da como resultado un número binario de 8 dígitos que comienza con 1 # print (i1)
b = "{0: b}". formato (i1) # convertir a binario
# imprimir (b)
b0 = str (b) # convertir a cadena
b1 = b0 [1: 8] #truncar el primer bit
print ("número binario:", b1)
# ¡Establecer píxeles en blinkt!
# establecer número binario
para h en el rango (0, 7): f = (h + 1) if (b1 [h] == "1"): set_pixel (f, r1, g1, b1) # print ("bit", h, " es 1, pixel ", f) else: set_pixel (f, r0, g0, b0) # print (" nil ")
# Establecer píxel indicador
if (vz == 1): set_pixel (0, 64, 0, 0) # rojo para valores positivos elif (vz == 2): set_pixel (0, 0, 0, 64) # azul para valores negativos else: set_pixel (0, 64, 0, 64) # magenta si es cero
show()
# final de temp_blinkt ()
def hum_blinkt (bh):
# ¡Esto toma el valor de humedad y lo muestra como un número binario en blinkt!
claro()
# color e intensidad de "1" píxeles: amarillo
r1 = 64 g1 = 64 b1 = 0
#color e intensidad de "0" píxeles:
r0 = 5 g0 = 5 b0 = 0
# Redondea y transforma en entero
r = redondo (bh)
# transformar a un número binario absoluto de 7 dígitos i = abs (r) #print (i)
i1 = i + 128 # para i da un número binario de 8 dígitos que comienza con 1
# imprimir (i1)
b = "{0: b}". formato (i1)
# imprimir (b)
b0 = str (b)
b1 = b0 [1: 8] #truncar el primer bit
print ("número binario:", b1)
# ¡Establecer píxeles en blinkt!
# establecer el número binario en píxeles
para h en el rango (0, 7): f = (h + 1) if (b1 [h] == "1"): set_pixel (f, r1, g1, b1) else: # mute to blank LED set_pixel (f, r0, g0, b0) # silenciar a LED en blanco
# Establecer píxel indicador
set_pixel (0, 0, 64, 0) # verde para humedad
show()
# final de hum_blinkt ()
set_clear_on_exit ()
# Leer datos de RuuviTag
mac = 'EC: 6D: 59: 6D: 01: 1C' # Cambie a la dirección mac de su propio dispositivo
print ('Comenzando')
sensor = RuuviTagSensor (mac)
mientras que es cierto:
datos = sensor.update ()
line_sen = str.format ('Sensor - {0}', mac)
line_tem = str.format ('Temperatura: {0} C', datos ['temperatura']) line_hum = str.format ('Humedad: {0}%', datos ['humedad']) line_pre = str.format ('Presión: {0}', datos ['presión'])
impresión()
# muestra la temperatura en blinkt! ba = str.format ('{0}', data ['temperatura']) bt = float (ba) print (bt, "Â ° C") temp_blinkt (bt) print ()
time.sleep (10) # muestra la temperatura durante 10 segundos
# mostrar la humedad en blinkt!
bg = str.format ('{0}', data ['humedad']) bh = float (bg) print (bh, "%") hum_blinkt (bh) print ()
# Limpiar la pantalla e imprimir los datos del sensor en la pantalla
os.system ('clear') print ('Presiona Ctrl + C para salir. / n / n') print (str (datetime.now ())) print (line_sen) print (line_tem) print (line_hum) print (line_pre) imprimir ('\ n / n / r …….')
# Espere unos segundos y comience de nuevo
try: time.sleep (8) excepto KeyboardInterrupt: # Cuando se presiona Ctrl + C, la ejecución del ciclo while se detiene print ('Exit') clear () show () break