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

【更多帮助:】

点阵的接法有共阴和共阳两种(共阳指的是对每一行LED来讲是共阳)。

由于51单片机驱动能力有限,亮度不够,所以一般需要三极管驱动,下图为一个8X8点阵原理图,仅仅是仿真,如果需要接实物的话,加上三极管才足够亮。

显示的方法有两种:
1、逐列扫描方式。如下图所示,P1口输出列码决定哪一列能亮(相当于位码),P2口输出行码(列数据)决定列上哪些LED亮(相当于段码),能亮的列从左向右扫描完8列(相当于位码循环移位8次)即显示出一帧完整的图像。
2、逐行扫描方式,与逐列扫描调换,即P2口输出位码,P1口输出段码,扫描完8行显示出一帧图像。

                                     图1
                   
                     图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<<(7-Q)|Y>>Q;
    P1=Y%256;
    delay(60);
    P2=P2<<1|P2>>7;
       }
    }
}
}


郑重声明:资讯 【LED点阵显示与C语言编程(基础篇)_希希_百度空间】由 发布,版权归原作者及其所在单位,其原创性以及文中陈述文字和内容未经(企业库qiyeku.com)证实,请读者仅作参考,并请自行核实相关内容。若本文有侵犯到您的版权, 请你提供相关证明及申请并与我们联系(qiyeku # qq.com)或【在线投诉】,我们审核后将会尽快处理。
—— 相关资讯 ——