单片机/MCU论坛
登录
直播中
luojun358
11年用户
79经验值
擅长:可编程逻辑 模拟技术 EDA/IC设计
私信
关注
[文章]
基于单片机的dht11湿度温度检测不显示问题
温度检测
用stc90c516rd+烧写该程序,在
开发板
上实验,lcd1602显示屏上不会显示温度和湿度,怎么回事啊
,是程序问题还是所用芯片不对呀,求助。。。(该程序是在网上找的)
#include
#define uint unsigned int
#define uchar unsigned char
typedef bit BOOL ;
***it io = P2^0 ;
***it rs = P2^7;
***it rw = P2^6 ;
***it ep = P2^5 ;
uchar data_byte;
uchar RH,RL,TH,TL;
/**************延时模块***************/
void delay(uchar ms)
{ // 延时子程序
uchar i ;
while(ms--)
{
for(i = 0 ; i<250;i++) ;
}
}
void delay1()//延时10us
{
uchar i;
i--;
i--;
i--;
i--;
i--;
i--;
}
void longdelay(uchar s) //长延时
{
while(s--)
{
delay(60) ;
}
}
/************LCD模块************/
BOOL lcd_bz()//测试LCD忙碌状态
{
BOOL result ;
rs = 0 ;
rw = 1 ;
ep = 1 ;
result = (BOOL)(P1 & 0x80) ;
ep = 0 ;
return result ;
}
void write_cmd(uchar cmd)// 写指令
{
while(lcd_bz()) ;
rs = 0 ;
rw =0 ;
ep = 0 ;
P1 = cmd ;
ep = 1 ;
ep = 0 ;
}
void write_addr(uchar addr)//写地址
{
write_cmd(addr|0x80) ;
}
void write_byte(uchar dat)//写字节
{
while(lcd_bz()) ;
rs = 1 ;
rw = 0 ;
ep = 0 ;
P1 = dat ;
ep = 1 ;
ep = 0 ;
}
void lcd_init()// 初始化
{
write_cmd(0x38) ;
delay(1);
write_cmd(0x08) ;
delay(1);
write_cmd(0x01) ;
delay(1);
write_cmd(0x06) ;
delay(1);
write_cmd(0x0c) ;
delay(1);
}
void display(uchar addr, uchar q)//在某一地址上显示一字节
{
delay(10) ;
write_addr(addr) ;
write_byte(q) ;
longdelay(2) ;
}
/************DHT11测试模块************/
void start()//开始信号
{
io=1;
delay1();
io=0;
delay(20);//>18ms
io=1;
delay1();//20-40us
delay1();
delay1();
delay1();
delay1();
}
uchar receive_byte()//接收一个字节
{
uchar i,temp,count;
for(i=0;i<8;i++)
{
count=2;
while((!io)&&count++)//等待50us低电平结束
temp=0;
delay1();delay1();delay1();delay1();
if(io==1)temp=1;
count=2;
while((io)&&count++);
if(count==1)break;
data_byte<<=1;
data_byte|=temp;
}
return data_byte;
}
void receive()//接收数据
{
uchar T_H,T_L,R_H,R_L,check,num_check;
uchar count;
start();//开始信号
io=1;
if(!io)//读取DHT11响应信号
{
count=2;
while((!io)&&count++);//DHT11高电平80us是否结束
count=2;
while((io)&&count++);
R_H=receive_byte();
R_L=receive_byte();
T_H=receive_byte();
T_L=receive_byte();
check=receive_byte();
io=0; //拉低延时50us
delay1();delay1();delay1();delay1();delay1();
io=1;
num_check=R_H+R_L+T_H+T_L;
if(num_check=check)
{
RH=R_H;
RL=R_L;
TH=T_H;
TL=T_L;
check=num_check;
}
}
}
/************主函数************/
void main()
{
lcd_init();
delay(10);
while(1)
{
receive();
delay(100);
display(0x00,'R') ;
display(0x01,':');
display(0x02,RH/10+0x30);
display(0x03,RH%10+0x30);
display(0x04,'%');
display(0x40,'T') ;
display(0x41,':');
display(0x42,TH/10+0x30);
display(0x43,TH%10+0x30);
display(0x44,0xdf);
display(0x45,0x43);
}
}
/************结束************/
回帖
(9)
柳寒
2013-5-4 22:31:27
亲测可用
#include
#include
//
#define uchar unsigned char
#define uint unsigned int
uchar busy; //12864判忙标志
uchar a=0;
uchar key1num=0;
uchar dis0[]={"12345678"};
uchar dis1[]={"12 45 "};
/*端口定义*/
/*定义12864液晶屏数据线------------------------------------------------------*/
***it LCM_CS = P1^0; //模式位,为0输入指令,为1输入数据
***it LCM_RW = P1^1; //读写位,为0读,为1写
***it LCM_EN = P1^2; //使能位
***it LCM_POS = P1^3;
#define Lcd_data P0 //LCM12864数据总线
***it p33= P3^7; //温度数据线,这里使用的是51单片机P37,根据个人情况修改
/*延时程序-------------------------------------------------------------------*/
//延时函数 1MS/次
void delayms(uint xms)
{
uint i,j;
for(i=xms;i>0;i--)
for(j=114;j>0;j--);
}
/*12864液晶显示屏并口驱动程序------------------------------------------------*/
//检查忙位(底层)
void chk_busy()
{
do
{
LCM_EN=0; //发送LCD是否忙查询指令
LCM_RW=1;
LCM_CS=0;
LCM_EN=1;
busy=Lcd_data; //获得数据
LCM_EN=0;
delayms(1);
} while(busy&&0x80==1); //如果忙则继续等待
}
//写指令到LCD(底层)
void write_com(uchar cmdcode)
{
LCM_CS=0;
LCM_RW=0;
LCM_EN=1;
Lcd_data=cmdcode;
delayms(5);
LCM_EN=0;
delayms(5);
}
//写数据到LCD(底层)
void write_data(uchar Dispdata)
{
chk_busy();
LCM_CS=1;
LCM_RW=0;
LCM_EN=1;
Lcd_data=Dispdata;
delayms(5);
LCM_EN=0;
delayms(5);
}
/*set position*/
void lcd_pos(uchar X,uchar Y)
{
uchar pos;
if(X==0)
{
X=0x80;
}
else if(X==1)
{
X=0x90;
}
else if(X==2)
{
X=0x88;
}
else if(X==3)
{
X=0x98;
}
pos=X+Y;
write_com(pos);//diaplay the address
}
typedef unsigned char U8; /* defined for unsigned 8-bits integer variable 无符号8位整型变量 */
typedef unsigned int U16; /* defined for unsigned 16-bits integer variable 无符号16位整型变量 */
U8 U8FLAG;
U8 U8temp;
U8 U8T_data_H,U8T_data_L,U8RH_data_H,U8RH_data_L,U8checkdata;
U8 U8T_data_H_temp,U8T_data_L_temp,U8RH_data_H_temp,U8RH_data_L_temp,U8checkdata_temp;
U8 U8comdata;
void Delay(U16 j) //100us延时
{
U8 i;
for(;j>0;j--)
{
for(i=0;i<27;i++);
}
}
void Delay_10us(void) //进入函数3us
{
U8 i; //1us
i--; //1us
i--;
i--;
i--;
i--;
i--;
}
void COM(void) //串行读一个字节数据
{
U8 i;
for(i=0;i<8;i++)
{
U8FLAG=2;
while((!p33)&&U8FLAG++);//自加254次 默认执行下面程序 50us低电平结束判断
Delay_10us();
Delay_10us();
Delay_10us();
U8temp=0; //判断数据位是0还是1 如果高电平高过预定0高电平值则数据位为 1
if(p33)U8temp=1;
U8FLAG=2;
while((p33)&&U8FLAG++); //等待0/1高电平信号结束
//超时则跳出for循环
// if(U8FLAG==1)break; //经历255us 在这里不会执行
U8comdata<<=1;
U8comdata|=U8temp;
}
}
void RH(void)
{
//主机拉低18ms
p33=0;
Delay(180);
p33=1;
//总线由上拉电阻拉高 主机延时20us
Delay_10us();
Delay_10us();
Delay_10us();
Delay_10us();
//主机设为输入 判断从机响应信号
p33=1;
//判断从机是否有低电平响应信号 如不响应则不读数据,响应则向下运行
if(!p33) //p20==0往下执行
{
U8FLAG=2;
//判断从机发出 80us 的低电平响应信号是否结束
while((!p33)&&U8FLAG++); //强制低电平信号最长为254us
U8FLAG=2;
//判断从机发出 80us 的高电平,如发出则进入数据接收状态
while((p33)&&U8FLAG++);
//数据接收状态
COM();
U8RH_data_H_temp=U8comdata;
COM();
U8RH_data_L_temp=U8comdata;
COM();
U8T_data_H_temp=U8comdata;
COM();
U8T_data_L_temp=U8comdata;
COM();
U8checkdata_temp=U8comdata;
p33=1;
//数据校验
U8temp=(U8T_data_H_temp+U8T_data_L_temp+U8RH_data_H_temp+U8RH_data_L_temp);
if(U8temp==U8checkdata_temp)
{
U8RH_data_H=U8RH_data_H_temp;
U8RH_data_L=U8RH_data_L_temp; //低八位为0
U8T_data_H=U8T_data_H_temp;
U8T_data_L=U8T_data_L_temp; //低八位为0
U8checkdata=U8checkdata_temp;
}
}
}
//初始化LCD屏(被调用层)
void lcd_init()
{
LCM_POS=1; //bingkoufangshi
write_com(0x30); //选择8bit数据流
delayms(5);
write_com(0x0c); //开显示(无游标、不反白)
delayms(5);
write_com(0x01); //清除显示,并且设定地址指针为00H
delayms(5);
}
void main()
{
uchar i;
lcd_init(); //initiate the LCD
i=0;
/* while(1)
{
getDHT11();
chuli();
fenjie();
lcd_pos(0,0);
for(i=0;i<8;i++)
{
write_data(dis1[i]);
}
}*/
Delay(20000);
while(1)
{
RH(); //调用温湿度读取子程序
// display2(U8RH_data_H/10%10,U8RH_data_H%10,U8T_data_H/10%10,U8T_data_H%10);
lcd_pos(0,0);
for(i=0;i<8;i++)
{
write_data(dis0[i]);
}
dis1[0]=U8RH_data_H/10%10+0x30;
dis1[1]=U8RH_data_H%10+0x30;
dis1[3]=U8T_data_H/10%10+0x30;
dis1[4]=U8T_data_H%10+0x30;
lcd_pos(1,0);
for(i=0;i<8;i++)
{
write_data(dis1[i]);
}
}
}
亲测可用
#include
#include
//
#define uchar unsigned char
#define uint unsigned int
uchar busy; //12864判忙标志
uchar a=0;
uchar key1num=0;
uchar dis0[]={"12345678"};
uchar dis1[]={"12 45 "};
/*端口定义*/
/*定义12864液晶屏数据线------------------------------------------------------*/
***it LCM_CS = P1^0; //模式位,为0输入指令,为1输入数据
***it LCM_RW = P1^1; //读写位,为0读,为1写
***it LCM_EN = P1^2; //使能位
***it LCM_POS = P1^3;
#define Lcd_data P0 //LCM12864数据总线
***it p33= P3^7; //温度数据线,这里使用的是51单片机P37,根据个人情况修改
/*延时程序-------------------------------------------------------------------*/
//延时函数 1MS/次
void delayms(uint xms)
{
uint i,j;
for(i=xms;i>0;i--)
for(j=114;j>0;j--);
}
/*12864液晶显示屏并口驱动程序------------------------------------------------*/
//检查忙位(底层)
void chk_busy()
{
do
{
LCM_EN=0; //发送LCD是否忙查询指令
LCM_RW=1;
LCM_CS=0;
LCM_EN=1;
busy=Lcd_data; //获得数据
LCM_EN=0;
delayms(1);
} while(busy&&0x80==1); //如果忙则继续等待
}
//写指令到LCD(底层)
void write_com(uchar cmdcode)
{
LCM_CS=0;
LCM_RW=0;
LCM_EN=1;
Lcd_data=cmdcode;
delayms(5);
LCM_EN=0;
delayms(5);
}
//写数据到LCD(底层)
void write_data(uchar Dispdata)
{
chk_busy();
LCM_CS=1;
LCM_RW=0;
LCM_EN=1;
Lcd_data=Dispdata;
delayms(5);
LCM_EN=0;
delayms(5);
}
/*set position*/
void lcd_pos(uchar X,uchar Y)
{
uchar pos;
if(X==0)
{
X=0x80;
}
else if(X==1)
{
X=0x90;
}
else if(X==2)
{
X=0x88;
}
else if(X==3)
{
X=0x98;
}
pos=X+Y;
write_com(pos);//diaplay the address
}
typedef unsigned char U8; /* defined for unsigned 8-bits integer variable 无符号8位整型变量 */
typedef unsigned int U16; /* defined for unsigned 16-bits integer variable 无符号16位整型变量 */
U8 U8FLAG;
U8 U8temp;
U8 U8T_data_H,U8T_data_L,U8RH_data_H,U8RH_data_L,U8checkdata;
U8 U8T_data_H_temp,U8T_data_L_temp,U8RH_data_H_temp,U8RH_data_L_temp,U8checkdata_temp;
U8 U8comdata;
void Delay(U16 j) //100us延时
{
U8 i;
for(;j>0;j--)
{
for(i=0;i<27;i++);
}
}
void Delay_10us(void) //进入函数3us
{
U8 i; //1us
i--; //1us
i--;
i--;
i--;
i--;
i--;
}
void COM(void) //串行读一个字节数据
{
U8 i;
for(i=0;i<8;i++)
{
U8FLAG=2;
while((!p33)&&U8FLAG++);//自加254次 默认执行下面程序 50us低电平结束判断
Delay_10us();
Delay_10us();
Delay_10us();
U8temp=0; //判断数据位是0还是1 如果高电平高过预定0高电平值则数据位为 1
if(p33)U8temp=1;
U8FLAG=2;
while((p33)&&U8FLAG++); //等待0/1高电平信号结束
//超时则跳出for循环
// if(U8FLAG==1)break; //经历255us 在这里不会执行
U8comdata<<=1;
U8comdata|=U8temp;
}
}
void RH(void)
{
//主机拉低18ms
p33=0;
Delay(180);
p33=1;
//总线由上拉电阻拉高 主机延时20us
Delay_10us();
Delay_10us();
Delay_10us();
Delay_10us();
//主机设为输入 判断从机响应信号
p33=1;
//判断从机是否有低电平响应信号 如不响应则不读数据,响应则向下运行
if(!p33) //p20==0往下执行
{
U8FLAG=2;
//判断从机发出 80us 的低电平响应信号是否结束
while((!p33)&&U8FLAG++); //强制低电平信号最长为254us
U8FLAG=2;
//判断从机发出 80us 的高电平,如发出则进入数据接收状态
while((p33)&&U8FLAG++);
//数据接收状态
COM();
U8RH_data_H_temp=U8comdata;
COM();
U8RH_data_L_temp=U8comdata;
COM();
U8T_data_H_temp=U8comdata;
COM();
U8T_data_L_temp=U8comdata;
COM();
U8checkdata_temp=U8comdata;
p33=1;
//数据校验
U8temp=(U8T_data_H_temp+U8T_data_L_temp+U8RH_data_H_temp+U8RH_data_L_temp);
if(U8temp==U8checkdata_temp)
{
U8RH_data_H=U8RH_data_H_temp;
U8RH_data_L=U8RH_data_L_temp; //低八位为0
U8T_data_H=U8T_data_H_temp;
U8T_data_L=U8T_data_L_temp; //低八位为0
U8checkdata=U8checkdata_temp;
}
}
}
//初始化LCD屏(被调用层)
void lcd_init()
{
LCM_POS=1; //bingkoufangshi
write_com(0x30); //选择8bit数据流
delayms(5);
write_com(0x0c); //开显示(无游标、不反白)
delayms(5);
write_com(0x01); //清除显示,并且设定地址指针为00H
delayms(5);
}
void main()
{
uchar i;
lcd_init(); //initiate the LCD
i=0;
/* while(1)
{
getDHT11();
chuli();
fenjie();
lcd_pos(0,0);
for(i=0;i<8;i++)
{
write_data(dis1[i]);
}
}*/
Delay(20000);
while(1)
{
RH(); //调用温湿度读取子程序
// display2(U8RH_data_H/10%10,U8RH_data_H%10,U8T_data_H/10%10,U8T_data_H%10);
lcd_pos(0,0);
for(i=0;i<8;i++)
{
write_data(dis0[i]);
}
dis1[0]=U8RH_data_H/10%10+0x30;
dis1[1]=U8RH_data_H%10+0x30;
dis1[3]=U8T_data_H/10%10+0x30;
dis1[4]=U8T_data_H%10+0x30;
lcd_pos(1,0);
for(i=0;i<8;i++)
{
write_data(dis1[i]);
}
}
}
举报
luojun358
2013-5-4 22:37:40
引用:
1192121586 发表于 2013-5-4 22:31
亲测可用
如果是lcd1602屏,你那个程序能不能用的啊?不行的话要怎么改动啊?
引用:
1192121586 发表于 2013-5-4 22:31
亲测可用
如果是lcd1602屏,你那个程序能不能用的啊?不行的话要怎么改动啊?
举报
柳寒
2013-5-11 13:31:42
只需要改相应的显示函数部分 其他都一样
只需要改相应的显示函数部分 其他都一样
举报
李富彬
2013-8-9 13:02:21
我试一试看、、、、、、、、、、、、
我试一试看、、、、、、、、、、、、
举报
302352381
2014-3-6 15:02:03
可以呀,如果你把对应的IO口改对就可以显示了,看的时候注意下背光
可以呀,如果你把对应的IO口改对就可以显示了,看的时候注意下背光
举报
cygd
2014-3-6 15:46:28
{:1:}
{:1:}
举报
zhangzheyu55555
2014-3-18 15:58:42
不能正常变化啊、!
不能正常变化啊、!
举报
蓝林晶
2016-6-2 15:48:09
这个测量温湿度的程序是对的吗
这个测量温湿度的程序是对的吗
举报
电子g
2017-11-11 17:55:53
1602能显示嘛
1602能显示嘛
举报
更多回帖
rotate(-90deg);
回复
相关帖子
温度检测
基于
DHT11
的温
湿度
检测
0
基于51
单片机
+
DHT11
温
湿度
+LCD1602
显示
121
【
单片机
】
DHT11
模块温
湿度
检测
19
使用51
单片机
实现
DHT11
温
湿度
检测
的代码程序免费下载
138
基于51
单片机
的
DHT11
温
湿度
灰尘煤气
检测
1602液晶
显示
设计
3
如何使用Blynk从
DHT11
读取
温度
和
湿度
0
DHT11
温
湿度
显示
问题
3385
基于
单片机
的
DHT11
温
湿度
传感器设计
0
DHT11
温
湿度
+OLED
显示
54
【STM32
单片机
-库函数】
DHT11
模块
14
发帖
登录/注册
20万+
工程师都在用,
免费
PCB检查工具
无需安装、支持浏览器和手机在线查看、实时共享
查看
点击登录
登录更多精彩功能!
首页
论坛版块
小组
免费开发板试用
ebook
直播
搜索
登录
×
20
完善资料,
赚取积分