基于单片机的水位检测系统_51单片机温度传感器程序

基于单片机的水位检测系统_51单片机温度传感器程序开发前的准备:LCD1602一块51单片机开发板一块(这里我用的是普中的板子)霍尔水流量传感器一块(红色接5V黑色接GND黄色是数据传接口)霍尔传感器流量经验公式:Q=(F+3)/8.1Q表示流量…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

开发前的准备:

LCD1602一块

基于单片机的水位检测系统_51单片机温度传感器程序

51单片机开发板 一块(这里我用的是普中的板子)

霍尔水流量传感器一块(红色接5V黑色接GND黄色是数据传接口)

基于单片机的水位检测系统_51单片机温度传感器程序

 霍尔传感器流量经验公式: Q=(F+3)/8.1 Q表示流量

main.c

#include <REGX52.H>//头文件
#include "LCD1602.H"//1602显示的头文件
#include "Buzzer.h"//蜂鸣器的头文件

#define uchar unsigned char   //宏定义
#define uint  unsigned int   //宏定义
#define stand  40   //设置报警值(可调根据自己需求调)

uint flag;//设置标志位

sbit led=P2^0;
sbit K1=P3^1;//定义按键Key1引脚

float Q,F,num;//Q为流量,单位L/min;F为频率,单位HZ

//毫秒级延时函数
void delay(uint z)
{
		 uint x,y;
		 for(x = z; x > 0; x--)
		 for(y = 114; y > 0 ; y--);
}

uint read()//得到计数器0当前脉冲次数函数
{
			uint tl,th1,th2;//读两次高位,两次高位一样说明没有低位进位,读数更加精确。
			uint value;//设置存储值value
			while(1)
			{
					th1=TH0;//定时器置高位赋值给th1
					tl=TL0;//定时器置低位赋值给t1
					th2=TH0;//定时器置高位赋值给th2
					if(th1==th2)//判断如果两个高位相等就结束
				  break;
			}
			 value=th1*256+tl;//把定时器高位转为二进制+上低位
			 return value;//返回val的值
}

void buzzer()//蜂鸣器报警
{
		Buzzer_Time(100);
}
void timer0()//定时器函数
{
     TMOD=0x15;//定时器计数器工作方式配置
		 TH0=0;//高位
		 TL0=0;//低位
		 TH1=(65536-45872)/256;//确定高位
		 TL1=(65536-45872)%256;//确定低位
		 EA=1;//开总中断
		 ET0=1;//中断允许
		 ET1=1;
		 TR0=1;//运行控制位
		 TR1=1;
}

void KeyPro()//按键函数
{

  static uint a;//静态变量a标志位
    if(K1==0)//如果k1按下
		{
		  delay(20);//按时20ms
			if(K1==0)//再一次判断		
			{
			  a++;//标志位+1
				if(a%2==0)//标注位对二求余等于0
				 {
						flag=1;//flag就等于1
			  	}
				else//否则就flag等于0
				{			
				 flag=0;				
				}
				
			}
			
		}
		
}

void main()//主函数
{
			
	
		 LCD_Init();//初始化
		 timer0();//定时器初始化
	   while(1)//死循环
		 {			 
			 KeyPro();//按键函数
			 LCD_ShowNum(1,2,Q,4);//lcd1602显示函数
			 LCD_ShowString(1,6,"ML");//lcd1602显示函数  字符串
			 if(stand <= Q)//判断预设值和报警值
			 {
			    if(flag==1)//标注位等于1的话蜂鸣器就报警
					 {
					  buzzer();//蜂鸣器报警
				   }
			 }
    }	 
}



void T0_time()interrupt 1//中段函数1
{
	 TH0=0;
	 TL0=0;
}

void T1_time()interrupt 2//中断3
	{
		
				 TH1=(65536-45872)/256;//50毫秒
				 TL1=(65536-45872)%256;
				 num++;
		
			 if(num==5)  //1s更新一次数据,送至数码管显示
			  {
					
					num=0;
					F=read();//每隔1s读一次计数器0,该值则为频率。计算出Q后立马把计数器0清零重新计数。

				if(F>0)
					
				{
					 Q=(F+3)/8.1*100;   //流量传感器经验公式根据这个公式计算水流量
					 TH0=0;
					 TL0=0;													 
									
				}
				
				else
					
				{
					 Q=0;//如果不加这句,当F=0,由公式知道Q!=0。
					 TH0=0;
					 TL0=0;
					
		    }
				
	  } 
				
}














版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/188767.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 对贝叶斯理解以及解释贝叶斯函数「建议收藏」

    对贝叶斯理解以及解释贝叶斯函数「建议收藏」贝叶斯

  • 空间变换是什么_信号与系统状态转移矩阵

    空间变换是什么_信号与系统状态转移矩阵出自论文SpatialTransformerNetworksInsight:文章提出的STN的作用类似于传统的矫正的作用。比如人脸识别中,需要先对检测的图片进行关键点检测,然后使用关键点来进行对齐操作。但是这样的一个过程是需要额外进行处理的。但是有了STN后,检测完的人脸,直接就可以做对齐操作。关键的一点就是这个矫正过程是可以进行梯度传导的。想象一下,人脸检测完了,直接使用R

    2022年10月19日
  • MATLAB处理图像_matlab视频图像处理

    MATLAB处理图像_matlab视频图像处理RGB图像转为灰度图像:X=rgb2gray(I)

  • xsync 脚本[通俗易懂]

    xsync 脚本[通俗易懂]xsync文件分发脚本#!/bin/bash#1获取输入参数个数,如果没有参数,直接退出pcount=$#if((pcount==0));thenechonoargs;exit;fi#2获取文件名称p1=$1fname=`basename$p1`echofname=$fname#3获取上级目录到绝对路径pdir=`cd-P$(dirname$p1…

  • Raspberry Pi (树莓派)折腾记之一

    Raspberry Pi (树莓派)折腾记之一那么什么是RaspberryPi?RaspberryPi是一款针对电脑业余爱好者、教师、小学生以及小型企业等用户的迷你电脑,预装Linux系统,体积仅信用卡大小,搭载ARM架构处理器,运算性能和智能手机相仿。在接口方面,RaspberryPi提供了可供键鼠使用的USB接口,此外还有快速以太网接口、SD卡扩展接口以及1个HDMI高清视频输出接口,可与显示器或者TV…

  • Java中标识符的命名规则

    Java中标识符的命名规则培养好的编程习惯是十分重要的。本文带你简单认识一下Java中标识符的命名规则和规范。

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号