Indholdsfortegnelse:

Attiny85 Termómetro OLED: 5 trin
Attiny85 Termómetro OLED: 5 trin

Video: Attiny85 Termómetro OLED: 5 trin

Video: Attiny85 Termómetro OLED: 5 trin
Video: Самодельный цифровой термометр на ATtiny13 2024, December
Anonim
Attiny85 Termómetro OLED
Attiny85 Termómetro OLED
Attiny85 Termómetro OLED
Attiny85 Termómetro OLED

Este proyecto consiste en un termómetro pequeño y simple que muestra la facta actual, la humedad relativa y el índice de temperatura. Det kan realiseres med en ATmega328p, men kan også bruges til at bruge en version af ATtiny85 til at konvertere et batteri og disponere et porto.

En fortsættende beskrivelse af funktionsmulighederne, som kan bruges til at afslutte en fuldstændig gennemførelse af programmer og generelle kommentarer.

Forbrugsvarer

1 x ATtiny85

1 x Arduino UNO/PRO/etc (programmør af ATtiny)

1 x 128x64 pantalla I2C OLED

1 x Sensor temperatura DHT22

1 x Resistensia 4,7MOhm (1/4W)

1 x kondensator electrolítico 0.1uF

1 x Fuente de 3.3V - 5V 10+ x Jumpere

Trin 1: Beskriv Del Funcionamiento

El objetivo del proyecto es mostrar los tres valores anteriormente mencionados en la pantalla OLED, además, como objetivo secundario, e incluido el uso de la librería sleep. He interrupt. la batería.

Nuestro programa se guiará por el siguiente proceso: Leer temperatura -> Mostrar temperatura en pantalla -> Apagar ATtiny -> Reiniciar al presionar botón.

Para cada uno de estos pasos dejaremos la Mayor parte del trabajo a las librerías ya existentes, por lo que no reinventaremos la rueda. La librería DHT sensor library de Adafruit (disponible en el IDE) y Tiny4kOLED de datacute que descargaremos de Github ya que, al parecer, el author original es datacute y, además, necesitaremos modificarla un poco luego.

El método de reinicio puede ser tanto un botón como dos placas metálicas que se tocan para encender el equipo. En lo personlig, han encontrado la opción de las placas metálicas más interactivo.

Trin 2: Kredsløb

Kredsløb
Kredsløb
Kredsløb
Kredsløb
Kredsløb
Kredsløb

En la primer billeder kan encuentra el circuito que requerimos para programar el ATtiny85. Primeramente se debe programar al Arduino (el capacitor debe estar desconectado) con el sketch ArduinoISP, que se encuentra en Archivos -> Ejemplos -> 11. ArduinoISP. Una vez hecho esto se debe colocar el capacitor para evitar que nuestro Arduino se reinicie al programar el ATtiny85.

El ATtiny se puede alimentar directamente del Arduino. En caso de utilizar una fuente de poder como una batería es necesario conectar la masa (GND) del Arduino y el ATtiny85.

Colocar un botón entre el pin 13 del Arduino y el 2 del ATtiny puede facilitar el hacer pruebas ya que la pantalla no puede estar conectada cuando se programa al ATtiny.

Como se observa en las imágenes. El pin SDA del ATyiny es el 0 y el SCL/CLK es el 2. Nuestro DHT está conectado en el pin 4.

Trin 3: Programmering

Primeramente, debemos select "Arduino as ISP" som programmør. Si aún no han instalado la placa para el ATtiny, recomiendo installer la placa ATtinyCore de Spence Konde. Esta placa no me generó ningún problema de compilación durante la realización del proyecto.

La placa debe estar konfigurada sin BOD, kan reloj de 8MHz intern og y OptiBoot. En udnyttelse af 1MHz til I2C kan ikke foretages via en ekstern 16MHz ekstern enhed, der kan bruges til digitalisering af strøm, og forbruget af energibesparende oplysninger.

Kan fjernes, da han ændrer en arkiv på Tiny4kOLED. El archivo modificado es "font8x16.h" y he cambiado la línea 117 por el siguiente código con el fin de cambiar el símbolo ~ por ° que usaremos en ° C.

0x00, 0x06, 0x01, 0x01, 0x02, 0x02, 0x04, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00

En fortsat ajunto el sketch necesario para el proyecto.

#include #include #include #include #define I_PINB PCINT3 #define I_PIN PB3 #define I_VECTOR PCINT0_vect #define adc_disable () (ADCSRA & = ~ (1 << aden)) disable = "" adc = "" converter #define DHTPIN #define DHTTYPE DHT22 DHT dht (DHTPIN, DHTTYPE); const uint8_t bredde = 128; const uint8_t højde = 64; flygtig bool vendt = falsk; / * * * Interrupt handler * */ISR (PCINT_VECTOR) {// interrupt genopretter altid fra søvn, hvis (digitalRead (I_PIN) == HIGH) {slået = sandt; // indstil flaget til at tegne skærmen igen}} ugyldig opsætning () {cli (); // deaktiver afbrydelser PCMSK | = (1 << I_PINB); GIMSK | = (1 << PCIE); pinMode (I_PIN, INPUT); sei (); // tænde afbrydelser adc_disable (); // spare strøm ved at slukke for konverteren set_sleep_mode (SLEEP_MODE_PWR_DOWN); // indstil søvntypen til dyb søvn oled.begin (bredde, højde, størrelseof (tiny4koled_init_128x64br), tiny4koled_init_128x64br); // start oled objekt oled.setFont (FONT8X16); // denne skrifttype ser bedre ud end den anden drawScreen (); oled.on (); forsinkelse (2000); dht.begin (); vendt = sandt; // flag til tegningsskærm} ugyldig søvn () {sleep_enable (); sleep_cpu (); } ugyldig sløjfe () {hvis (vendt) {cli (); // sluk for interrupts oled.on (); float h = dht.readHumidity (); // falsk læsning for at nulstille dht cache forsinkelse (2200); // vent dht for at indlæse h = dht.readHumidity (); float t = dht.readTemperature (); float i = dht.computeHeatIndex (t, h, false); oled.setCursor (55, 1); oled.print (t); oled.print ("~ C"); oled.setCursor (55, 3); oled.print (h, 0); oled.print ("%"); oled.setCursor (55, 5); oled.print (i); oled.print ("~ C"); // symbolet ~ blev ændret på biblioteket til at ligne en ° graders forsinkelse (5000); // vis i 5 sekunder oled.off (); vendt = falsk; sei (); // vedhæft afbrydelser igen} søvn (); // gå altid i dvale i slutningen} void drawScreen () {// tegner rammen og hovedteksten for (uint8_t y = 0; y <8; y ++) {oled.setCursor (0, y); oled.startData (); for (uint8_t x = 0; x <128; x += 2) {oled.sendData (0b10101010); oled.sendData (0b01010101); } oled.endData (); } oled.setCursor (0, 0); oled.startData (); oled.sendData (0b11111111); oled.repeatData (0b00000101, bredde - 2); oled.sendData (0b11111111); oled.endData (); for (uint8_t y = 1; y <(højde - 8) / 8; y ++) {oled.setCursor (0, y); oled.startData (); oled.sendData (0b11111111); oled.repeatData (0b00000000, bredde - 2); oled.sendData (0b11111111); oled.endData (); } oled.setCursor (0, (højde - 8) / 8); oled.startData (); oled.sendData (0b11111111); oled.repeatData (0b10100000, bredde - 2); oled.sendData (0b11111111); oled.endData (); oled.setCursor (4, 1); oled.print ("Temp:"); oled.setCursor (4, 3); oled.print ("Hum:"); oled.setCursor (4, 5); oled.print ("Sens:"); }

Trin 4: Konklusioner

Konklusioner
Konklusioner
Konklusioner
Konklusioner

A pesar de su tamaño insignificante, el ATtiny85 ofrece una amplia gama de aplicaciones en las que podemos implementer este controlador de bajo costo sin perder funcionalidad. Personalmente no esperaba que fuera posible incluir el control of pantalla and the sleep juntos debido a las limitaciones de memoria. Dichozamente, el programa ha entrado en nuestro ATtiny

Eksister otras librerías para las pantallas OLED. La librería GFX de Adafruit no me permitió compilar por lo que decidí buscar algo precisamente para el ATtiny, pero existen otras librerías y soluciones que son interesantes de explorar

El forbrug af dispositivo es muy bajo. Tænk på en uso konstant, han medido og estimating la vida para una batería de 3000mAh (NiMH o LiIon) en 500 días. Elforbruget kan reducere mængden af en panton og en sensor, der skal bruges til at fastgøre en PIN -kode, men det er ikke nødvendigt at overveje det

Según Technoblogy.com el ATtiny puede operar en un consumo tan bajo como el mostrado en la primera imagen, pero en este proyecto he obtenido un consumo mayor que correspondonde al de la segunda image. El consumo de la batería continúa siendo lo suficientemente bajo como para ser un proyecto factible

Trin 5: Links Y Lecturas Relacionados

www.technoblogy.com/show?KX0&fbclid=IwAR0qu…

github.com/SpenceKonde/ATTinyCore

www.electroschematics.com/am2302-dht22-dat…

ww1.microchip.com/downloads/da/DeviceDoc/A…

embedded Thoughts.com/2016/06/06/attiny85-i…

www.instructables.com/id/ATtiny85-Interrup…

www.technoblogy.com/show?WNM

www.technoblogy.com/show?2F5D

Anbefalede: