显示格式为“时时:分分:秒秒”。
用4个功能键操作来设置当前时间。功能键K1~K4功能如下。
K1—进入设置现在的时间。
K2—设置小时(按一次,小时增1)。
K3—设置分钟(按一次,分钟增1)。
K4—确认完成设置。
程序执行后工作指示灯闪动,表示程序开始执行,LED显示“00:00:00”,然后开始计时。
本题可以考虑用LCD(比如:LCD1602)来实现显示,则显示更加清楚。
以51单片机为核心的时钟,在LED显示器上显示当前的时间:
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- signsw 2015-06-21 14:01关注
#include
#include
#define uchar unsigned char
#define uint unsigned int
#define shuju P0
#define bus P1
//#define lcdbus P3
sbit rs=P2^7;
sbit rw=P2^6;
sbit e=P2^5;
sbit sda=P2^0; //IO口定义
sbit scl=P2^1;
uchar r;
void delayms(int i)
{
int j;
for(j=0;j<i;j++);
}
void enable()
{
rs=0;
rw=0;
e=0;
delayms(65000);
e=1;
}
void write()
{
rs=1;
rw=0;
e=0;
delayms(65000);
e=1;
}
void chushi()
{
sda=0;
scl=0;
shuju=0x01;
enable();
shuju=0x38;
enable();
shuju=0x0f;
enable();
shuju=0x06;
enable();
shuju=0x80;
enable();
}
void display(uchar i)
{
shuju=i;
write();
}
void jianpan()
{
uchar a;
uchar k;
bus=0xff;
bus=0xef; //扫描第一行
delayms(6000);
a=bus;
a=a&0x0f;
if(a!=0x0f)
{
delayms(2000);
if(a!=0x0f)
{
switch(a)
{
case 0x0e:
k=0x41;break; case 0x0d: k=0x42; break; case 0x0b: k=0x43; break; case 0x07: k=0x44; break; } display(k); r=r-1; while(a!=0x0f) { bus=0x0f; delayms(2000); a=bus; }
}
}
bus=0xdf; //扫描第二行
delayms(6000);
a=bus;
a=a&0x0f;
if(a!=0x0f)
{
delayms(2000);
if(a!=0x0f)
{
switch(a)
{
case 0x0e:
k=0x45;
break;
case 0x0d:
k=0x46;
break;
case 0x0b:
k=0x47;
shuju=0x07;
break;
case 0x07:
k=0x48;
break;
}
display(k);
r=r-1;
while(a!=0x0f)
{
bus=0x0f;
delayms(2000);
a=bus;} } } bus=0xbf; //扫描第3行 delayms(6000); a=bus; a=a&0x0f; if(a!=0x0f) { delayms(2000); if(a!=0x0f) { switch(a) { case 0x0e: k=0x49; break; case 0x0d: k=0x4a; break; case 0x0b: k=0x4b; break; case 0x07: k=0x4c; break; } display(k); r=r-1; while(a!=0x0f) { bus=0x0f; delayms(2000); a=bus; } } } bus=0x7f; //扫描第4行 delayms(6000); a=bus; a=a&0x0f; if(a!=0x0f) { delayms(2000); if(a!=0x0f) { switch(a) { case 0x0e: k=0x4d; break; case 0x0d: k=0x4e; break; case 0x0b: k=0x4f; break; case 0x07: k=0x50; break; } display(k); r=r-1; while(a!=0x0f) { bus=0x0f; delayms(2000); a=bus; } } }
}
void main()
{
while(1)
{
chushi();
r=0x10;
while(r>0)
{
jianpan();
}
shuju=0xc0;
enable();
r=0x10;
while(r>0)
{
jianpan();
}
}
}解决 3无用
悬赏问题
- ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
- ¥15 如何在scanpy上做差异基因和通路富集?
- ¥20 关于#硬件工程#的问题,请各位专家解答!
- ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
- ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
- ¥30 截图中的mathematics程序转换成matlab
- ¥15 动力学代码报错,维度不匹配
- ¥15 Power query添加列问题
- ¥50 Kubernetes&Fission&Eleasticsearch
- ¥15 報錯:Person is not mapped,如何解決?