new logo iset57-black
Carrera de Técnicas Digitales en Rosario - Tel. (0341) 4720470

 

/*
LECTURA DE TEMPERATURA Y HUMEDAD COPN EL DHT11
LA INFO SE MUESTRA EN UN LCD.

PIC16F628A

-Realizado para MikroC-
Mayo 2014 -OK-
*/

/***********************************/
/* Configuracion del DHT11 */
sbit LCD_RS at RB4_bit;
sbit LCD_EN at RB5_bit;
sbit LCD_D7 at RB3_bit;
sbit LCD_D6 at RB2_bit;
sbit LCD_D5 at RB1_bit;
sbit LCD_D4 at RB0_bit;
// Pin direction
sbit LCD_RS_Direction at TRISB4_bit;
sbit LCD_EN_Direction at TRISB5_bit;
sbit LCD_D7_Direction at TRISB3_bit;
sbit LCD_D6_Direction at TRISB2_bit;
sbit LCD_D5_Direction at TRISB1_bit;
sbit LCD_D4_Direction at TRISB0_bit;
/***********************************/

char message1[] = "Temp = 00.0ºC";
char message2[] = "RH = 00.0 %";

/*
Lectura de los 8 bits (1 byte)
*/
unsigned short ReadByte()
{
unsigned short num = 0, i,t;
TRISA.B0 = 1;
for (i=0; i<8; i++){

//espero la subida del flanco
while(!PORTA.B0);

//espero 40us para caer dentro de un 0 (siguiente inicio de bit)
//o dentro del '1' de 80us
Delay_us(40);

//seteo el bit que corresponda (si es 1 )
if(PORTA.B0) num |= 1<<(7-i);

//espero que termine el nivel 1 (espero flanco de bajada final)
while(PORTA.B0);

} return num;
}

/*
Lee la trama de 5 bytes (40 bits) del DHT11.
La trama es asi:
+---+---+---+---+---+
|RH1|RH2|T1 |T2 |CHK|
+---+---+---+---+---+
Data format: 8bit integral RH data + 8bit decimal RH data
+ 8bit integral T data + 8bit decimal T data
+ 8bit check sum.
If the data transmission is right, the check-sum should be the last 8bit
of "8bit integral RH data + 8bit decimal RH data
+ 8bit integral T data + 8bit decimal T data".
*/
unsigned char leer_DHT11(char *RH1, char *RH2, char *T1, char *T2)
{
//----------------------------------
// Pulso de Start para el DHT11
TRISA.B0=0; // Escribo en el DHT11.
PORTA.B0=0; // pulso de bajada de 20ms.
Delay_ms(25);
PORTA.B0=1; // pulso en 1 de 30us.
Delay_us(20);
TRISA.B0=1; // lectura del DHT11

//----------------------------------
//espero que responda el DHT11...
while(!PORTA.B0);
while(PORTA.B0);

//----------------------------------
// leo de los 4 bytes de datos
*RH1 = ReadByte();
*RH2 = ReadByte();
*T1 = ReadByte();
*T2 = ReadByte();

//----------------------------------
// leo el checksum y retorno :
// 0=ERROR , 1=OK
return ReadByte() == *RH1 + *RH2 + *T1 + *T2;
}



void main()
{
char i;
CMCON = 7; // TODO solo usar el bit que corresponde
TRISA = 1; // RA0 como entrada
//inicializo del display
Lcd_Init();
Lcd_Cmd(_LCD_CURSOR_OFF);
Lcd_Out(1, 1, "ISET 57");

while(1)
{
char RH1,RH2,T1,T2;

//espero unos segundos y borro el msg desplazando...
Delay_1sec();
Delay_1sec();
Delay_1sec();
for(i=0;i<14;i++) {
Lcd_Cmd(_LCD_SHIFT_LEFT);
Delay_100ms();
Delay_100ms();
Delay_100ms();
}

Lcd_Cmd(_LCD_CLEAR);
// lee la temperatura y humedad con el DHT11

leer_DHT11(&RH1,&RH2,&T1,&T2);
//transformo los datos en texto "imprimible"

message2[7] = RH1/10 + '0'; // DECENA de RH parte entera
message2[8] = RH1%10 + '0'; // UNIDAD de RH parte entera
message2[10] = RH2/10 + '0'; // RH parte decimal
message1[7] = T1/10 + '0'; // DECENA de Temp parte entera
message1[8] = T1%10 + '0'; // UNIDAD de Temp parte entera
message1[10] = T2/10 + '0'; // Temp parte decimal
message1[11] = 223; // simbolo de grado °

Lcd_Out(1, 1, message1);
Lcd_Out(2, 1, message2);

}
}