找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 734|回复: 2
收起左侧

基于51单片机的室内空气净化系统LCD1602+MQ-135程序源码

[复制链接]
ID:1099118 发表于 2023-11-10 08:26 | 显示全部楼层 |阅读模式
  1. /*
  2. 实验说明:
  3.         根据自己使用的LCD1602是否带有转接板,如果带有转接板的即为4位,需在LCD.H头文件中
  4.         将宏#define LCD1602_4PINS打开,我们这里使用的LCD1602是8位,所以默认将该宏注释。
  5. 实验接线:
  6.         1,LCD1602液晶模块-->单片机管脚
  7.         参考LCD1602液晶显示实验接线(开发攻略内在对应的实验章节内实验现象有接线说明)
  8.         2,MQ-135传感器模块-->单片机管脚
  9.         将传感器模块对应插入到开发板上的接口处,然后使用杜邦线将MQ135模块的P6端子上AO脚与开发板上
  10.         DAC模块边上的J52端子的AIN3脚连接
  11.         3,ADC模块-->单片机管脚
  12.         参考ADC模数转换实验接线(开发攻略内在对应的实验章节内实验现象有接线说明)
  13.         4,独立按键模块-->单片机管脚
  14.         K1-->P33
  15.         K2-->P21
  16.         K3-->P22
  17.         5,蜂鸣器模块-->单片机管脚
  18.         BEEP-->P15
  19.         6,直流电机模块-->单片机管脚
  20.         参考直流电机实验接线(开发攻略内在对应的实验章节内实验现象有接线说明)
  21.         
  22. 实验现象:
  23.         通过按键K1可对气体浓度阀值进行设定
  24.         按下一次K1,进入上限设定,再按下K1一次,退出设定模式,进入正常气体浓度采集状态。
  25.         进入阀值设定模式后,通过K2和K3进行数值加减。当采集的气体浓度高于设定上限值,蜂鸣器报警且
  26.         电机旋转排气,当采集的气体浓度低于设定上限值,蜂鸣器和电机不工作,处于正常工作状态。
  27. */

  28. #include<reg51.h>
  29. #include "XPT2046.h"
  30. #include"lcd.h"

  31. typedef unsigned char uint8;
  32. typedef unsigned int uint16;


  33. sbit k1=P3^3; //模式
  34. sbit k2=P2^1; //加
  35. sbit k3=P2^2; //减

  36. sbit moto=P1^0;
  37. sbit beep=P1^5;


  38. uint8 mode=0;
  39. char temph=20;
  40. uint8 temp,flag;

  41. uint8 code num[10]="0123456789";

  42. uint8 code str1[]="GAS:";  
  43. uint8 code str2[]="SET:";



  44. void delay(uint16 i)
  45. {
  46.         while(i--);
  47. }

  48. void wrc(uint8 c)         //写命令
  49. {
  50.         LcdWriteCom(c);
  51. }
  52. void wrd(uint8 dat)          //写数据
  53. {
  54.         LcdWriteData(dat);
  55. }
  56. void lcd_init()           // LCD1602初始化
  57. {
  58.         LcdInit();
  59. }

  60. void key_pros()  //按键处理函数
  61. {
  62.         if(k1==0)
  63.         {
  64.                 delay(1000);
  65.                 if(k1==0)
  66.                 {
  67.                         mode++;
  68.                         flag=0;
  69.                         if(mode==2)
  70.                         {
  71.                                 mode=0;
  72.                                 flag=1;        
  73.                         }
  74.                         
  75.                 }
  76.                 while(!k1);
  77.         }
  78.         if(mode==1)                  //对空气检测报警值设定
  79.         {
  80.                 if(k2==0)                  //加
  81.                 {
  82.                         delay(1000);
  83.                         if(k2==0)
  84.                         {
  85.                                 temph+=1;
  86.                                 if(temph>=100)temph=100;
  87.                         }
  88.                         while(!k2);
  89.                 }
  90.                 if(k3==0)           //减
  91.                 {
  92.                         delay(1000);
  93.                         if(k3==0)
  94.                         {
  95.                                 temph-=1;
  96.                                 if(temph<=0)temph=0;        
  97.                         }
  98.                         while(!k3);
  99.                 }
  100.         }
  101.         
  102. }

  103. void lcd_init_display()           //LCD初始化显示
  104. {
  105.         uint8 i;
  106.         for(i=0;i<4;i++)
  107.         {
  108.                 wrc(0x80+i);
  109.                 wrd(str1[i]);        
  110.         }

  111.         for(i=0;i<4;i++)
  112.         {
  113.                 wrc(0xc0+i);
  114.                 wrd(str2[i]);        
  115.         }
  116. }

  117. void data_pros()        //数据处理函数
  118. {
  119.         uint8 tempbuf[3],temp_buf[3],i;
  120.         tempbuf[0]=temp/100+0x30;
  121.         tempbuf[1]=temp%100/10+0x30;                                
  122.         tempbuf[2]=temp%100%10+0x30;
  123.         
  124.         temp_buf[0]=temph/100+0x30;
  125.         temp_buf[1]=temph%100/10+0x30;                                
  126.         temp_buf[2]=temph%100%10+0x30;

  127.         for(i=0;i<3;i++)
  128.         {
  129.                 wrc(0x84+i);
  130.                 wrd(tempbuf[i]);
  131.         }

  132.         for(i=0;i<3;i++)
  133.         {
  134.                 wrc(0xc4+i);
  135.                 wrd(temp_buf[i]);
  136.         }
  137. }

  138. void sound()
  139. {
  140.         uint8 i=100;
  141.         while(i--)
  142.         {
  143.                 beep=~beep;
  144.                 delay(100);        
  145.         }
  146. }
  147. void baojinpros()        //报警处理
  148. {
  149.         if(temp>=temph&&flag==1)
  150.         {
  151.                 moto=1;
  152.                 sound();
  153.         }
  154.         else
  155.         {        
  156.                 moto=0;
  157.                 beep=1;
  158.         }
  159. }

  160. void main()
  161. {
  162.         moto=1;
  163.         beep=1;
  164.         lcd_init();
  165.         lcd_init_display();           //LCD初始化显示
  166.         while(1)
  167.         {        
  168.                 key_pros();
  169.                 data_pros();
  170.                 baojinpros();
  171.                 temp = Read_AD_Data(0x94)/40;                        
  172.         }        
  173. }
复制代码

原理图: 无
仿真: 无
代码: 基于单片机的室内空气净化系统.7z (19.27 KB, 下载次数: 28)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:262 发表于 2023-11-15 22:44 | 显示全部楼层
好资料,51黑有你更精彩!!!
回复

使用道具 举报

ID:1105130 发表于 2023-12-19 13:33 | 显示全部楼层
精彩实在是很厉害
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表