/**************************************************************************************
* 动态数码管显示实验 *
实现现象:下载程序后数码管从左至右显示0-7。
注意事项:
***************************************************************************************/
#include "reg52.h" //此文件中定义了单片机的一些特殊功能寄存器
typedef unsigned int u16; //对数据类型进行声明定义
typedef unsigned char u8;
sbit LSA=P2^2;
sbit LSB=P2^3;
sbit LSC=P2^4;
sbit k1=P1^0;
sbit k2=P1^1;
sbit k3=P1^2;
sbit k4=P1^3;
sbit k5=P1^4;
char hour = 12;
char minute = 0;
char second = 0;
//char a=0,b=0,c=0,d=0,e=0,f=0,counter=20;
char counter = 20;
u8 DisplayData[8];
u8 code smgduan[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
/*******************************************************************************
* 函 数 名 : delay
* 函数功能 : 延时函数,i=1时,大约延时10us
*******************************************************************************/
void delay(u16 i)
{
while(i--);
}
void stop1(void) //清零、初始化
{
hour =0;
minute =0;
second =0;
TH0=0x3c;
TL0=0xb0;
}
/*******************************************************************************
* 函 数 名 : display
* 函数功能 : 显示时、分、秒
*******************************************************************************/
void display()
{
DisplayData[0]=smgduan[hour/10]; //显示小时的十位
delay(4);
DisplayData[1]=smgduan[hour%10]; //显示小时的个位
delay(4);
DisplayData[2]=0x40; //显示小时的'-'位
delay(4);
DisplayData[3]=smgduan[minute/10]; //显示分的十位
delay(4);
DisplayData[4]=smgduan[minute%10]; //显示分的个位
delay(4);
DisplayData[5]=0x40; //显示分的'-'位
delay(4);
DisplayData[6]=smgduan[second/10]; //显示秒的十位
delay(4);
DisplayData[7]=smgduan[second%10]; //显示秒的个位
delay(4);
}
/*******************************************************************************
* 函 数 名 : DigDisplay
* 函数功能 : 数码管动态扫描函数,循环扫描8个数码管显示
*******************************************************************************/
void DigDisplay()
{
u8 i;
for(i=0;i<8;i++)
{
switch(i)
{
case(0):
LSA=0;LSB=0;LSC=0; break;
case(1):
LSA=1;LSB=0;LSC=0; break;
case(2):
LSA=0;LSB=1;LSC=0; break;
case(3):
LSA=1;LSB=1;LSC=0; break;
case(4):
LSA=0;LSB=0;LSC=1; break;
case(5):
LSA=1;LSB=0;LSC=1; break;
case(6):
LSA=0;LSB=1;LSC=1; break;
case(7):
LSA=1;LSB=1;LSC=1; break;
}
P0=DisplayData[i];//发送数据
delay(100); //间隔一段时间扫描
P0=0x00;//消隐
}
}
void timer_0() interrupt 1 using 1 //计数
{
TH0=0x3C;
TL0=0xB0;
counter--;
if(counter==0)
{
counter=20;
second++;
if(second==60)
{
second=0;
minute++;
if(minute==60)
{
minute=0;
hour++;
if(hour==24)
{
stop1();
} //24 hour
}
}
}
}
void keyscan(void) //按键状态
{
if(k1==0)
{
delay(10);
if(k1==0)
{
TR0=!TR0;
}
while(!k1);
}
if(k2==0)
{
delay(10);
if(k2==0)
{
hour++;
if(hour ==24)
{
hour = 0;
}
}
while(!k2);
}
if(k3==0)
{
delay(10);
if(k3==0)
{
minute++;
if(minute == 60)
{
minute = 0;
}
}
while(!k3);
}
if(k4==0)
{
delay(10);
if(k4==0)
{
second++;
if(second ==60)
{
second = 0;
}
}
while(!k4);
}
if(k5==0)
{
delay(10);
if(k5==0)
{
stop1();
}
while(!k5);
}
}
/*******************************************************************************
* 函 数 名 : main
* 函数功能 : 主函数
* 输 入 : 无
* 输 出 : 无
*******************************************************************************/
void main()
{
EA=1;
ET0=1;
TR0=1;
TF0=0;
TMOD=0x21;
while(1)
{
keyscan();
DigDisplay(); //数码管显示函数
display();
}
}
偷吃月亮的猫.
- 粉丝: 0
- 资源: 4
最新资源
- 程序员问卷调查.docx
- 计网G32201何振浪 202151021665.zip
- Dev-C++的下载和安装教程(非常详细)从零基础入门到精通,看完这一篇就够了_devc+_dev c++-CSDN博客.url
- 三轴磁力计校准.docx
- 以下是该竞赛的教程和经验分享,帮助你了解比赛流程、准备方式、常用方法和策略
- CAD主流电气原理图,通俗易懂,合适工控爱好者学习,多套主流PLC电气图纸,有常见的污水处理厂控制,变频器控制,中央空调控制以及
- Go-master.zip
- 基于Crowbar电路的双馈风力发电机DFIG低电压穿越LVRT仿真模型 本模型采用Crowbar Matlab Simulin
- scratch-level-1-master.zip
- 机器学习大作业-基于BP神经网络实现鲍鱼的性别分类项目源码+实验报告.zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈