基于51单片机的智能鞋柜衣柜消毒柜

资料编号:141 

视频讲解:

141-基于51单片机智能鞋柜消毒柜(源程序+原理图+PCB+全套毕设资料)

本设计以51单片机为控制核心,设计并制作智能鞋柜,可实现杀菌消毒、除湿加热、
手动/自动的功能。
功能要求
1、能自动定时启动杀菌消毒功能.或手动控制杀菌消毒
2、能自动和手动开启除湿加热功能

3、具备显示功能

全套资料齐全:

 下面是DHT11传感器的读取函数:

#include"reg52.h"
#include"DHT11.h"
#include"delay.h"
#include <intrins.h>
// 请根据自己的 dht11接的 IO口来改动位定义 
sbit  DHT11_DQ=P3^7;

bit status;      //状态标志位

void delay_10us(unsigned int nus) 
{
    unsigned char i;

    i = 2*nus;
    while (--i);
}
//void delay_ms(unsigned int nms)        
//{
//    unsigned int i ,j;
//    for(i=nms;i>0;i--)              //nms即延时约n毫秒 
//    {    for(j=110;j>0;j--);    }
//}
/************************************************************************
* 函数: void DHT11_Rst(void)
* 描述: 复位DHT11
* 参数: none.
* 返回: none.
* 日期: 2017-07-02
* 备注: 
************************************************************************/
void DHT11_Rst(void)    //复位DHT11
{
    DHT11_DQ=0;          //拉低DQ
    delay_ms(20);        //拉低至少18ms
    DHT11_DQ=1;          //拉高DQ
    delay_10us(4);     //延时20-40us,等待一段时间后检测应答信号, 应答信号是从机拉低数据线80us     
}
/************************************************************************
* 函数: bit DHT11_Check(void)
* 描述: 等待DHT11的回应
* 参数: none.
* 返回: 1:未检测到DHT11的存在
        0:存在
* 日期: 2017-07-02
* 备注: 
************************************************************************/
bit DHT11_Check(void)     //等待DHT11的回应
{
    unsigned char retry=0;

    while(DHT11_DQ&&retry<100)   //等DHT11会拉低40~50us作为相应时间
    {
        retry++;
        delay_10us(1);
    };
    if(retry>=100)return 1;      //若为相应则失败输出1
    else retry=0;                //反之清零等待再次相应高
    while(!DHT11_DQ&&retry<100)  //DHT11拉低后会再次拉高40~80us
    {
        retry++;
        delay_10us(1);
    };
    if(retry>=100)return 1;
         return 0;
    
}
/************************************************************************
* 函数: bit DHT11_Init(void)
* 描述: DHT11初始化
* 参数: none.
* 返回: 1:未检测到DHT11的存在
        0:存在
************************************************************************/
bit DHT11_Init(void)     //DHT11初始化
{
    DHT11_Rst() ;           //复位DHT11
    return DHT11_Check();
}

/************************************************************************
* 函数: static unsigned char DHT11_Read_Byte(void)
* 描述: 从DHT11读取一个字节
* 参数: none.
* 返回: dat : 读到的数据
* 日期: 2017-07-02
* 备注: 
************************************************************************/
static unsigned char DHT11_Read_Byte(void)

    unsigned char retry, dat = 0, i; 
    status = OK;     //设定标志为正常状态 
    for(i = 8; i > 0; i--) 
    { 
        //高位在先 
        dat <<= 1; 
        retry = 0; 
        //每一位数据前会有一个 50us 的低电平时间. 等待50us 低电平结束 
        while(DHT11_DQ == 0 && retry++ < NUMBER); 
        if(retry >= NUMBER) 
        { 
            status = ERROR;   //设定错误标志 
            return 0;          //函数执行过程发生错误就退出函数 
        } 
        //26-28us的高电平表示该位是 0, 为70us 高电平表该位 1 
        delay_10us(2);
        //延时30us 后检测数据线是否还是高电平 
        if(DHT11_DQ != 0) 
        { 
            //进入这里表示该位是 1 
            dat++; 
            //等待剩余(约40us)的高电平结束 
            while(DHT11_DQ != 0 && retry++ < NUMBER) 
            { 
                DHT11_DQ = 1; 
            } 
            if(retry >= NUMBER) 
            { 
                status = ERROR;   //设定错误标志 
                return 0; 
            }  
        } 
    }  
    return (dat);
}  
/************************************************************************
* 函数: bit DHT11_Read_Date(unsigned char *temp,unsigned char *humi)
* 描述: 从DHT11读取温湿度
* 参数: *temp : 温度
        *humi : 湿度
* 返回: 0 OK : 正常;
        1 ERROR : 读取失败
************************************************************************/
bit DHT11_Read_Date(unsigned char *temp,unsigned char *humi)  //读取温湿度
{  
    unsigned char i = 0,retry = 0; 
    unsigned char buf[SIZE]; 
    DHT11_DQ = 0;       //拉低数据线大于 18ms发送开始信号 
    delay_ms(30);       // 需大于 18 毫秒 
    DHT11_DQ = 1;       //释放数据线, 用于检测低电平的应答信号 
    //延时20-40us,等待一段时间后检测应答信号, 应答信号是从机拉低数据线80us 
    delay_10us(3);
    if(DHT11_DQ != 0)    // 检测应答信号, 应答信号是低电平 
    { 
        //没应答信号  
        return ERROR; 
    } 
    else 
    { 
        //有应答信号 
        while(DHT11_DQ == 0 && retry++ < NUMBER);      // 等待应答信号结束 
        if(retry >= NUMBER)  //检测计数器是否超过了设定的范围 
        { 
            DHT11_DQ = 1; 
            return ERROR;   //读数据出错, 退出函数 
        } 
        retry = 0; 
        DHT11_DQ = 1;        //释放数据线  
        //应答信号后会有一个 80us 的高电平,等待高电平结束  
        while(DHT11_DQ != 0 && retry++ < NUMBER); 
        if(retry >= NUMBER) 
        { 
            DHT11_DQ = 1; 
            return ERROR;  //退出函数 
        } 
    
        //读出湿. 温度值   
        for(i = 0; i < SIZE; i++)    //读取40位数据
        { 
            buf[i] = DHT11_Read_Byte(); 
            if(status == ERROR)        //调用 DHT11_Read_Byte() 读数据出错会设定status 为ERROR 
            { 
                DHT11_DQ = 1;    
                return ERROR;  
            }  
        } 
        if((buf[0]+buf[1]+buf[2]+buf[3])==buf[4])  //校验正确
        {
            *humi = buf[0]; 
            *temp = buf[2]; 
            DHT11_DQ = 1; 
            return OK;                               //正确的读出 dht11输出的数据   
        } 
        else                 //校验数据出错  
        { 
            
            return ERROR; 
        } 
    }         
}

单片机最小系统介绍
单片机(Microcontrollers)是一种集成电路芯片,是采用超大规模集成电路技术把具有数据处理能力的中央处理器CPU、随机存储器RAM、只读存储器ROM、多种I/O口和中断系统、定时器/计数器等功能(可能还包括显示驱动电路、脉宽调制电路、模拟多路转换器、A/D转换器等电路)集成到一块硅片上构成的一个小而完善的微型计算机系统,在工业控制领域广泛应用。从上世纪80年代,由当时的4位、8位单片机,发展到现在的300M的高速单片机。本文的单片机特指51单片机,具体芯片型号是 AT89C52。需注意STC89C51,STC89C52,AT89C51,AT89C52都是51单片机的一种具体芯片型号。

最小系统组成:

51单片机最小系统:单片机、复位电路、晶振(时钟)电路、电源

最小系统用到的引脚

1、主电源引脚(2根)

VCC:电源输入,接+5V电源

GND:接地线

2、外接晶振引脚(2根)

XTAL1:片内振荡电路的输入端

XTAL2:片内振荡电路的输出端

3、控制引脚(4根)

RST/VPP:复位引脚,引脚上

复位电路
一般来说,在电路图中,电容的的大小是10uf,电阻的大小是10k。(不特指本电路,具体参数看仿真图)

在5V正常工作的51单片机中小于1.5V的电压信号为低电平信号,而大于1.5V的电压信号为高电平信号。可以算出电容充电到电源电压的0.7倍,即电容两端电压为3.5V、电阻两端电压为1.5V时,需要的时间约为T=RC=10K*10UF=0.1S。

也就是说在单片机上电启动的0.1S内,电容两端的电压从0-3.5V不断增加,这个时候10K电阻两端的电压为从5-1.5V不断减少(串联电路各处电压之和为总电压),所以RST引脚所接收到的电压是5V-1.5V的过程,也就是高电平到低电平的过程。

单片机RST引脚是高电平有效,即复位;低电平无效,即单片机正常工作。所以在开机0.1S内,单片机系统RST引脚接收到了时间为0.1S左右的高电平信号,所以实现了自动复位。

在单片机启动0.1S后,电容C两端的电压持续充电为5V,这是时候10K电阻两端的电压接近于0V,RST处于低电平所以系统正常工作。当按键按下的时候,开关导通,这个时候电容两端形成了一个回路,电容被短路,所以在按键按下的这个过程中,电容开始释放之前充的电量。随着时间的推移,电容的电压在0.1S内,从5V释放到变为了1.5V,甚至更小。根据串联电路电压为各处之和,这个时候10K电阻两端的电压为3.5V,甚至更大,所以RST引脚又接收到高电平。单片机系统自动复位。

资料下载链接https://pan.baidu.com/s/1D8o6vrTtrJ4lf54-OedRlw?pwd=ijop

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

电子工程DIY工作室

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值