【proteus仿真】C51单片机实现学校打铃器

运用89C51单片机实现对数码管和喇叭的控制,运用按键设置单片机的实时时间和响铃时间。
仿真视频:

https://www.bilibili.com/video/BV1nY4y1B7wu/

#include<reg51.h>
#define uchar unsigned char
#define uint unsigned int
sbit sounder=P3^6;
bit sound_time=0;
uchar sec,min,hour;
uchar sec_xg,min_xg,hour_xg;
uchar sec_change,min_change,hour_change;
uint code digi[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x40};
uchar code guan[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
uchar bell_hour[]={8,8,8,9,10,10,11,11,14,14,14,15,16,16,17,17};
uchar bell_min[]={0,45,55,40,10,55,5,50,0,40,55,40,10,55,5,50};
uchar temp=0;
uint time_con=0;
uchar w,w1=0;
uchar flag1,flag2,flag3,flag=0,flag4=1;
uchar findflag=0,xgflag=0;
uchar key;
uchar change;
uchar t,t1;
uchar a=0,b=0;
void delay(uint t1)
{ uchar i,j;
   for(i=0;i<t1;i++)
	for(j=0;j<30;j++);
}
void play()
{
 if(w>=1)
 {
 w1=0;
 flag=1;
 }
 else
 { if(flag==1&&flag4==1)
     w=0;
	 if(flag==1&&flag4==1&&a==1)
	 { w1=1;
	 }
 }
 P0=guan[0];
 P2=digi[sec%10];
 if(w1==1)delay(7);
 else delay(40);
 P0=guan[1];
 P2=digi[sec/10];
 if(w==1)delay(7);
 else delay(40);
 P0=guan[2];
 P2=digi[10];
 delay(40);
 P0=guan[3];
 P2=digi[min%10];
 if(w==3) delay(7);
 else delay(40);
 P0=guan[4]; 
 P2=digi[min/10]; 
 if(w==4)delay(7);
 else delay(40);
 P0=guan[5];
 P2=digi[10];
 delay(40);
 P0=guan[6];
 P2=digi[hour%10];
 if(w==6)delay(7);
 else delay(40);
 P0=guan[7];
 P2=digi[hour/10];
 if(w==7) delay(7);
 else delay(40);
}
void belltime()interrupt 3
{
 TH1=(65536-50000)/256;
 TL1=(65536-50000)%256;
 sounder=!sounder;
 time_con++;
 if(time_con==9760)
 {
  time_con=0;
  sound_time=0;
 }
}
void time()interrupt 1
{
 uchar i;
 flag1=0;
 flag2=0;
 flag3=0;
 TH0=(65536-50000)/256;
 TL0=(65536-50000)%256;
 if(temp>19)
 {
  temp=0;
  sec++;
  if(sec>59)
  {
   sec=0;
   min++;
   if(min>59)
    { min=0;
	  hour++;
	  if(hour>23)
	   hour=0;
	  }
	}
  }
  else temp++;
  if(sec==0)
  flag1=1;
  if(t==0)
  {
   for(i=t;i<23;i++)
   {
    if(min==bell_min[i])
	flag2=1;
	if(hour==bell_hour[i])
	flag3=1;
	if(flag2==1&&flag3==1)
	{ break;}
   }
  }
  if(t>0)
  { if(bell_min[t]==0&&bell_hour[t]==0)
     { b=1;}
	 if(min==bell_min[t])
	 flag2=1;
	 if(hour==bell_hour[t])
	 flag3=1;
  }
  if(flag1==1&&flag2==1&&flag3==1&&b==0)
  { t++;
    sound_time=1;
	flag1=0;
	flag2=0;
	flag3=0;
  }
  if(b==1)
  t=0;
}
void xiugai()
{ 
 TR0=0;
 w1=1;
 sec_xg=sec;
 min_xg=min;
 hour_xg=hour;
}
void find()
{ TR0=0;
  sec_change=sec;
  min_change=min;
  hour_change=hour;
  hour=bell_hour[change];
  min=bell_min[change];
  sec=0;
}
void jia()
{
 if(xgflag>0)
 { if(w==0)
   { sec++;
   if(sec>=60)
   sec=0;
   }
   if(w==1)
   { sec=sec+10;
   if(sec>=60)
   sec=0;
   }
   if(w==3)
   { min++;
   if(min>=60)
   min=0;
   }
   if(w==4)
   {min=min+10;
   if(min>=60)
   min=0;
   }
   if(w==6)
   { hour++;
   if(hour>=24)
   hour=0;
   }
   if(w==7)
   { hour=hour+10;
     if(hour>=24)
	 hour=0;
   }
  }
}
void jian()
{ if(xgflag>0)
  { if(w==0)
    { sec--;
	  if(sec<0)
	  sec=0;
	}
	if(w==1)
	{ sec=sec-10;
	if(sec<0)
	  sec=0;
	}
	if(w==3)
	{ min--;
	if(min<0)
	min=0;
	}
	if(w==4)
	{ min=min-10;
	  if(min<0)
	  min=0;
	}
	if(w==6)
	{ hour--;
	  if(hour<0)
	    hour=0;
	}
	if(w==7)
	{ hour=hour-10;
	  if(hour<0)
	   hour=0;
	}
  }
}
void save()
{ 
 TR0=0;
 if(xgflag>0)
{w1=0;
 w=0;
 flag4=0;
}
if(t1>0)
{ bell_hour[change]=hour;
  bell_min[change]=min;
  sec=sec_change;
  min=min_change;
  hour=hour_change;
}
}
void cancel()
{ TR0=1;
  if(xgflag>0)
  { if((sec_xg!=sec)||(min_xg!=min)||(hour_xg!=hour))
    { sec=sec_xg;
	  min=min_xg;
	  hour=hour_xg;
	}
	w1=0;
	w=0;
	flag4=0;
	}
	if(t1>0)
	{ sec=sec_change;
	  min=min_change;
	  hour=hour_change;
	}
}
void main()
{ uchar i;
  P0=0x00;
  P2=0x3f;
  TMOD=0x01;
  TH0=(65536-50000)/256;
  TL0=(65536-50000)%256;
  TH1=(65536-50000)/256;
  TL1=(65536-50000)%256;
  EA=1;
  ET0=1;
  TR0=1;
  ET1=1;
  sec=55;
  min=59;
  hour=7;
  flag1=0;
  flag2=0;
  flag3=0;
  t=0;
  key=P1;
  w=0;
  change=1;
  t1=0;
  while(1)
  { play();
    if(sound_time)
     TR1=1;
	 else TR1=0;
	 P1=0xff;
	 key=P1;
	 if(key!=0xff)
	  for(i=0;i<30;i++)
	   play();
	   switch(key)
	   { 
	     case 0xfe:xgflag++;findflag=0;w=0;xiugai();break;
		 case 0xfd:jia();break;
		 case 0xfb:jian();break;
		 case 0xf7:if(xgflag>0)
		           { w++;
				     if(w>7)
					 w=0;
					}
					if(findflag>0)
					{ change++;
					  hour=bell_hour[change];
					  min=bell_min[change];
					  sec=0;
					  if(change>23)
					  change=0;
					}break;
		  case 0xef: if(xgflag>0)
		             { w--;
					 if(w<0) w=7;}
					 if(findflag>0)
					 { change--;
					   hour=bell_hour[change];
					   min=bell_min[change];
					   sec=0;
					   if(change<0)
					   change=23;}break;
		  case 0xdf: cancel();xgflag=0;findflag=0;t1=0;break;
		  case 0xbf: save();xgflag=0;findflag=0;t1=0;break;
		  case 0x7f: findflag++;w=0;t1=1;find();break;
		  }
		  }
}



  • 2
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
300个C51单片机设计proteus仿真源码软件源码: 100000秒以内的计时程序 10秒的秒表 12864LCD图形滚动演示 128X64LED 160128LCD图文演示 1602字符液晶滚动演示程序 1602液晶显示的DS1302实时时钟 16×16点阵(滚动显示) 16×16点阵2(滚动显示) 2io5键盘模拟音量数码管显示 2×20串行字符液晶演示 32x16汉字 44行列键盘 485全双工通信 4×4键盘矩阵控制条形LED显示 4个独立式按键控制LED开关 4个独立式按键控制LED移位 4只数码管滚动显示0~3 555可调PWM发生 555的应用 6264扩展内存 6个16×16点阵 74HC154译码应用 74HC595 74HC595串入并出芯片应用 74LS138译码应用 74LS148扩展中断 8051双机通信简例 8255并行口扩展实例 89C51PWM 8x8LED汉字显示 8x8点阵做的贪吃蛇游戏 8×8LED点阵屏显示数字 8只数码管同时显示不同字符 8只数码管显示多个不同字符 8只数码管滚动显示8~F 8只数码管滚动显示单个数字 8只数码管滚动显示数字串 8只数码管闪烁显示 8通道自动温度检测系统仿真(含原程序) ADC0808 PWM实验 ADC0809模数转换与显示 ADC0832模数转换与显示 AT89C51对直流电动机的驱动 AVR_Uart BCD译码数码管显示数字 c51 可预设电压的数控电源(功能强大) clock Conter CPU控制的独立式键盘扫描实验 da、ad。液晶,传递函数模型综合应用的实例 DIY51式数控电源 DS1621温度传感实验 ds18b20 DS18B20温度传感实验 DS18B20温度检测及其液晶显示 HorseLight I2C IIC-24C04与数码管 IIC-24C04与蜂鸣 INT0与INT1中断计数 INT0中断3位计数 INT0及INT1中断计数 INT0和INT1控制条形LED INT1中断5位计数 IO并行口直接驱动单个数码管 K1-K4 分组控制LED K1-K4 控制LED移位 K1-K4 控制数码管加减演示 K1-K4 控制数码管移位显示 K1-K4 键状态显示 key_lcd ks0108 液晶12864 LCD频率计仿真 LED代码查询V1[1].1 LED模拟交通灯 LED闪烁 M16_AN_Compare M16_EEPROM M16_Horse MAX7221控制数码管动态显示 my16key_c NT0中断控制LED NT0中断计数 NumberDisplay P3口流水灯 PCF8574 PCF8583+LCD1602 PCF8591模数与数模转换实验 proteus ADDC的练习程序 PWM PWMLED PWM控制LED的亮度仿真程序 PWM控制马达的方法 PWM波输出(可调) PWM电机正反转 pwm程序实例 PWM调温 RAM扩展练习 sscom32串口调试 TIMER0与TIMER1控制条形LED TIMER0控制LED二进制计数 TIMER0控制单只LED闪烁 TIMER0控制四只LED滚动闪烁 TIMER0控制流水灯 ULN2803 usart_t 《lcd1602仿真实例》 一个数控直流稳压电源 一个步进电机的仿真 一步一步教你51_PC串口通信 万能逻辑电路实验 三机通讯 串口仿真mcu_pc 串口方式1 串行数据转换为并行数据 交通灯 从左到右的流水灯 光藕隔离驱动电机 内部函数intrins.h应用举例 净水控制仿真电路 刚做好的十个字的led屏模拟有程序 包含单片机寄存的头文件 单只按键控制单只数码管滚动显示 单只数码管循环显示0-9 单只数码管循环显示0~F 单片机与PC机串口通讯仿真 单片机之间双向通信 单片机向PC发送数据 单片机向主机发送字符串 单片机接收PC发出的数据 单片机控制的电动自行车驱动系统 单片机数据发送程序 发一个用定时做的PWM 基于1602+ds12b80+ds1302+音乐+电子书+流水灯的多功能电子表 基于ADC0832的数字电压表 基于AT24C02的多机通信 基于AT89C51+MAX7219的频率计 附带proteus仿真电路图 实际硬件电路测试通过 基于DS1302的日历时钟 基于yjwpm测试过的DS18B20仿真实例 多功能电子钟 多点温度测量 多路开关状态指示 大屏幕仿真 子电路做的一个H型电机驱动电路 字符串函数string.h应用举例 字符函数ctype.h应用举例 宏定义应用举例 定时中断控制的独立式键盘扫描实验 定时控制交通指示灯 定时控制数码动态显示 定时控制数码管动管显示 对I2C总线上挂接多个AT24C0
课程设计-基于C51单片机自动打铃系统 : 摘 要 本次设计中的LED数码管电子时钟电路采用24小时制记时方式,本次设计采用AT89C51单片机的扩展芯片和6个PNP三极管做驱动,由三块LED数码管构成的显示系统,与传统的基于8/16位普通单片机的LED显示系统相比较,本系统在不显著地增加系统成本的情况下,可支持更多的LED数码管稳定显示。设计采用AT98C51单片机,使用5V电源供电,并且在按键的作用下可以进行调时,调分,复位功能。计时数据的更新在计算机C语言的驱动下每秒自动进行一次,但不需程序干预其输出状态。 关键词:AT89C51; 数码管 ; LED 第一章 设计简介及方案论述 1.1作息时间控制钟系统概述: 本设计是一个具有报时功能的作息时间控制钟。它利用89C51单片机的2Hz时基计时,进行年历计算,并用的蜂鸣驱动模块将它报出来;在进行时间计算,分每加一时,都与规定的作息时间比较,如果相等则进行相应的控制或动作。由七段显示驱动模块、蜂鸣驱动模块和按钮控制模块三部分组成,四个按键用于报时及校正时间。现代机关企业,特别是学校要求对时间加以控制,要按时打铃及播放广播,以保证学习与工作的正常运行。本设计实现了这些功能,给学校及其他机关企业带来方便,整体性好,人性化强、可靠性高,实现了对时间控制的智能化。 1.2本设计任务和主要内容: (1)设计任务 用可编程器件为主体,设计并制作一台自动打铃系统。要求完成的作品必须固化软件,测试检查时上电即可工作,不允再用计算机下载。实现能够显示当前的时间,同时能够在规定的时间点控制打铃装置打出预期的铃声。另外增设四个按钮,通过分配以实现对时间的调整,包括对时钟、分钟的增加和减少,秒钟的清零;以及强制打铃和关闭打铃。 (2)主要内容 1、基本计时和显示功能(用12小时制显示)。包括上下午标志,时、分的数字显示,秒信号指示。 2、能设置当前时间(含上、下午,时,分) 3、能实现基本打铃功能,规定: 上午6:00起床铃:打铃5秒、停2秒、再打铃5秒。 下午10:30熄灯铃:打铃5秒、停2秒、再打铃5秒。 铃声可用小喇叭播放,凡是用到铃声功能的均按此处理。 第二章 系统主要硬件电路设计 2.1单片机总体设计思路 (1)设计能正常工作的一个单片机最小硬件系统,外围电路包括设置键盘,LCD或LED的显示屏; (2)进行软件设计,利用单片机系统时钟先设计一个高精度的内部时钟系统,最小精确时间为期1秒; (3)在秒计数的基础上设计一个24小时时钟,并设计若干定时功能; (4)设计打铃执行机构,完成自动打铃功能。 2.2各功能模块程序实现原理分析

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值