基于51单片机对自动打铃系统的设计

2020-05-22来源: eefocus关键字:51单片机  自动打铃系统  

51单片机自动打铃C语言程序:

基于51单片机对自动打铃系统的设计

#include “reg51.h”

#include “intrins.h” #define uchar unsigned char #define uint unsigned int

uchar code DSY_CODE[] = {0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xff};//共阴极总段//

uchar DSY_BUFFER[]={0,0,0xBF,0,0,0xff,0,0};//时间显示时-分 模式

uchar DSY_BUFFER1[]={0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff}; //模式显示段//

uchar Scan_BIT;//位选择//

uchar DSY_IDX;//段选择//

uchar Key_State; //按键控制//

uchar s,s100,h1 ;

char h,m;

sbit dd=P1^7; //喇叭和led输出端口//

sbit cc=P1^6;

sbit ss=P1^5; //时间和秒转换显示键//

void DelayMS(uchar x)

{

uchar i;

while(x--) for(i = 0;i《120;i++);

}

void Increase_Hour()

{

if (++h》23) h=0;

DSY_BUFFER[0] =DSY_CODE[h/10];

DSY_BUFFER[1] =DSY_CODE[h];

}

void Decrease_Hour()

{ h--;

if (h《0) h=23;

DSY_BUFFER[0] =DSY_CODE[h/10];

DSY_BUFFER[1] =DSY_CODE[h];

}

void Increase_Minute()

{

if(++m》59)

{

m=0;Increase_Hour();

}

DSY_BUFFER[3] =DSY_CODE[m/10];

DSY_BUFFER[4] =DSY_CODE[m];

}

void Decrease_Minute()

{ m--;

if(m《0) m=59;

DSY_BUFFER[3] =DSY_CODE[m/10];

DSY_BUFFER[4] =DSY_CODE[m];

}

void Increase_Hour1()

{

if (++h1》7) h1=1;

DSY_BUFFER[6] =DSY_CODE[h1/10];

DSY_BUFFER[7] =DSY_CODE[h1];

}

void Increase_Second()

{

if(++s》59)

{

s=0;Increase_Minute();

}

DSY_BUFFER1[0] =DSY_CODE[s/10];

DSY_BUFFER1[1] =DSY_CODE[s];

}

void T0_INT() interrupt 1 //显示屏显示//

{

TH0=(65536-1000)/256;

TL0=(65536-1000)%6;

if(ss==1) //P1.5键没按下,显示时间//

{

P3=Scan_BIT;

P2=~DSY_BUFFER[DSY_IDX];

}

else { //P1.5键按下,闪//

P3=Scan_BIT;

P2=~DSY_BUFFER[DSY_IDX];

}

Scan_BIT=_crol_(Scan_BIT,1);//位显示移动//

DSY_IDX=(DSY_IDX+1)%8; //段选择每次变化//

if(h1==3)

{ if(h==6&m==0)cc=dd=0;else cc=dd=1;//时间到闹钟响,led亮,一分钟//

if(h==6&m==15)cc=dd=0; else cc=dd=1;

if(h==7&m==0)cc=dd=0; else cc=dd=1;

if(h==12&m==30)cc=dd=0; else cc=dd=1;

if(h==14&m==0)cc=dd=0; else cc=dd=1;

if(h==16&m==30)cc=dd=0; else cc=dd=1;

if(h==18&m==0)cc=dd=0; else cc=dd=1;

if(h==18&m==45)cc=dd=0; else cc=dd=1;

if(h==19&m==30)cc=dd=0; else cc=dd=1;

if(h==21&m==30)cc=dd=0; else cc=dd=1;

if(h==22&m==0)cc=dd=0;else cc=dd=1; }

else cc=dd=1;

if(h1==1|h1==4|h1==2|h1==5)

{ if(h==6&m==0)cc=dd=0;else cc=dd=1;//时间到闹钟响,led亮,一分钟//

if(h==7&m==0)cc=dd=0; else cc=dd=1;

if(h==12&m==30)cc=dd=0; else cc=dd=1;

if(h==14&m==0)cc=dd=0; else cc=dd=1;

if(h==16&m==30)cc=dd=0; else cc=dd=1;

if(h==18&m==0)cc=dd=0; else cc=dd=1;

if(h==18&m==45)cc=dd=0; else cc=dd=1;

if(h==19&m==30)cc=dd=0; else cc=dd=1;

if(h==21&m==30)cc=dd=0; else cc=dd=1;

if(h==22&m==0)cc=dd=0;else cc=dd=1; }

else cc=dd=1;

if(h1==6)

{ if(h==6&m==0)cc=dd=0;else cc=dd=1;//时间到闹钟响,led亮,一分钟//

if(h==7&m==0)cc=dd=0; else cc=dd=1;

if(h==12&m==30)cc=dd=0; else cc=dd=1;

if(h==14&m==30)cc=dd=0; else cc=dd=1;

if(h==18&m==0)cc=dd=0; else cc=dd=1;

if(h==21&m==0)cc=dd=0; else cc=dd=1;

if(h==21&m==30)cc=dd=0; else cc=dd=1;

if(h==22&m==30)cc=dd=0;else cc=dd=1; }

else cc=dd=1;

if(h1==7)

{ if(h==6&m==30)cc=dd=0;else cc=dd=1;//时间到闹钟响,led亮,一分钟//

if(h==7&m==0)cc=dd=0; else cc=dd=1;

if(h==11&m==30)cc=dd=0; else cc=dd=1;

if(h==12&m==30)cc=dd=0; else cc=dd=1;

if(h==15&m==30)cc=dd=0; else cc=dd=1;

if(h==16&m==30)cc=dd=0; else cc=dd=1;

if(h==18&m==0)cc=dd=0; else cc=dd=1;

if(h==18&m==40)cc=dd=0; else cc=dd=1;

if(h==20&m==0)cc=dd=0; else cc=dd=1;

if(h==20&m==30)cc=dd=0; else cc=dd=1;

if(h==21&m==30)cc=dd=0; else cc=dd=1;

if(h==22&m==0)cc=dd=0;else cc=dd=1; }

else cc=dd=1;

}

void T1_INT() interrupt 3//时间秒自动加一,走时//

{

TH1=(65536-50000)/256;

TL1=(65536-50000)%6;//延时50毫秒//

if (s100==20)

{

s100=0;

Increase_Second();

}

else s100++;

}

void main ()

{

P2=P3=0xFF;

TMOD=0x11;

TH0=(65536-1000)/256;

TL0=(65536-1000)%6;

TH1=0XDC;

TL1=0;

TCON=0x01;

EA=1;

ET0=1;

ET1=1;

h=05,m=55,s=s100,h1=1; //时间和闹钟初值//

DSY_BUFFER[0]=DSY_CODE[h/10]; //时间初值赋给时间段码显示组//

DSY_BUFFER[1]=DSY_CODE[h];

DSY_BUFFER[3]=DSY_CODE[m/10];

DSY_BUFFER[4]=DSY_CODE[m];

DSY_BUFFER[6]=DSY_CODE[h1/10];

DSY_BUFFER[7]=DSY_CODE[h1];

DSY_BUFFER1[0]=DSY_CODE[h1/10]; //闹钟初值赋给闹钟段码显示组//

DSY_BUFFER1[1]=DSY_CODE[h1];

Scan_BIT=0xFE; //给位选择赋初值为二进制数 11111110,即只有最后一位为低电平,之后每次左移一位,依次为11111101,11111011.。..。.01111111,11111110循环移动//

DSY_IDX=0; //段码显示组的选择变量//

TR0=TR1=1;

Key_State=0xFF;

while(1)

{

if (P1^Key_State) //判断按键是否有按下//

{

DelayMS(10);

if (P1^Key_State)

{

Key_State=P1; EA=0;

if((Key_State&0x01)==0) Increase_Hour(); //小时加一//

else if ((Key_State&0x02)==0) Decrease_Hour(); //小时减一//

else if ((Key_State&0x04)==0) Increase_Minute(); //分钟加一//

else if ((Key_State&0x08)==0) Decrease_Minute(); //分钟减一//

else if ((Key_State&0x10)==0) //复位按键//

{h=05,m=55,s=0,h1=1;

DSY_BUFFER[0]=DSY_CODE[h/10];

DSY_BUFFER[1]=DSY_CODE[h];

DSY_BUFFER[3]=DSY_CODE[m/10];

DSY_BUFFER[4]=DSY_CODE[m];

DSY_BUFFER[6]=DSY_CODE[h1/10];

DSY_BUFFER[7]=DSY_CODE[h1];

}

else if ((Key_State&0x20)==0)Increase_Hour1(); //模式加一//

EA=1;

}

}

}

}


关键字:51单片机  自动打铃系统   编辑:什么鱼 引用地址:http://news.eeworld.com.cn/mcu/ic497975.html 本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:C51单片机在电机转速测量仿真系统中的设计
下一篇:最后一页

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

51单片机实验8:led点阵(1):点亮一个点
开发板led点阵模块电路图如下:74HC595:74HC595是一个8位串行输入、并行输出的位移缓存器。芯片第11角为数据输入时钟线,上升沿有效。芯片第12脚为输出存储器锁存时钟线,上升沿有效。芯片第13脚为输出有效(低电平)。芯片第14脚为串行数据输入。为表示出输入74HC595的8位二进制数,开发板加入了led模块(图一中绿色所示)。若要使led发光,则需将JP595接vcc。OE为输出有效控制端,低电平有效,所以务必将JOE短接片短接到GND端。_nop_();函数为延时一个机器周期,所对应头文件为intrins.h#include<reg52.h>#include<intrins.h>#define
发表于 2020-05-08
51单片机实验8:led点阵(1):点亮一个点
51单片机 4个独立按键控制LED灯 (protues仿真)(C语言版)
}}void main(){while(1){key();}}四、运行程序后成功后,打开proteus右键单击单片机AT89C51,找到编辑,然后添加hex文件
发表于 2020-05-08
51单片机 4个独立按键控制LED灯 (protues仿真)(C语言版)
51单片机课程设计——led点阵广告牌程序设计
上学期期末的课设题目是led点阵广告牌,当时的要求如下:(1)能够显示不同字符的LED点阵广告牌;(2)按键切换不同的显示效果(如闪烁,静止,平移等);(3)按键切换不同的显示内容;(4)能够显示图形或自定义字符;(5)其他功能(创新部分);(6)系统调试、分析、总结与功能实现。当时用的是我用是的普中科技的STC90C51RD+的单片机,不过只要是51单片机,换哪个51内核的芯片都可以,只要电路和程序匹配就可以。我用的那款普中科技的51单片机可以直接连线决定线路的布置,不需要自己去重新焊一个电路板。然后我根据任务要求连接了电路,写了对应的程序,还有proteus仿真。另外,觉得有趣可以点个赞;有什么有趣的想法可以评论一下,我感兴趣
发表于 2020-05-08
51单片机课程设计——led点阵广告牌程序设计
51单片机 基于LED点阵的9~0倒计数
#include <reg52.h>sbit ADDR0 = P1^0;sbit ADDR1 = P1^1;sbit ADDR2 = P1^2;sbit ADDR3 = P1^3;sbit ENLED = P1^4;unsigned char code image[11][8] = {{0xC3, 0x81, 0x99, 0x99, 0x99, 0x99, 0x81, 0xC3}, //数字0{0xEF, 0xE7, 0xE3, 0xE7, 0xE7, 0xE7, 0xE7, 0xC3}, //数字1{0xC3, 0x81, 0x9D, 0x87, 0xC3, 0xF9, 0xC1, 0x81}, //数字2{0xC3,
发表于 2020-05-07
基于51单片机智能红外温控风扇设计
1、设计需求及目标本产品采用单片机+最小系统+数码管显示模块+数码管驱动模块+温度采集模块+人体感应模块+风扇模块+按键模块等构成;功能描述:(1)采用DS18B20温度传感器测温,人体感应模块检测是否有人。(2)共3个按键:1键切换/设置、2键加、3键减。(3)本设计共三种模式:自动模式、手动模式和自然风模式。(4)自动模式,按一下1键可以设置温度上限,再按下设置温度下限,均可以按键加减调整。数码管第一位不显示,后三位显示温度值。人体感应模块检测有人时,温度小于下限风扇不转,温度在上下限之间50%转动,大于上限时,风扇全速转动。人离开后,延迟几秒风扇停止转动,起到节能环保的作用。(5)手动模式,数码管第一位显示风扇档位,后三位
发表于 2020-05-07
基于51单片机智能红外温控风扇设计
C51单片机数码管动态显示
数码管作为最廉价的输出设备,在各种自动化设备中有很大的应用,最简单普通的显示方式为动态刷新显示,称为假动态显示,即通过分时扫描每一位,利于人眼的视觉停留现象,造成一种静态显示的效果,如下图所示:C51单片机由于运行速度很慢,在高刷新频率下,单片机的资源耗费很厉害,这样单片机就不可以再进行大量的计算工作,实际上,单片机在刷新时,只需要周期性的改变GPIO口的状态就可以了,剩下的时间其实都是在空转的状态下,我们能不能将这个空转的状态拿来用呢?当然是可以的啦,这里,我们利用单片机的定时器周期地产能中断,在中断内进行数码管的刷新工作,就可以将等待中断的这个CPU时间拿来做别的事情了。硬件电路:代码贴过来:主函数#include "
发表于 2020-05-07
C51单片机数码管动态显示
小广播
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2020 EEWORLD.com.cn, Inc. All rights reserved