微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > MCU和单片机设计讨论 > 用单片机和1602做万年历的问题

用单片机和1602做万年历的问题

时间:10-02 整理:3721RD 点击:
请问有的月030天和有的月31天还有闰年2月28天该怎么区分呢?我程序写不出来

31天和30天怎么区分的,做个if判断就行了,了解下闰年是怎么回事就ok了。

你做一个闰年判断程序,再用一个switch()……case……语句来判断和给定月份的天数。

if(tian==30)
if(tian==31)
这样?
可是当天数增加的时候,先加到30,之后就要月数要加1了啊,天数清零,没法判断31天啊

switch (mon)
{
case 4:
case 6:
case 9:
case 11:days=30;
break;
case 2: if(year1==0)
        {
                if(year2%4==0)
                days=29;
                else  
                days=28;
        }
        else
        {
                if(year1%4==0)
                days=29;
                else
                days=28;
        }                       
break;
default:days=31;
break;  
}
这是我自己写的一个程序  先判断这个月有多少天(此程序有2月是否是闰年的2月功能  能判定30天和31天的月份)  mon代表月份  days表示这个月的天数   如果到了days+1天   那么使天数清1   然后月份加一  下面的程序你自己写


if(year%4==0) days=29;
else days=28;

忘了告诉你year1 代表年份的后两位   yeaar2代表年份的前两位   如2012年   则year1=12   year2=20

我发觉加一个ds1302好像简单多了

o ,我知道了 ,谢谢


,值得借鉴

#include<reg52.h>
#include<define.h>
void delay(uint z)
{
uint x,y;
for(x=0;x<z;x++)
  for(y=0;y<148;y++);
}
void write_com(uchar com)
{
rs=0;
rw=0;
e=0;
P0=com;
delay(5);
e=1;
delay(5);
e=0;
}
void write_date(uchar date)
{
rs=1;
rw=0;
e=0;
P0=date;
delay(5);
e=1;
delay(5);
e=0;
}
void init()
{
uchar num;
e=0;
nian=0;
yue=1;
tian=1;
week=1;
write_com(0x38);
write_com(0x0c);
write_com(0x06);
write_com(0x01);
write_com(0x80+0x01);
for(num=0;num<14;num++)
{
  write_date(table[num]);
  //delay(20);
}
write_com(0x80+0x44);
for(num=0;num<8;num++)
{
  write_date(table1[num]);
  //delay(20);
}
TMOD=0x01;
TH0=19456/256;
TL0=19456%256;
EA=1;
ET0=1;
TR0=1;
}
void sfm(uchar add,uchar date)
{
uchar shi,ge;
shi=date/10;
ge=date%10;
write_com(0x80+add);
write_date(0x30+shi);
write_date(0x30+ge);
}
void main()
{
init();
while(1)
{
  key();
  if(t==20)
  {
   t=0;
   miao++;
   if(miao==60)
   {
    miao=0;
    fen++;
    if(fen==60)
    {
     fen=0;
     shi++;
     if(shi==24)
     {
      shi=0;
      tian++;
      week++;
      if(week>7)
      {
       week=1;
      }
      switch(week)
      {
       case 1:write_com(0x80+12);write_date('S');write_date('u');write_date('n');break;
       case 2:write_com(0x80+12);write_date('M');write_date('o');write_date('n');break;      
       case 3:write_com(0x80+12);write_date('T');write_date('u');write_date('e');break;
       case 4:write_com(0x80+12);write_date('W');write_date('e');write_date('d');break;
       case 5:write_com(0x80+12);write_date('T');write_date('h');write_date('u');break;
       case 6:write_com(0x80+12);write_date('F');write_date('r');write_date('i');break;
       case 7:write_com(0x80+12);write_date('S');write_date('a');write_date('t');break;
      }
      if((yue==1)||(yue==3)||(yue==5)||(yue==7)||(yue==8)||(yue==10)||(yue==12))
      {
       day=31;
      }
      if((yue==4)||(yue==6)||(yue==9)||(yue==11))
      {
       day=30;
      }
      if(yue==2)
      {
       if((nian%4==0)||(nian==0))
       {
        day=29;
       }
       else
       {
        day=28;
       }
      }
      if(tian>day)
      {
       tian=1;
       yue++;
       if(yue>12)
       {
        yue=1;
        nian++;
        if(nian>99)
        {
         nian=0;
        }
        sfm(3,nian);
       }
       sfm(6,yue);
      }
      sfm(9,tian);
     }
     sfm(0x44+0,shi);
    }
    sfm(0x44+3,fen);
   }
   sfm(0x44+6,miao);
  }
}
}
void time0() interrupt 1
{
TH0=19456/256;
TL0=19456%256;
t++;
}
这是我自己写的,没注释···

高手

上原理图呀    很好   !思想很好,值得学习!

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top