基于51单片机的空气质量检测(PM2.5粉尘检测+温湿度检测)


前言

本设计采用由STC89C52单片机最小系统、粉尘传感器、ADC0832模数转换器模块、、DHT11温湿度传感器、LCD1602液晶模块、电源模块、蜂鸣器报警模块和按键模块模块组成。单片机实时通过ADC0832转换芯片采集粉尘传感器的粉尘的浓度,通过单片机的数据转换处理后在液晶屏上显示空气中的质量,通过DHT11温湿度传感器检测空气中的温湿度,蜂鸣器和发光二极管发出声光报警,PM2.5和温湿度报警值可通过按键设置。


一、系统功能

1.系统整体框图

系统框图

2.系统流程图

流程图

二、硬件构成

系统硬件主要由STC89C52单片机最小系统、PM2.5粉尘传感器、DHT11温湿度传感器、ADC0832模数转换器模块、LCD1602液晶模块、电源模块、蜂鸣器报警模块和按键模块模块组成。原理图如图所示:
原理图

三、仿真

在这里插入图片描述
仿真目前主要只涉及PM2.5粉尘检测,DHT11温湿度检测如有需要,可私信定制增加

四、代码

部分程序代码如下文所示,主要为AD转换部分,可移值参考:

#include"delay.h"  		  //添加延时函数头文件
#include<intrins.h>
sbit CS   = P1^2;
sbit Clk  = P1^1;
sbit DATI = P1^0;
sbit DATO = P1^0;
/****************************************************************************
函数功能:AD转换子程序
入口参数:CH
出口参数:dat
****************************************************************************/
unsigned char adc0832(unsigned char CH)
{
	unsigned char dat = 0x00;      //AD值
    unsigned char i,test,adval;
    adval = 0x00;
    test = 0x00;
    Clk = 0;       //初始化
    DATI = 1;
    _nop_();
    CS = 0;
    _nop_();
    Clk = 1;
   _nop_();
	if ( CH == 0x00 )      //通道选择
   	{
    	Clk = 0;
       	DATI = 1;      //通道0的第一位
       	_nop_();
      	Clk = 1;
        _nop_();
        Clk = 0;
      	DATI = 0;      //通道0的第二位
      	_nop_();
      	Clk = 1;
      _nop_();
    } 	
    else
    {
       Clk = 0;
      	DATI = 1;      //通道1的第一位
       _nop_();
       Clk = 1;
       _nop_();
      	Clk = 0;
      	DATI = 1;      //通道1的第二位
    	_nop_();
     	Clk = 1;
     	_nop_();
    }
    Clk = 0;
    DATI = 1;
    for( i = 0;i < 8;i++ )      //读取前8位的值
    {
      	_nop_();
       	adval <<= 1;
       	Clk = 1;
       	_nop_();
       	Clk = 0;
       	if (DATO)
          	adval |= 0x01;
      	else
          	adval |= 0x00;
    }
    for (i = 0; i < 8; i++)      //读取后8位的值
    {
        test >>= 1;
        if (DATO)
           	test |= 0x80;
        else 
            test |= 0x00;
        _nop_();
        Clk = 1;
       	_nop_();
        Clk = 0;
     }
     if (adval == test)      //比较前8位与后8位的值,如果不相同舍去。若一直出现显示为零,请将该行去掉
          dat = test;
      _nop_();
      CS = 1;        //释放ADC0832
      DATO = 1;
      Clk = 1;
      return dat;
}
sbit vled  = P1^7;

void Delay1us(uint t)		//@12MHz
{
	while(t--)_nop_();
}
uint read_data(uchar N)
{
	uint val=0;
	vled=0;
	Delay1us(20);
	val=adc0832(N);
	vled=1;
	Delay1us(400);	
	return val;
}


五、资料下载

资料截图及下载:
在这里插入图片描述

  • 11
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值