求基于单片机的数字钟

2019-07-16 03:35发布

求基于单片机的数字钟。。。交作业。。求高手帮助。。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
2条回答
lovezjf234
1楼-- · 2019-07-16 05:38
论坛搜,
xp918127
2楼-- · 2019-07-16 08:06
#include<reg52.h>
sbit wela=P2^7;
sbit dula=P2^6;
sbit key1=P3^4;
sbit key2=P3^5;
sbit key3=P3^6;
sbit key4=P3^7;
sbit beep=P2^3;
unsigned char code table[]={
                              0x3f,0x06,0x5b,0x4f,
                              0x66,0x6d,0x7d,0x07,
                              0x7f,0x6f,0x77,0x7c,
                              0x39,0x5e,0x79,0x71
                              };
unsigned char code table1[]={ 0xfe,0xfd,0xfb,0xf7,0xef,0xdf};
unsigned int tt;
unsigned int sec,fen,hr;
void init();
void scankey();
void beeping();
void display(hr,fen,sec);
void delay(z);
void main()
{
  init();
  while(1)
  {
    //clock();
    scankey();
    display(hr,fen,sec);
  }
}
/*****************
初始化程序,char型最大值为255可以调整时间
进行整点报时的时钟
*****************/
void init()
{
  //num=0;
  hr=fen=sec=0;
  TMOD=0x01;
  TH0=(65536-10000)/256;
  TL0=(65536-10000)%256;
  EA=1;
  ET0=1;
  TR0=1;
}
/************
定时器中断
*************/
void timer0() interrupt 1
{
  TH0=(65536-10000)/256;
  TL0=(65536-10000)%256;
  tt++;
  if(tt ==100)
   {  
     tt=0;
     sec++;
     if(sec ==60)
      {
        sec=0;
        fen++;
        if(fen ==60)
         {
           fen=0;
           hr++;
           if(hr ==24)
             {
               hr =0;
             }
         }
      }
  }
  beeping();
  //display(hr,fen,sec);
}
/*******************/     
     /*num++;
     miao_ge=num%60%10;
     miao_shi=num%60/10;
     fen_ge=num/60%10;
     fen_shi=num/60/10;
     if(num == 3600)
       {
          num=0;
          hr++;
          if(hr ==24) hr=0;
       }
     hr_ge=hr%10;
     hr_shi=hr/10;*/  
/**************/
void display(hr,fen,sec)
{  
  wela=1;
  P0=0xfe;
  wela=0;
  P0=0x00;
  dula=1;
  P0=table[hr/10];
  dula=0;
  P0=0xff;
  delay(1);  

  wela=1;
  P0=0xfd;
  wela=0;
  P0=0x00;
  dula=1;
  P0=table[hr%10];
  dula=0;
  P0=0xff;
  delay(1);
  
  wela=1;
  P0=0xfb;
  wela=0;
  P0=0x00;
  dula=1;
  P0=table[fen/10];
  dula=0;
  P0=0xff;
  delay(1);

  wela=1;
  P0=0xf7;
  wela=0;
  P0=0x00;
  dula=1;
  P0=table[fen%10];
  dula=0;
  P0=0xff;
  delay(1);

  wela=1;
  P0=0xef;
  wela=0;
  P0=0x00;
  dula=1;
  P0=table[sec/10];
  dula=0;
  P0=0xff;
  delay(1);  

  wela=1;
  P0=0xdf;
  wela=0;
  P0=0x00;
  dula=1;
  P0=table[sec%10];
  dula=0;
  P0=0xff;
  delay(1);
}

/***********
延时程序
**************/
void delay(unsigned int z)
{
  unsigned int x,y;
  for(x=z;x>0;x--)
   for(y=110;y>0;y--);
}
/************/
void scankey()
{
  int i,j,flag_key;
   i=j=flag_key=0;
  if(key1!=1)
   {
     delay(10);
     if(key1!=1)
       {
         TR0=1;   
       }
   }
   if(key2!=1)
  {
    delay(10);
    if(key2!=1)
     {
       TR0=0;
       hr++;
       if(hr ==24) hr=0;
       while(key2!=1) display(hr,fen,sec);
     }
  }
   if(key3!=1)
   {
     delay(10);
     if(key3!=1)
     {
       TR0=0;
       fen++;
       if(fen ==60) fen=0;
       while(key3!=1) display(hr,fen,sec);
      }
   }
  if(key4!=1)
   {
     delay(10);
     if(key4!=1)
       {
         TR0=0;
         sec++;
         if(sec ==60) sec=0;
         while(key4!=1) display(hr,fen,sec);
       }
   }  
}
void beeping()
{
  beep=1;
  if(fen==0 && sec ==0)
   {
     beep=0;
   }
}

一周热门 更多>