dht11.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. #include "dht11.h"
  2. #include "public.h"
  3. unsigned char dht11_read_byte(void)
  4. {
  5. unsigned char r_val = 0;
  6. unsigned char t_count = 0; //计时器,防止超时;
  7. unsigned char i;
  8. for(i = 0 ; i < 8 ; i++)
  9. {
  10. t_count = 0;
  11. //低电平50us后开始一个数据位读取;
  12. while( !DHT11_PIN )
  13. {
  14. asm("NOP");
  15. t_count++;
  16. if(t_count > 250) //超时;
  17. return 100;
  18. }
  19. t_count = 0;
  20. system_delay_us(32); //32us
  21. //高电平26~28us表示'0',70us表示'1'
  22. if( DHT11_PIN == 1 )
  23. {
  24. r_val <<= 1;
  25. r_val |= 1;
  26. }
  27. else
  28. {
  29. r_val <<= 1;
  30. continue;
  31. }
  32. //等待DHT11数据输出结束;
  33. while( DHT11_PIN == 1)
  34. {
  35. asm("NOP");
  36. t_count++;
  37. if(t_count>250)
  38. {
  39. return 100;
  40. }
  41. }
  42. }
  43. return r_val;
  44. }
  45. char dht11_value(unsigned char *temp , unsigned char *humi , unsigned char flag)
  46. {
  47. unsigned char t_count = 0; //计时器;
  48. unsigned char h_i = 0 , h_f = 0;
  49. unsigned char t_i = 0 , t_f = 0;
  50. unsigned char check_sum = 0;
  51. DHT11_PIN_OUT();
  52. DHT11_PIN_L(); //输出低电平;
  53. //低电平持续时间必须大于18ms;
  54. system_delay_us(20000); //20ms;
  55. DHT11_PIN_H(); //主机结束信号,高电平;
  56. //主机等待20us~40us,读取DHT11响应输出;
  57. system_delay_us(30);
  58. DHT11_PIN_IN();
  59. if(DHT11_PIN == 0) //正确的响应输出;
  60. {
  61. while( !DHT11_PIN )
  62. {
  63. asm("NOP");
  64. t_count++;
  65. if(t_count > 250) //超时;
  66. return -1;
  67. }
  68. t_count = 0;
  69. system_delay_us(50); //DHT11给出响应输出后会拉高总线80us;
  70. while( DHT11_PIN ); //等待接收;
  71. {
  72. asm("NOP");
  73. t_count++;
  74. if(t_count > 250) //超时;
  75. return -1;
  76. }
  77. h_i = dht11_read_byte(); //湿度整数部分;
  78. h_f = dht11_read_byte(); //湿度小数部分;
  79. t_i = dht11_read_byte(); //温度整数部分;
  80. t_f = dht11_read_byte(); //温度小数部分;
  81. check_sum = dht11_read_byte(); //校验和;
  82. //校验和正确或者温湿度整数部分获取正确即表示获取成功!
  83. if(check_sum == ( h_i + h_f + t_i + t_f ) || (h_i != 100 && t_i != 100) )
  84. {
  85. if(flag == DHT11_STRING)
  86. {
  87. temp[0] = t_i/10+0x30;
  88. temp[1] = t_i%10+0x30;
  89. humi[0] = h_i/10+0x30;
  90. humi[1] = h_i%10+0x30;
  91. }
  92. else
  93. {
  94. *temp = t_i;
  95. *humi = h_i;
  96. }
  97. }
  98. else
  99. {
  100. // if(flag == DHT11_STRING)
  101. // {
  102. // temp[0] = '0';
  103. // temp[1] = '0';
  104. // humi[0] = '0';
  105. // humi[1] = '0';
  106. // }
  107. // else
  108. // {
  109. // *temp = 0;
  110. // *humi = 0;
  111. // }
  112. return -1;
  113. }
  114. }
  115. else
  116. {
  117. // if(flag == DHT11_STRING)
  118. // {
  119. // temp[0] = '0';
  120. // temp[1] = '0';
  121. // humi[0] = '0';
  122. // humi[1] = '0';
  123. // }
  124. // else
  125. // {
  126. // *temp = 0;
  127. // *humi = 0;
  128. // }
  129. return -1;
  130. }
  131. return 0;
  132. }