LED点阵汉字显示移动程序

LED点阵汉字显示移动程序,第1张

程序看来p2口是用来控制点阵行扫描的,p1口负责送显示的数据

p2=0x01

//起始行高电平

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

//循环点亮8行,循环送8次数据

{

p1=tab[i]

delay(100)

//每行点亮时送上相应的显示数据(即tab[i]里的数据)

p2=p2<扒州源<1|p2>>7

//

点亮下一行

其实点阵显示就是:(针对16*16点阵显示一个汉字)

静止的春态显示就是扫第一行时送汉字的第一行,扫第二行时送汉字的第二行...扫第16行时送汉字的第16行,这叫第一帧扫完。如果想让字动那么扫第二帧时,行扫描第一行时,送汉字的第二行数据,行扫描第二行时,送汉字的第三行数据...就这样错开一行,再下一帧时再错开一行,直至错开迹简16次一个完整的字就上移至上面了。

总的说来就是一帧一帧的显示,每帧显示汉字的一个画面,重叠在一起就看见字在动了。

点阵原理就是一个LED的两端都接IO,当正极为1,负极为0时点亮相应的LED。

下面是8×8的LED点阵程序,参考一下吧

#include<reg51.h>

#define uchar unsigned char

#define 弊枝扮uint unsigned 搭察int

uchar code TAB[]={

0X00,0X00,0X00,0X00,0X00,0X00,0X00,0X00,

0x00,0x82,0xFE,0x82,0x80,0xC0,0x00,0x00,

0x00,0x7C,0x82,0x82,0x82,0x7C,0x00,0x00,

0x02,0x0E,0x72,0x80,0x70,0x0E,0x02,0x00,

0x00,0x82,0xFE,0x92,0xBA,0x82,0xC6,0x00,

0X00,0X00,0X00,0X00,0X00,0X00,0X00,0X00

}

/*delay(uint t)

{

uint a,b

for(a=0a<ta++)

for(b=0b<110b++)

} */

void main(void)

{

uint i,j,xx

uchar bittemp=0x01

while(1)

{

for(i=0i<40i++)

{

for(xx=0xx<500xx++)

{

bittemp=0x80

for(j=0j<8j++)

{

P2=0x00 //消隐

P0= ~TAB[i+8-j]

P2 = bittemp

bittemp 租灶>>= 1

}

}

}

}

}

这程序写得真烂,滚茄察完全不是工程上写的那些程序。

这个只是那种不入流的或者看教科书自学成才的人写的程序,懒得注释。

你连模仿的对象都这么差,你以后写出来的程序会更差

随便贴一段我们以前写的代码,当然有些是宏,只是摘个片段给你看,真纳亮正的程序是这样写的,不是书上的ijk,名字也不是乱取的,程序写出来是给人看的,只要你语法和逻辑对,机器都能大茄编译,但是维护的人可要头大了

void HT1632_Initial_Command(char by_Mode)

{

HT1632_Write_Command(SYS_EN)

HT1632_Write_Command(LED_ON)

HT1632_Write_Command(RC_256K)

if(by_Mode==8)

HT1632_Write_Command(COMMONS_8N)

else

HT1632_Write_Command(COMMONS_16N)

HT1632_Write_Command(PWM_DUTY_13_16)

}

void HT1632_Set_IO_WR(char by_Addr,char by_Bit)

{

HT1632_Cul_IO_Address(by_Addr,ADR_WR,by_Bit)

IO_Set_Output_HT1632_WR()

by_Status |= (1 <<ADR_WR)

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/12438024.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-23
下一篇2023-05-23

发表评论

登录后才能评论

评论列表(0条)

    保存