单片机节日彩灯实训报告_基于单片机的节日彩灯控制电路与程序设计报告与资料...

#include

#define uchar unsigned char          //宏定义

#define uint unsigned int

sbit k1=P1^2;                  //位定义

sbit k2=P1^3;

sbit k3=P1^4;

sbit k4=P1^5;

uchar a=0;                //定义所需变量

uchar b;

uchar code table1[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};          //从上到下流水数组

uchar code table2[]={0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe};          //从下到上流水数组

void delay_ms(uint xms)                                //延时函数

{

uint i,j;

for(i=xms;i>0;i--)

for(j=110;j>0;j--);

}

void key_scan(uchar b)                                 //按键扫描

{

if(b==1)                                                        //若K1按下

{

while(k2==1&&k3==1&&k4==1)

{

for(a=0;a<8;a++)                   //执行从上到下流水操作

{

P0=table1[a];

delay_ms(100);

}

a=0;

}

}

if(b==2)                                                        //若K2按下

{

while(k1==1&&k3==1&&k4==1)

{                                                                //P0全部输出高电平,关闭LED

P0=0xff;

}

}

if(b==3)                                                        //若K3按下

{

while(k1==1&&k2==1&&k4==1)

{

for(a=0;a<8;a++)                        //执行从下到上流水操作

{

P0=table2[a];

delay_ms(100);

}

a=0;

}

}

if(b==4)                                                        //若K4按下

{

while(k1==1&&k2==1&&k3==1)

{

P0=0xaa;                                        //奇偶位分别点亮

delay_ms(100);

P0=0x55;

delay_ms(100);

}

}

}

void main(void)                                                                //主函数

{

TMOD=0X01;                                                                //定时器中断初始化

TH0=(65536-1000)/256;

TL0=(65536-1000)%256;

EA=1;

ET0=1;

TR0=1;

while(1);

}

……………………

…………限于本文篇幅 余下代码请从51黑下载附件…………

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值