基于51单片机的报警器(燃气,温度,2模拟)原理图、流程图、物料清单、仿真图、源代码

请添加图片描述

基于51单片机的报警器(燃气,温度,2模拟)原理图、流程图、物料清单、仿真图、源代码
基于51单片机的报警器(燃气,温度,2模拟)

燃气报警系统
1、检测温度、甲醛、一氧化碳(也可以改成别的名字、别的传感器)
2、按键设定报警值,测量值过限报警
3、使用LCD1602显示测量值和报警参数请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

#include "reg51.h"
#include "ADC0832.h"
#include "Ds18b20.h"
#include "lcd1602.h"
#define uchar unsigned char
#define uint unsigned int
sbit beep=P3^4;//蜂鸣器
sbit k1=P2^3;//按钮
sbit k2=P2^4;
sbit k3=P2^5;
sbit k4=P2^6;
sbit k5=P2^7;
sbit led1=P3^5;
sbit led2=P3^6;
sbit led3=P3^7;

uchar time=0,sec=0;//系统定时
uchar co=0;//一氧化碳
uchar hcho=0;//甲醛
uchar down=10;//温度下限
uchar up[]={40,20,15};//上限
uchar disp1[]="00 ";
uchar disp2[]="00% ";
uchar mode=0;//模式
//主函数
void main()
{
	disp1[2]=0xdf;
	init_1602();	
	TMOD|=0X01;
	TH0=0X3C;
	TL0=0XB0;	
	ET0=1;//打开定时器0中断允许
	EA=1;//打开总中断
	TR0=1;//打开定时器
	while(1)
	{
		if(!k1)		 //设置
		{
			if(mode<3)
				mode++;
			else
				mode=0;
			write_string(1,0,"                ");
			write_string(2,0,"                ");
			while(!k1);
		} 
		if(mode>0)//上下限设置
		{
			if(!k2)
			{
				if(up[mode-1]<99)
					up[mode-1]++;
				while(!k2);
			}
			if(!k3)
			{
				if(up[mode-1]>0)
					up[mode-1]--;
				while(!k3);
			}
			if(!k4)
			{
				if(down<up[0])
					down++;
				while(!k4);
			}
			if(!k5)
			{
				if(down>0)
					down--;
				while(!k5);
			}
		}
		//判断
		if(co>up[2])//一氧化碳
			led3=0;
		else
			led3=1;
		if(hcho>up[1])//甲醛
			led2=0;
		else
			led2=1;
		if((ds18b20_temp<down)||(ds18b20_temp>up[0]))//温度
			led1=0;
		else
			led1=1;
		//报警
		if(!led1 || !led2 || !led3)
			sec=10;
	}
}
//定时器中断
void Timer0() interrupt 1
{	
	uint i;
	if(sec>0)  //蜂鸣器驱动
	{
		sec--;
		beep=0;
	}
	else
		beep=1;
	if(time<19)//0.5s
		time++;
	else
	{
		time=0;
		co=ADC(2);//测量一氧化碳
		i=co;
		co=i*99/127;
		Ds18b20ReadTemp();
		hcho=ADC(1);//测量甲醛
		i=hcho;
		hcho=i*99/127;
		//显示
		if(mode==0)
		{			
			write_string(1,0,"tem: ");//温度
			i=ds18b20_temp;
			disp1[0]=i/10+0x30;
			disp1[1]=i%10+0x30;
			write_string(1,4,disp1);
			write_string(2,0,"hcho:");//甲醛
			disp2[0]=hcho/10+0x30;
			disp2[1]=hcho%10+0x30;
			write_string(2,5,disp2);
			write_string(2,9,"CO:");//一氧化碳
			disp2[0]=co/10+0x30;
			disp2[1]=co%10+0x30;
			write_string(2,12,disp2);
		}
		if(mode==3)//一氧化碳
		{
			write_string(1,0,"CO:   ");
			disp2[0]=up[2]/10+0x30;
			disp2[1]=up[2]%10+0x30;
			write_string(2,4,disp2);
		}
		if(mode==1)//温度
		{
			write_string(1,0,"temp:  ");
			write_string(2,0,"  H:");
			disp1[0]=up[0]/10+0x30;
			disp1[1]=up[0]%10+0x30;
			write_string(2,4,disp1);
			write_string(2,8,"  L:");
			disp1[0]=down/10+0x30;
			disp1[1]=down%10+0x30;
			write_string(2,12,disp1);
		}
		if(mode==2)//甲醛
		{
			write_string(1,0,"hcho:  ");
			disp2[0]=up[1]/10+0x30;
			disp2[1]=up[1]%10+0x30;
			write_string(2,4,disp2);
		}
	}
	TH0=0X3C;
	TL0=0XB0;
}
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

cqtianxingkeji

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

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

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

打赏作者

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

抵扣说明:

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

余额充值