已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也
下个程序是DHT11的湿度读取,LCD1602显示程序,DHT11的官方版读取温度湿度的程序,我给改成LCD1602显示,加上了注释。。。DHT11的官方版程序写的太乱了,将就着点。
#include <reg51.h>
#include <intrins.h>
#include<stdio.h>
#define uchar unsigned char                        
#define uint unsigned int  
typedef unsigned char  U8;       /* defined for unsigned 8-bits integer variable       无符号8位整型变量  */
typedef signed   char  S8;       /* defined for signed 8-bits integer variable          有符号8位整型变量  */
typedef unsigned int   U16;      /* defined for unsigned 16-bits integer variable       无符号16位整型变量 */
typedef signed   int   S16;      /* defined for signed 16-bits integer variable       有符号16位整型变量 */
typedef unsigned long  U32;      /* defined for unsigned 32-bits integer variable       无符号32位整型变量 */
typedef signed   long  S32;      /* defined for signed 32-bits integer variable       有符号32位整型变量 */
typedef float          F32;      /* single precision floating point variable (32bits) 单精度浮点数(32位长度) */
typedef double         F64;      /* double precision floating point variable (64bits) 双精度浮点数(64位长度) */
#define uint unsigned int
sbit lcdrs=P1^0;
sbit lcdrw=P1^1;
sbit lcden=P1^2;
uchar code tab[]="0123456789";        //利用表解决温度显示乱码
void disdelay(U8 i);


void displayt(uint temph ,uint templ);
void displayr(uint rh ,uint rl);

//----------------------------------------------//
//----------------IO口定义区--------------------//
//----------------------------------------------//
sbit  P2_0=P0^3 ;  //DHT11的数据脚


void disdelay(U8 i)  //延时代码
{
unsigned int j;
for(i=0;i<8;i++)
    {for(j=0;j<50;j++);
    }
}
//----------------------------------------------//
//----------------定义区--------------------//
//----------------------------------------------//
U8  U8FLAG,k;
U8  U8count,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;
U8  x;
U8  count, count_r=0;
U16 U16temp1,U16temp2;
void Delay(U16 j)
    {      U8 i;
        for(;j>0;j--)
      {    
        for(i=0;i<27;i++);

      }
    }
       void  Delay_10us(void)
      {
        U8 i;
        i--;
        i--;
        i--;
        i--;
        i--;
        i--;
       }
    
void  COM(void)
  {
    
     U8 i;
   for(i=0;i<8;i++)      
     {
        U8FLAG=2;
     while((!P2_0)&&U8FLAG++);
        Delay_10us();
        Delay_10us();
        Delay_10us();
              U8temp=0;
         if(P2_0)U8temp=1;
            U8FLAG=2;
         while((P2_0)&&U8FLAG++);
            

           //超时则跳出for循环          
            if(U8FLAG==1)break;
           //判断数据位是0还是1    
              
        // 如果高电平高过预定0高电平值则数据位为 1
            
           U8comdata<<=1;
              U8comdata|=U8temp;        //0
         }//rof
      
    }

    //--------------------------------
    //-----湿度读取子程序 ------------
    //--------------------------------
    //----以下变量均为全局变量--------
    //----温度高8位== U8T_data_H------
    //----温度低8位== U8T_data_L------
    //----湿度高8位== U8RH_data_H-----
    //----湿度低8位== U8RH_data_L-----
    //----校验 8位 == U8checkdata-----
    //----调用相关子程序如下----------
    //---- Delay();, Delay_10us();,COM();
    //--------------------------------

void RH(void)
{
      //主机拉低18ms
       P2_0=0;
       Delay(180);
       P2_0=1;
     //总线由上拉电阻拉高 主机延时20us
       Delay_10us();
       Delay_10us();
       Delay_10us();
       Delay_10us();
     //主机设为输入 判断从机响应信号
       P2_0=1;
     //判断从机是否有低电平响应信号 如不响应则跳出,响应则向下运行      
       if(!P2_0)         //T !      
       {
       U8FLAG=2;
     //判断从机是否发出 80us 的低电平响应信号是否结束    
       while((!P2_0)&&U8FLAG++);
       U8FLAG=2;
     //判断从机是否发出 80us 的高电平,如发出则进入数据接收状态
       while((P2_0)&&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;
       P2_0=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;
          U8T_data_H=U8T_data_H_temp;
             U8T_data_L=U8T_data_L_temp;
             U8checkdata=U8checkdata_temp;
       }    
       }

    }


//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@//
//###############液晶显示模块######################//
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@//
void delay1(uchar z)
{
    uchar x,y;
    for(x=1000;x>1;x--)
        for(y=z;y>1;y--);
}

void write_com(uchar com)
{
    lcdrs=0;
    P2=com;    
    delay1(5);
    lcden=1;
    delay1(5);
    lcden=0;
}
void write_date(uchar date)
{
    lcdrs=1;
    P2=date;
    delay1(5);
    lcden=1;
    delay1(5);
    lcden=0;
}
void init_lcd()
{
    lcden=0;
    lcdrw=0;
    write_com(0x38);
    write_com(0x01);
    write_com(0x0c);
    write_com(0x06);
    write_com(0x80);    
}
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@//
//###############液晶显示模块end###################//
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@//

//*******参数传递rh ,rL**********************************
void displayr(U8 rh ,U8 rL)
{  
   U8 sw,gw,xw1,xw2;
   sw=rh/10;//0
   gw=rh%10;
   xw1=rL/10;
   xw2=rL%10;
   write_com(0x80);
   write_date(tab[sw]);

    write_com(0x81);
    write_date(tab[gw]);
    write_com(0x82);
    write_date(0x2e);
    
    write_com(0x83);
    write_date(tab[xw1]);

    write_com(0x84);
    write_date(0x25);
  
}



void main()
{
  init_lcd();
  while(1)
  {
  RH();
  displayr( U8RH_data_H , U8RH_data_L);
  Delay(100);
  }
}
+400  科创币    warmonkey   2010-08-16   
文号 / 249286

千古风流
名片发私信
学术分 3
总主题 42 帖总回复 759 楼拥有证书:学者 笔友
注册于 2009-07-25 13:54最后登录 2023-11-27 07:24
主体类型:个人
所属领域:无
认证方式:邮箱
IP归属地:未同步

个人简介

暂未填写
文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

插入资源
全部
图片
视频
音频
附件
全部
未使用
已使用
正在上传
空空如也~
上传中..{{f.progress}}%
处理中..
上传失败,点击重试
等待中...
{{f.name}}
空空如也~
(视频){{r.oname}}
{{selectedResourcesId.indexOf(r.rid) + 1}}
处理中..
处理失败
插入表情
我的表情
共享表情
Emoji
上传
注意事项
最大尺寸100px,超过会被压缩。为保证效果,建议上传前自行处理。
建议上传自己DIY的表情,严禁上传侵权内容。
点击重试等待上传{{s.progress}}%处理中...已上传,正在处理中
空空如也~
处理中...
处理失败
加载中...
草稿箱
加载中...
此处只插入正文,如果要使用草稿中的其余内容,请点击继续创作。
{{fromNow(d.toc)}}
{{getDraftInfo(d)}}
标题:{{d.t}}
内容:{{d.c}}
继续创作
删除插入插入
插入公式
评论控制
加载中...
文号:{{pid}}
加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}
ID: {{user.uid}}