旋转时钟原理和程序 - 图文(4)

2019-01-12 14:37

0x00,0x00,0x0c,0x00,0x1c,0x00,0x34,0x00, // -4- 0x64,0x40,0xff,0xc0,0xff,0xc0,0x04,0x40, 0x00,0x00,0xf8,0x80,0xf8,0xc0,0x88,0x40, // -5- 0x88,0x40,0x8c,0x40,0x8f,0xc0,0x87,0x80, 0x00,0x00,0x3f,0x80,0x7f,0xc0,0xc8,0x40, // -6- 0x88,0x40,0x88,0x40,0x0f,0xc0,0x07,0x80, 0x00,0x00,0xc0,0x00,0xc0,0x00,0x83,0xc0, // -7- 0x87,0xc0,0x8c,0x00,0xf8,0x00,0xf0,0x00, 0x00,0x00,0x77,0x80,0xff,0xc0,0x88,0x40, // -8- 0x88,0x40,0x88,0x40,0xff,0xc0,0x77,0x80, 0x00,0x00,0x70,0x00,0xf8,0x40,0x88,0x40, // -9- 0x88,0x40,0x88,0xc0,0xff,0x80,0x7f,0x00, 0x00,0x00,0x00,0xc0,0x01,0x80,0x03,0x00, // -/- 0x06,0x00,0x0c,0x00,0x18,0x00,0x30,0x00, };

unsigned char code HZ_12[] = {

0x80,0x00,0x88,0x1F,0x30,0x48,0x00,0x24, //\调\ 0xF0,0x1F,0x10,0x01,0x50,0x1D,0xF0,0x15, 0x50,0x1D,0x10,0x41,0xF8,0x7F,0x10,0x00, 0x00,0x02,0x00,0x41,0x80,0x41,0x60,0x31, //\分\ 0x18,0x0F,0x00,0x01,0x00,0x21,0x38,0x41, 0x40,0x3F,0x80,0x00,0x00,0x01,0x00,0x01, 0xE0,0x1F,0x20,0x09,0x20,0x09,0x20,0x09, //\时\ 0xE0,0x1F,0x40,0x00,0x40,0x01,0x40,0x26, 0x40,0x40,0xF8,0x7F,0x40,0x00,0x40,0x00, 0x00,0x00,0x00,0x00,0x00,0x00,0xF0,0x3F, //\日\ 0x10,0x11,0x10,0x11,0x10,0x11,0x10,0x11, 0x10,0x11,0xF8,0x3F,0x10,0x00,0x00,0x00, 0x00,0x40,0x00,0x20,0x00,0x10,0xF8,0x0F, //\月\ 0x48,0x02,0x48,0x02,0x48,0x22,0x48,0x42, 0x48,0x42,0xF8,0x3F,0x00,0x00,0x00,0x00,

0x80,0x04,0x40,0x04,0x20,0x04,0x98,0x07, //\年\ 0x90,0x04,0x90,0x04,0xF0,0x7F,0x90,0x04, 0x90,0x04,0x98,0x04,0x90,0x04,0x10,0x04 };

unsigned int disp1,disp2,key1,key2,key; unsigned int ii,jj;

unsigned int i,w,n,xz,CM,TZ,BZ; void Delay(unsigned int ms){ ms=ms*3; while(--ms); }

void num_led(int aa, int bb) { int kk;

for(kk=0;kk<8;kk++){ gate11=key1; gate12=key2;

P2=~NUM1[aa+kk*2];P1=~NUM1[aa+1+kk*2]; Delay(20); P1=0xff;P2=0xff;

gate11=key2; gate12=key1;

P2=~NUM2[bb+15-kk*2];P1=~NUM2[bb+14-kk*2]; Delay(20); P1=0xff;P2=0xff; } }

void display_clock(void) {

key1=key;key2=!key;

disp1=BUFFER[3]/10;disp2=BUFFER[4]-(BUFFER[4]/10)*10; ii=disp1*16;jj=disp2*16; num_led(ii,jj);

P2=0xff;P1=0xff;Delay(60);

disp1=BUFFER[3]-disp1*10;disp2=BUFFER[4]/10; ii=disp1*16;jj=disp2*16; num_led(ii,jj);

P2=0xff;P1=0xff;Delay(60);

ii=160;jj=160; num_led(ii,jj);

P2=0xff;P1=0xff;Delay(60);

disp1=BUFFER[2]/10;disp2=BUFFER[5]-(BUFFER[5]/10)*10; ii=disp1*16;jj=disp2*16; num_led(ii,jj);

P2=0xff;P1=0xff;Delay(60);

disp1=BUFFER[2]-disp1*10;disp2=BUFFER[5]/10; ii=disp1*16;jj=disp2*16; num_led(ii,jj);

P2=0xff;P1=0xff;Delay(60); ii=160;jj=160; num_led(ii,jj);

P2=0xff;P1=0xff;Delay(60);

disp1=BUFFER[1]/10;disp2=BUFFER[6]-(BUFFER[6]/10)*10; ii=disp1*16;jj=disp2*16; num_led(ii,jj);

P2=0xff;P1=0xff;Delay(60);

disp1=BUFFER[1]-disp1*10;disp2=BUFFER[6]/10; ii=disp1*16;jj=disp2*16; num_led(ii,jj);

P2=0xff;P1=0xff;Delay(60); }

void display_TZ(void) {

gate11=key;gate12=!key; for(jj=0;jj<16;jj++){ P2=0xff;P1=0xff; Delay(40); }

for(jj=0;jj<12;jj++){

P2=~HZ_12[jj*2];P1=~HZ_12[1+jj*2]; Delay(40); P1=0xff;P2=0xff; }

for(jj=0;jj<12;jj++){

P2=~HZ_12[TZ*24+jj*2];P1=~HZ_12[TZ*24+1+jj*2]; Delay(40); P1=0xff;P2=0xff; }

for(jj=0;jj<8;jj++){

P2=~NUM1[160+jj*2];P1=~NUM1[160+1+jj*2]; Delay(40); P1=0xff;P2=0xff; }

disp1=BUFFER[TZ+1]/10; for(jj=0;jj<8;jj++){

P2=~NUM1[disp1*16+jj*2];P1=~NUM1[disp1*16+1+jj*2]; Delay(40); P2=0xff;P1=0xff; }

Delay(60);

disp1=BUFFER[TZ+1]-disp1*10; for(jj=0;jj<8;jj++){

P2=~NUM1[disp1*16+jj*2];P1=~NUM1[disp1*16+1+jj*2]; Delay(40); P2=0xff;P1=0xff; }

Delay(60); }

void intersvr0(void) interrupt 0 {

key=!key; if(w==0) w=1; }

void intersvr1(void) interrupt 2 {

TH1=0; TL1=0; }

void timer1(void) interrupt 3 using 1 { }

void timer0(void) interrupt 1 using 1 {

TH0=-(5000/256); TL0=-(5000%6); TR0=1;

BUFFER[0]=BUFFER[0]+1;

if (BUFFER[6]%4==0) M[1]=M[1]+1; if (BUFFER[0]>201+xz){ BUFFER[0]=0;

BUFFER[1]=BUFFER[1]+1; if (BUFFER[1]==60){ BUFFER[1]=0;

BUFFER[2]=BUFFER[2]+1; if (BUFFER[2]==60){ BUFFER[2]=0;

BUFFER[3]=BUFFER[3]+1; if (BUFFER[3]==24){ BUFFER[3]=0;

BUFFER[4]=BUFFER[4]+1;

if (BUFFER[4]>M[BUFFER[5]-1]){ BUFFER[4]=1;

BUFFER[5]=BUFFER[5]+1; if (BUFFER[5]>12){ BUFFER[5]=1;

BUFFER[6]=BUFFER[6]+1; if(BUFFER[6]>99) { BUFFER[6]=0;

M[1]=M[1]-1; }

} } } } } } }

void Jm(void) {

unsigned int kk,mm; CM=0x00;

for(kk=0;kk<30;kk++){ mm=0;

while((P3&0x80)==0x00){}; while((P3&0x80)==0x80){mm++;};

if((mm>350)&&(mm<100)){CM=0x00; break;}; yy[kk]=mm;


旋转时钟原理和程序 - 图文(4).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:《国际经贸地理》教学大纲

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: