基于51单片机的液位监测系统仿真数码管显示程序原理图

附:http://www.jh-tec.cn/archives/7135

硬件设计

由数码管作为显示器,ADC芯片采用ADC0808,滑动变阻器模拟液位,具有声光报警,四个按键用于设置阈值;
在这里插入图片描述
阈值高值:
在这里插入图片描述
阈值低值:
在这里插入图片描述

程序设计:

#include <reg52.h>
#include<intrins.h>         //调用_nop_();延时函数用		   4ns
#define uint unsigned int
#define uchar unsigned char
#define def P3 //0809数据端口
#define suji P0//数码管数据端口 
#define l 17   //宏定义
#define h 18
sbit k1=P1^0;  //四个按键定义中的,模式切换
sbit k2=P1^1;  //数字加
sbit k3=P1^2;  //数字减
sbit k4=P1^3;  //保留

sbit s1=P2^3;  //数码管第一位控制端口
sbit s2=P2^2;
sbit s3=P2^1;
sbit s4=P2^0;

sbit z1=P2^4; //蜂鸣器报警端口
sbit d1=P1^5; //电机驱动端口

sbit st=P1^4; //abc转换芯片控制端口
sbit eoc=P2^7;
sbit oe=P2^6;
sbit CLOCK=P2^5;
uint as=115,as1=70;	//高水位变亮/低水位变亮
uchar q[4];	//定义显示函数
unsigned char  q1[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00,0x38,0x76};
void delay(uint z)//延时函数
{while(z--);}
unsigned char adc0809()
   { unsigned char date;
   	 st=0;//ADC0809初始化
	 st=1;
	 _nop_();_nop_();
     st=0;
	_nop_();_nop_(); _nop_();
	 while(eoc==0);//等待转换完成	
	 oe=1;
	 date=def;//p2选择为ADC的数据口
	 oe=0;
	 return date; 
   }
void a1() //数码管动态扫描
    {
	 s1=0;s2=s3=s4=1;
	 suji=q1[q[0]];
	 delay(20);
	 suji=0x00;s1=s2=s3=s4=1;

	 s2=0;s1=s3=s4=1;
	 suji=q1[q[1]];
	 delay(20);
	 suji=0x00;s1=s2=s3=s4=1;

	 s3=0;s2=s1=s4=1;
	 suji=q1[q[2]];
	 delay(20);
	 suji=0x00;s1=s2=s3=s4=1;

	 s4=0;s2=s3=s1=1;
	 suji=q1[q[3]];
	 delay(20);
	 suji=0x00;s1=s2=s3=s4=1;
	}
void a2()  //按键子程序
    {  uint i1;
		  if(k1==0)
	    {delay(20);
		   i1++;while(k1==0);
		   while(1)
		   {
		   	if(i1==1)
			{q[0]=h;
			  if(k2==0){delay(20);as=as+5;if(as>=150)as=120;while(!k2);}
			  if(k3==0){delay(20);as=as-5;if(as<=15)as=5;while(!k3);}
			  q[1]=as/100;
			  q[2]=as%100/10;
			  q[3]=as%10;a1();
			}
			  	if(i1==2)
			{q[0]=l;
			  if(k2==0){delay(20);as1=as1+5;if(as1>=140)as1=120;while(!k2);}
			  if(k3==0){delay(20);as1=as1-5;if(as1<=15)as1=5;while(!k3);}
			  q[1]=as1/100;
			  q[2]=as1%100/10;
			  q[3]=as1%10;a1();
			}
			a1();
			if(k1==0){delay(20);if(i1==2)i1=0;while(!k1);break;}
		   }
		}
	}
void main()
   { uchar x;
     uint i1; 
   	TMOD=0x02;//选择定时器工作方式2
	TH0=254;
	TL0=254;//定时2us,为ADC0809提供500Khz的工作频率
	TR0=1;
	ET0=1;
	EA=1;	
	oe=0;
//	d1=0;
	k1=k2=k3=k4=1;
   	while(1)
	 {
	  a1();
	  x=adc0809();
	  x=210-x;
	   q[0]=16;			 //210/100=2 10/10=1; 
	   q[1]=x/100;
	   q[2]=x%100/10;
	   q[3]=x%10;							
	   if(as<x){d1=z1=1;i1=0;}		  
	   else if(i1==0){if(as1>x){i1=1;d1=z1=0;}}
	  a2();
	 }
   }
void int1(void )interrupt 1//定时器中断
{	
	CLOCK=~CLOCK;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值