DHT11温湿度传感器驱动程序_第1页
DHT11温湿度传感器驱动程序_第2页
DHT11温湿度传感器驱动程序_第3页
DHT11温湿度传感器驱动程序_第4页
DHT11温湿度传感器驱动程序_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

/* 本程序适用于DHT11温湿度传感器由于DHT11使用拉高总线的不同时常来代替0和1 0 28US 1 70us 同时数据送入1602a显示 */#include#include#include#define Data P0/数据端口sbit RS = P24; /Pin4sbit RW = P25; /Pin5sbit E = P26; /Pin6sbit dat=P12;unsigned int shidu_h=0,shidu_l=0,wendu_h=0,wendu_l=0,i,xiaoyan=0;/定义湿度 温度变量unsigned char code tab=0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39;/定义1602a显示0-9unsigned int a16=0 ;void delayus(unsigned char i) /延时2uswhile(-i);void delayms(unsigned char j) /延时1mswhile(-j)delayus(125);delayus(125);delayus(125);delayus(125);/*/* 写入命令函数 1602 */*/void WriteCommand(unsigned int c) delayms(10);/操作前短暂延时,保证信号稳定代替状态监测 E=0; RS=0; RW=0; _nop_(); E=1; Data=c; E=0;/*/* 写入数据函数 */*/void WriteData(unsigned char c) delayms(10);/操作前短暂延时,保证信号稳定 E=0; RS=1; RW=0; _nop_(); E=1; Data=c; E=0; RS=0;/*/* 写入字节函数 */*/void ShowChar(unsigned char pos,unsigned int c) unsigned char p; if (pos=0x10) p=pos+0xb0; /是第二行则命令代码高4位为0xc p低两位表示位置显示代码只用DDRAM前16位 else p=pos+0x80; /是第一行则命令代码高4位为0x8 p低两位表示位置显示代码只用DDRAM前16位 WriteCommand (p);/写命令写入数据指针确定行中哪一位显示 WriteData (c); /写数据/*/* 写入字符串函数 */*/void ShowString (unsigned char line,unsigned int *ptr) unsigned char l,i;/l表示行中某一位显示 l=line4;/L为0x01时左移四位为了与b0H相加变为0xc for (i=0;i16;i+) ShowChar (l+,*(ptr+i);/循环显示16个字符/*/* 初始化函数 */*/void InitLcd() WriteCommand(0x38); /display mode WriteCommand(0x38); /display mode WriteCommand(0x38); /display mode WriteCommand(0x06); /显示光标移动位置 WriteCommand(0x0c); /显示开及光标设置 WriteCommand(0x01); /显示清屏void main(void)InitLcd(); /初始化LCDdelayms(30);while(1) dat=0;delayms(18);/延时18ms拉低主线 dat=1;/主机拉高总线/*delayus(20);*/_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();while(!dat);/判断从机是否相应完毕相应完毕会拉高总线while(dat);/等待从机拉高总线准备开始传送数据while(!dat);/判断是否开始1bit 开始会拉高总线for(i=0;i8;i+)shidu_h=1; /右移1位delayus(14); /延时30us判断是否为1if(dat)shidu_h+;while(dat);/为一则等待从机拉低总线 为零直接跳出while(!dat);/判断是否开始1bit 开始会拉高总线for(i=0;i8;i+)delayus(14);shidu_l=1;if(dat)shidu_l+;while(dat);while(!dat);for(i=0;i8;i+)delayus(14);wendu_h=1;if(dat)wendu_h+;while(dat);while(!dat);for(i=0;i8;i+)delayus(14);wendu_l=1;if(dat)wendu_l+;while(dat);while(!dat);for(i=0;i8;i+)delayus(14);xiaoyan=1;if(dat)xiaoyan+;while(dat);while(!dat);a0=tab(wendu_h)/10;a1=tab(wendu_h)%10;a2=tab(shidu_h)/10;a3=tab(shi

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论