基于51单片机的心率脉搏检测proteus仿真程序原理图设计

硬件设计:

(末尾附文件)

本设计以STC89C51为主控芯片的单片机心率计,其硬件部分由主控器电路,心路采集电路,
液晶显示电路,蜂鸣器报警电路,按键模块电路组成,软件部分由 程序主函数, 液晶显示子程序 , 按键子程序,定时器中断 组成,能实现LCD1602液晶显示当前的心率,按键可以设置报警的上下限心率功能。

仿真图1:
基于51单片机的心率脉搏检测proteus仿真程序原理图设计
仿真图2:
基于51单片机的心率脉搏检测proteus仿真程序原理图设计
原理图2:
基于51单片机的心率脉搏检测proteus仿真程序原理图设计

程序设计

#include <reg52.h>
#include <intrins.h>	 //			 包含头文件

#define uint            unsigned int
#define uchar           unsigned char
#define ulong           unsigned long	 //宏定义
#define LCD_DATA        P0				 //定义P0口为LCD_DATA

sbit LCD_RS =P2^5;
sbit LCD_RW =P2^6;
sbit LCD_E  =P2^7;						 //定义LCD控制引脚

sbit Xintiao =P1^0 ;					 //脉搏检测输入端定义
sbit speaker =P2^4;						 //蜂鸣器引脚定义

void delay5ms(void);   //误差 0us
void LCD_WriteData(uchar LCD_1602_DATA);	 /********LCD1602数据写入***********/
void LCD_WriteCom(uchar LCD_1602_COM);		 /********LCD1602命令写入***********/
void lcd_1602_word(uchar Adress_Com,uchar Num_Adat,uchar *Adress_Data); /*1602字符显示函数,变量依次为字符显示首地址,显示字符长度,所显示的字符*/
void InitLcd();//液晶初始化函数

void Tim_Init();

uchar Xintiao_Change=0;	   //
uint  Xintiao_Jishu;
uchar stop;
uchar View_Data[3];
uchar View_L[3];
uchar View_H[3];
uchar Xintiao_H=100;	//脉搏上限
uchar Xintiao_L=40;		//脉搏下限


uchar Key_Change;
uchar Key_Value;		//按键键值
uchar View_Con;			//设置的位(0正常工作,1设置上限,2设置下限)
uchar View_Change;

void main()	  //主函数
{
 InitLcd();
 Tim_Init();
 lcd_1602_word(0x80,16,"Heart Rate:     ");	  //初始化显示
 TR0=1;
 TR1=1;				  //打开定时器
 while(1)			  //进入循环
  {
   if(Key_Change)	  //有按键按下并已经得出键值
    {
	 Key_Change=0;	  //将按键使能变量清零,等待下次按键按下
	 View_Change=1;
	 switch(Key_Value)				//判断键值
	  {
	   case 1:						//设置键按下
	         {
			  View_Con++;			//设置的位加
			  if(View_Con==3)		//都设置好后将此变量清零
			   View_Con=0;
			  break;				//跳出,下同
			 }
	   case 2:						//加键按下
	         {
			  if(View_Con==2)		//判断是设置上限
			   {
			   	if(Xintiao_H<150)	//上限数值小于150
				 Xintiao_H++;		//上限+
			   }
			  if(View_Con==1)		//如果是设置下限
			   {
			   	if(Xintiao_L<Xintiao_H-1)//下限值小于上限-1(下限值不能超过上限)
				 Xintiao_L++;		//下限值加
			   }
			  break;
			 }
	   case 3:						//减键按下
	         {
			  if(View_Con==2)		//设置上限
			   {
			   	if(Xintiao_H>Xintiao_L+1)//上限数据大于下限+1(同样上限值不能小于下限)
				 Xintiao_H--;		//上限数据减
			   }
			  if(View_Con==1)		//设置下限
			   {
			   	if(Xintiao_L>30)	//下限数据大于30时
				 Xintiao_L--;		//下限数据减
			   }
			  break;
			 } 
	 }
	}
   if(View_Change)//开始显示变量
    {
	 View_Change=0;//变量清零
	 if(stop==0)			  //心率正常时
	  {
	   if(View_Data[0]==0x30) //最高位为0时不显示
	    View_Data[0]=' ';
	  }
	 else					  //心率不正常(计数超过5000,也就是两次信号时间超过5s)不显示数据
	  {
	   View_Data[0]=' ';
	   View_Data[1]=' ';
	   View_Data[2]=' ';
	  }

	 switch(View_Con)
	  {
	   case 0: //正常显示
	          {
			   lcd_1602_word(0x80,16,"Heart Rate:     ");//显示一行数据
			   lcd_1602_word(0xc0,16,"                ");//显示第二行数据
			   lcd_1602_word(0xcd,3,View_Data);			 //第二行显示心率
			   break;
			  }
	   case 1: //设置下限时显示
	          {
			   lcd_1602_word(0x80,16,"Heart Rate:     ");//第一行显示心率
			   lcd_1602_word(0x8d,3,View_Data);
			   
			   View_L[0]=Xintiao_L/100+0x30;		//将下限数据拆字
			   View_L[1]=Xintiao_L%100/10+0x30;
			   View_L[2]=Xintiao_L%10+0x30;

			   if(View_L[0]==0x30)					//最高位为0时,不显示
			    View_L[0]=' ';
			   
			   lcd_1602_word(0xC0,16,"Warning L :     ");//第二行显示下限数据
			   lcd_1602_word(0xCd,3,View_L);
			   break;
			  }
	   case 2: //设置上限时显示(同上)
	          {
			   lcd_1602_word(0x80,16,"Heart Rate:     ");
			   lcd_1602_word(0x8d,3,View_Data);
			   
			   View_H[0]=Xintiao_H/100+0x30;
			   View_H[1]=Xintiao_H%100/10+0x30;
			   View_H[2]=Xintiao_H%10+0x30;

			   if(View_H[0]==0x30)
			    View_H[0]=' ';
			   
			   lcd_1602_word(0xC0,16,"Warning H :     ");
			   lcd_1602_word(0xCd,3,View_H);
			   break;
			  }
	  }
	}
  }
}

void Time1() interrupt 3		//定时器1服务函数
{
 static uchar Key_Con,Xintiao_Con;
 TH1=0xd8;		   //10ms
 TL1=0xf0;		   //重新赋初值
 switch(Key_Con)   //无按键按下时此值为0
  {
   case 0:		   //每10ms扫描此处
          {
		   if((P3&0x07)!=0x07)//扫描按键是否有按下
		    {
			 Key_Con++;		  //有按下此值加1,值为1
			}
		   break;
		  }
   case 1:					  //10ms后二次进入中断后扫描此处(Key_Con为1)
          {
		   if((P3&0x07)!=0x07)//第二次进入中断时,按键仍然是按下(起到按键延时去抖的作用)
		    {
			 Key_Con++;		  //变量加1,值为2
			 switch(P3&0x07)  //判断是哪个按键按下
			  {
			   case 0x06:Key_Value=1;break;	 //判断好按键后将键值赋值给变量Key_Value
			   case 0x05:Key_Value=2;break;
			   case 0x03:Key_Value=3;break;
			  }
			}
		   else								 //如果10ms时没有检测到按键按下(按下时间过短)
		   	{
			 Key_Con=0;						 //变量清零,重新检测按键
			}
		   break;
		  }
   case 2:									 //20ms后检测按键
          {
		   if((P3&0x07)==0x07)				 //检测按键是否还是按下状态
		    {
			 Key_Change=1;					 //有按键按下使能变量,(此变量为1时才会处理键值数据)
			 Key_Con=0;						//变量清零,等待下次有按键按下
			}
		   break;
		  }
  }

.
文件地址
链接:https://pan.baidu.com/s/1JdaKCgLxc1j8QNWWCpBS7A
提取码:h59s

.

上一篇:Xilinx Vivado的使用详细介绍(5):调用用户自定义封装的IP核


下一篇:JDBC连接数据库