流水灯实验
#include <reg52.h>
#include <iostream>
void delay(unsigned int cnt)
{
while(--cnt);
}
main()
{
unsigned char i;
P2=~0x01;
while(1)
{
for (i=0;i<=7;i++)
{
delay(30000);
P2<<=1;
P2|=0x01;
}
P2=0x7f;
for (i=0;i<=7;i++)
{
delay(30000);
P2>>=1;
P2|=0x80;
}
P2=~0x01;
}
}
综合性实验
#include "reg52.h"
typedef unsigned int u16;
typedef unsigned char u8;
#define GPIO_DIG P2
#define GPIO_KEY P1
u8 code smgduan[17]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
u8 n=0;
u8 n1=0;
unsigned char second=0;
unsigned char fen=0;
unsigned char hour=0;
sbit k3=P3^2;
int flag = 0;
sbit LSA=P3^5;
sbit LSB=P3^6;
sbit LSC=P3^7;
u8 KeyValue;
void delay(u16 i)
{
while(i--);
}
void choose(int i, int num)
{
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=smgduan[num];
delay(50);
P0=0x00;
}
void KeyDown(void)
{
char a=0;
GPIO_KEY=0x0f;
if(GPIO_KEY!=0x0f)
{
delay(1000);
if(GPIO_KEY!=0x0f)
{
GPIO_KEY=0X0F;
switch(GPIO_KEY)
{
case(0X07): KeyValue=0;break;
case(0X0b): KeyValue=1;break;
case(0X0d): KeyValue=2;break;
case(0X0e): KeyValue=3;break;
}
GPIO_KEY=0XF0;
switch(GPIO_KEY)
{
case(0X70): KeyValue=KeyValue;break;
case(0Xb0): KeyValue=KeyValue+4;break;
case(0Xd0): KeyValue=KeyValue+8;break;
case(0Xe0): KeyValue=KeyValue+12;break;
}
}
}
while((a<50)&&(GPIO_KEY!=0xf0))
{
a++;
}
}
void Int0Init()
{
IT0=1;
EX0=1;
EA=1;
}
void Timer1Init()
{
TMOD|=0X10;
TH1=0XFC;
TL1=0X18;
TH0=0XF3;
TL0=0XF3;
ET1=1;
EA=1;
TR1=1;
ES=1;
TR0=1;
}
void main()
{
Int0Init();
Timer1Init();
while(1)
{
choose(0, hour/10);
choose(1, hour%10);
choose(2, fen/10);
choose(3, fen%10);
choose(4, second/10);
choose(5, second%10);
KeyDown();
GPIO_DIG=~smgduan[KeyValue];
}
}
void Int0() interrupt 0
{
delay(1000);
if(k3==0)
{
if(flag == 0)
{
flag = 1;
}
else
{
flag = 0;
}
}
}
void Timer1() interrupt 3
{
static u16 i;
TH1=0XFC;
TL1=0X18;
i++;
if(flag == 1)
{
if(i>1000)
{
i=0;
second++;
if(second>=60)
{
second=0;
fen++;
if (fen>=60)
{
fen=0;
hour++;
if (fen>=60)
{
hour = 0;
}
}
}
n++;
if(n==9)
{
}
}
}
}
void Usart() interrupt 1
{
u8 receiveData;
receiveData=SBUF;
RI = 0;
SBUF=receiveData;
while(!TI);
TI=0;
}