Paso 2: El programa
Explicaciones de código (código completo más abajo):
#include "U8glib.h"#include "BMP280.h"
Son las 2 bibliotecas que tienes que poner dentro de Documents\Arduino\libraries\
#define P0 1021.97
Esto es donde calibrar el altímetro, si se cambia este valor. Una vez hecho, es bastante exacto!
(por defecto es 1013.25, tuve que subir a 1021.97 a la altitud correcta en mi ciudad)
U8GLIB_SSD1306_128X64 u8g(U8G_I2C_OPT_NO_ACK);
Aquí definen el tipo de pantalla Oled (128 x 64 etc...)
u8g.drawStr( 5, 10, "Temp: "); u8g.drawStr( 5, 30, "Bar : "); u8g.drawStr( 5, 50, "Alt : "); u8g.drawStr( 50, 10, sT); u8g.drawStr( 50, 30, sP); u8g.drawStr( 50, 50, sA);
Aquí la información que desea mostrar en la primera pantalla y de su posición (Y, X, valor)
dtostrf(A_MIN, 4, 2, sA_MIN); dtostrf(A_MAX, 4, 2, sA_MAX); u8g.drawStr( 5, 20, "A Min: "); u8g.drawStr( 60, 20, sA_MIN); u8g.drawStr( 5, 45, "A Max: "); u8g.drawStr( 60, 45, sA_MAX);
Mismo para la segunda pantalla
if ( A > A_MAX) { A_MAX = A; }
if ( A < A_MIN || A_MIN == 0) { A_MIN = A; }
Aquí actualizamos la altitud mínima y máxima almacenada
do { draw(T, P, A); } while ( u8g.nextPage() ); u8g.firstPage(); delay(1000);
Aquí, con el valor de delay (1000 en este caso), te quedas 1 segundo en la primera pantalla antes de pasar a la segunda. Así cambiar si quiere personalizar pantalla tiempo :)
do { draw2(A_MIN, A_MAX); } while ( u8g.nextPage() ); u8g.firstPage(); delay(1000);
Mismo para segunda pantalla!
Espero que sea claro, no dude en enviar una pregunta en los comentarios si es necesario!
Aquí está el código completo:
#include "U8glib.h"#include "BMP280.h" #include "Wire.h" #define P0 1021.97 //1013.25 BMP280 bmp; // OLED Type U8GLIB_SSD1306_128X64 u8g(U8G_I2C_OPT_NO_ACK); char sT[20]; char sP[9]; char sA[9]; char sA_MIN[9]; char sA_MAX[9]; double A_MIN = 0; double A_MAX = 0; void draw(double T, double P, double A) { u8g.setFont(u8g_font_unifont); dtostrf(T, 4, 2, sT); dtostrf(P, 4, 2, sP); dtostrf(A, 4, 2, sA); u8g.drawStr( 5, 10, "Temp: "); u8g.drawStr( 5, 30, "Bar : "); u8g.drawStr( 5, 50, "Alt : "); u8g.drawStr( 50, 10, sT); u8g.drawStr( 50, 30, sP); u8g.drawStr( 50, 50, sA); } void draw2(double A_MIN, double A_MAX) { u8g.setFont(u8g_font_unifont); dtostrf(A_MIN, 4, 2, sA_MIN); dtostrf(A_MAX, 4, 2, sA_MAX); u8g.drawStr( 5, 20, "A Min: "); u8g.drawStr( 60, 20, sA_MIN); u8g.drawStr( 5, 45, "A Max: "); u8g.drawStr( 60, 45, sA_MAX); } void setup() { Serial.begin(9600); if (!bmp.begin()) { Serial.println("BMP init failed!"); while (1); } else Serial.println("BMP init success!"); bmp.setOversampling(4); u8g.setColorIndex(1); u8g.setFont(u8g_font_unifont); } void loop(void) { double T, P; char result = bmp.startMeasurment(); if (result != 0) { delay(result); result = bmp.getTemperatureAndPressure(T, P); if (result != 0) { double A = bmp.altitude(P, P0); if ( A > A_MAX) { A_MAX = A; } if ( A < A_MIN || A_MIN == 0) { A_MIN = A; } // Serial.print("T = \t"); Serial.print(T, 2); Serial.print(" degC\t"); // Serial.print("P = \t"); Serial.print(P, 2); Serial.print(" mBar\t"); // Serial.print("A = \t"); Serial.print(A, 2); Serial.println(" m"); u8g.firstPage(); do { draw(T, P, A); } while ( u8g.nextPage() ); u8g.firstPage(); delay(1000); do { draw2(A_MIN, A_MAX); } while ( u8g.nextPage() ); u8g.firstPage(); delay(1000); } else { Serial.println("Error."); } } else { Serial.println("Error."); } delay(100); } #include "Wire.h"1013.25 BMP280 de bmp; Tipo OLEDchar sT [20]; sP de Char [9]; char la sA [9]; char sA_MIN [9]; char sA_MAX [9]; doble A_MIN = 0; doble A_MAX = 0; void draw (doble T, doble P, doble A) {u8g.setFont(u8g_font_unifont); dtostrf (T, 4, 2, sT), dtostrf (P, 4, 2, sP); dtostrf (A, 4, 2, sA);} void draw2 (doble A_MIN, doble A_MAX) {u8g.setFont(u8g_font_unifont);} void setup() {Serial.begin(9600); si (! bmp.begin()) {Serial.println ("BMP init error!") mientras que (1);} else Serial.println ("BMP init éxito!"); bmp.setOversampling(4); u8g.setColorIndex(1); u8g.setFont(u8g_font_unifont);} void loop(void) {doble T, P; resultado de char = bmp.startMeasurment(); if (resultado! = 0) {delay(result); resultado = bmp.getTemperatureAndPressure (T, P); si (resultado! = 0) {doble A = bmp.altitude (P, P0);Si (A < A_MIN || A_MIN == 0) {A_MIN = A;} / / Serial.print ("T = \t"); Serial.Print (T, 2); Serial.Print ("degC\t"); Serial.Print ("P = \t"); Serial.Print (P, 2); Serial.Print ("mBar\t"); Serial.Print ("A = \t"); Serial.Print (A, 2); Serial.println ("m"); u8g.firstPage();