
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)
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)