700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > c语言点阵式注释语句 LED点阵显示与C语言编程(基础篇)_希希_百度空间

c语言点阵式注释语句 LED点阵显示与C语言编程(基础篇)_希希_百度空间

时间:2021-10-04 02:17:56

相关推荐

c语言点阵式注释语句 LED点阵显示与C语言编程(基础篇)_希希_百度空间

图2 图3

void main(void)

{

while(1)

{

P2=0x01;

for(i=0;i<8;i++)

{

P1=TAB[i];

delay(100);

P2=P2<<1|P2>>7;

}

}

}

uchar code TAB[]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏

0xFD,0xFD,0xFD,0xFD,0xFD,0xFD,0xC1,0xFF, //L

0xE3,0xDD,0xDD,0xDD,0xDD,0xDD,0xE3,0xFF, //O

0xDD,0xDD,0xDD,0xDD,0xDD,0xEB,0xF7,0xFF, //V

0xC1,0xFD,0xFD,0xC1,0xFD,0xFD,0xC1,0xFF, //E

0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏

};

uchar i,t;

void main(void)

{ uchar N,T;

while(1)

{

for(N=0;N<6;N++) //循环扫描一遍6帧

for(T=0;T<100;T++) //速度

{

P2=0x01;

for(i=0;i<8;i++)

{

P1=TAB[i+8*N];

delay(100);

P2=P2<<1|P2>>7;

}

}

}

}

图4 图5 图6

uchar code TAB[]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏

0xFD,0xFD,0xFD,0xFD,0xFD,0xFD,0xC1,0xFF, //L

0xE3,0xDD,0xDD,0xDD,0xDD,0xDD,0xE3,0xFF, //O

0xDD,0xDD,0xDD,0xDD,0xDD,0xEB,0xF7,0xFF, //V

0xC1,0xFD,0xFD,0xC1,0xFD,0xFD,0xC1,0xFF, //E

0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏

};

uchar i,t;

void main(void)

{ uchar N,T;

while(1)

{

for(N=0;N<40;N++) //循环扫描一遍40帧

for(T=0;T<60;T++) //移动速度

{

P2=0x01;

for(i=0;i<8;i++)

{

P1=TAB[i+N];

delay(100);

P2=P2<<1|P2>>7;

}

}

}

}

uchar code TAB[]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏

0xFD,0xFD,0xFD,0xFD,0xFD,0xFD,0xC1,0xFF, //L

0xE3,0xDD,0xDD,0xDD,0xDD,0xDD,0xE3,0xFF, //O

0xDD,0xDD,0xDD,0xDD,0xDD,0xEB,0xF7,0xFF, //V

0xC1,0xFD,0xFD,0xC1,0xFD,0xFD,0xC1,0xFF, //E

0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏

};

void main(void)

{

uchar N,T,m,n;

for(m=0;m<6;m++)

for(n=0;n<8;n++)

Buffer[8*m+n]=TAB[7-n+m*8]; //将TAB数组中的数据重新排列

//使得下移字母顺序不变

while(1)

{

for(N=0;N<40;N++) //循环扫描一遍6帧

for(T=0;T<70;T++) //速度

{

P2=0x80;

for(i=0;i<8;i++)

{

P1=Buffer[i+N];

delay(100);

P2=P2>>1|P2<<7; //扫描起始行为{dy}行

}

}

}

}

如果将扫描方式改为列扫描,那么左右移动的程序就容易写了,但当点阵比较巨大并且硬件已经定下时,改变扫描方式不是好方法,甚至不可能实现。这里是以行扫描为例(逐行取字模),{dy}次取字码数组中的第1~8个数据到点阵列输入端,行码 扫描1~8行。第二次将{dy}次的 1~8个数据都循环左(右)移一位,并且将第9个数据的{zg}位移到第二次数据的{zd1}处,再输入到列端口,行扫描1~8行。即每次扫描都要把前一次扫描的列码左移一位。

图7 图8

void main(void)

{ uchar T,Y,Q;

while(1)

{

for(Q=0;Q<8;Q++)

for(T=0;T<100;T++) //速度

{

P2=0x01;

for(i=0;i<8;i++)

{

Y=TAB[i+1]*256+TAB[i];

Y=Y<>Q;

P1=Y%256;

delay(60);

P2=P2<<1|P2>>7;

}

}

}

}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。