2 qq 24163555 qq_24163555 于 2016.04.13 09:30 提问

求两块74hc595驱动4个8乘以8的led点阵的程序详解及原理 1C

#include

//--重定义函数变量--//
#define uchar unsigned char
#define uint unsigned int
#define ulong unsigned long

//--定义SPI要使用的 IO--//
sbit MOSIO = P3^4;
sbit R_CLK = P3^5;
sbit S_CLK = P3^6;

//---全局变量声明--//
ulong column; //点阵列
ulong row; //点阵行
ulong dt;

//--点阵显示数组--//
uchar code tab0[] =
{0x00, 0x01, 0x00, 0x02, 0x00, 0x04, 0x00, 0x08,
0x00, 0x10, 0x00, 0x20, 0x00, 0x40, 0x00, 0x80,
0x01, 0x00, 0x02, 0x00, 0x04, 0x00, 0x08, 0x00,
0x10, 0x00, 0x20, 0x00, 0x40, 0x00, 0x80, 0x00};

//--10字模--//
uchar code tab1[] =
{0, 0, 0, 0, 0, 0, 8, 24, 14, 36, 8, 66, 8, 66, 8, 66,
8, 66, 8, 66, 8, 66, 8, 36, 62, 24, 0, 0, 0, 0, 0, 0};

//--09字模--//
uchar code tab2[] =
{0, 0, 0, 0, 0, 0, 24, 24, 36, 36, 66, 66, 66, 66, 66,
66, 66, 100, 66, 88, 66, 64, 66, 64, 36, 36, 24, 28, 0, 0, 0, 0} ;

//--08字模--//
uchar code tab3[] =
{0, 0, 0, 0, 0, 0, 24, 60, 36, 66, 66, 66, 66, 66, 66, 36,
66, 24, 66, 36, 66, 66, 66, 66, 36, 66, 24, 60, 0, 0, 0, 0};

//--07字模--//
uchar code tab4[] =
{0, 0, 0, 0, 0, 0, 24, 126, 36, 34, 66, 34, 66, 16, 66, 16,
66, 8, 66, 8, 66, 8, 66, 8, 36, 8, 24, 8, 0, 0, 0, 0};

//--06字模--//
uchar code tab5[] =
{0, 0, 0, 0, 0, 0, 24, 56, 36, 36, 66, 2, 66, 2, 66, 26, 66,
38, 66, 66, 66, 66, 66, 66, 36, 36, 24, 24, 0, 0, 0, 0};

//--05字模--//
uchar code tab6[] =
{0, 0, 0, 0, 0, 0, 24, 126, 36, 2, 66, 2, 66, 2, 66, 26, 66,
38, 66, 64, 66, 64, 66, 66, 36, 34, 24, 28, 0, 0, 0, 0};

//--04字模--//
uchar code tab7[] =
{0, 0, 0, 0, 0, 0, 24, 32, 36, 48, 66, 40, 66, 36, 66, 36, 66,
34, 66, 34, 66, 126, 66, 32, 36, 32, 24, 120, 0, 0, 0, 0};

//--03字模--//
uchar code tab8[] =
{0, 0, 0, 0, 0, 0, 24, 60, 36, 66, 66, 66, 66, 32, 66, 24, 66,
32, 66, 64, 66, 64, 66, 66, 36, 34, 24, 28, 0, 0, 0, 0};

//--02字模--//
uchar code tab9[] =
{0, 0, 0, 0, 0, 0, 24, 60, 36, 66, 66, 66, 66, 66, 66, 32, 66,
32, 66, 16, 66, 8, 66, 4, 36, 66, 24, 126, 0, 0, 0, 0};

//--01字模--//
uchar code tab10[] =
{0, 0, 0, 0, 0, 0, 24, 8, 36, 14, 66, 8, 66, 8, 66, 8, 66, 8, 66,
8, 66, 8, 66, 8, 36, 8, 24, 62, 0, 0, 0, 0};

//--00字模--//
uchar code tab11[] =
{0, 0, 0, 0, 0, 0, 24, 24, 36, 36, 66, 66, 66, 66, 66, 66, 66, 66,
66, 66, 66, 66, 66, 66, 36, 36, 24, 24, 0, 0, 0, 0};

//--GO--//
uchar code tab12[] =
{0, 0, 0, 0, 0, 0, 60, 28, 34, 34, 34, 65, 1, 65, 1, 65, 1, 65, 113,
65, 33, 65, 34, 65, 34, 34, 28, 28, 0, 0, 0, 0};

//--全局函数声明--//
void HC595SendData( uchar BT3, uchar BT2,uchar BT1,uchar BT0);

/*******************************************************************************

  • 函 数 名 : main
  • 函数功能 : 主函数
  • 输 入 : 无
  • 输 出 : 无 *******************************************************************************/

void main(void)
{
int k, i, ms;

i = 60;                 //显示时间                                   

while(1)
{
    //--显示10--//
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                                     
        {    
        HC595SendData(~tab1[2*k +1],~tab1[2*k],tab0[2*k],tab0[2*k + 1]);
        }        
    }

    //--清屏--//
    HC595SendData(0xff,0xff,0,0);                                                                       

    //--显示09--//
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                                             
        {    
            HC595SendData(~tab2[2*k +1],~tab2[2*k],tab0[2*k],tab0[2*k + 1]);         
        }
    }

    //--清屏--//
    HC595SendData(0xff,0xff,0,0);                                       

    //--显示08--//
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                                             
        {    
            HC595SendData(~tab3[2*k +1],~tab3[2*k],tab0[2*k],tab0[2*k + 1]);         
        }
    }

    //--清屏--//  
    HC595SendData(0xff,0xff,0,0);   

    //--显示07--//
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                     
        {    
            HC595SendData(~tab4[2*k +1],~tab4[2*k],tab0[2*k],tab0[2*k + 1]);         
        }
    }

    //--清屏--//  
    HC595SendData(0xff,0xff,0,0);                                           

    //--显示06--//
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                                             
        {    
            HC595SendData(~tab5[2*k +1],~tab5[2*k],tab0[2*k],tab0[2*k + 1]);         
        }
    }

    //--清屏--//  
    HC595SendData(0xff,0xff,0,0);                                           

    //--显示05--//
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                                             //欢
        {    
            HC595SendData(~tab6[2*k +1],~tab6[2*k],tab0[2*k],tab0[2*k + 1]);         
        }
    }

    //--清屏--//  
    HC595SendData(0xff,0xff,0,0);                           

    //--显示04--//
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                         
        {    
            HC595SendData(~tab7[2*k +1],~tab7[2*k],tab0[2*k],tab0[2*k + 1]);         
        }
    }

    //--清屏--//  
    HC595SendData(0xff,0xff,0,0);                       

    //--显示03--//
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                         
        {    
            HC595SendData(~tab8[2*k +1],~tab8[2*k],tab0[2*k],tab0[2*k + 1]);         
        }
    }

    //--清屏--//  
    HC595SendData(0xff,0xff,0,0);                               

    //--显示02--//    
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                     
        {    
            HC595SendData(~tab9[2*k +1],~tab9[2*k],tab0[2*k],tab0[2*k + 1]);         
        }
    }

    //--清屏--//  
    HC595SendData(0xff,0xff,0,0);                                   

    //--显示01--//
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                             
        {    
            HC595SendData(~tab10[2*k +1],~tab10[2*k],tab0[2*k],tab0[2*k + 1]);       
        }
    }

    //--清屏--//  
    HC595SendData(0xff,0xff,0,0);                                       

    //--显示00--//
    for(ms = i; ms > 0; ms--)
    {
        for(k = 0; k < 16; k++)                         
        {    
            HC595SendData(~tab11[2*k +1],~tab11[2*k],tab0[2*k],tab0[2*k + 1]);       
        }
    }
    //--清屏--//  
    HC595SendData(0xff,0xff,0,0);                                         //清屏

    //--一直显示G0--//
    while(1)
    {
        for(k = 0; k < 16; k++)                                             //中
        {    
            HC595SendData(~tab12[2*k +1],~tab12[2*k],tab0[2*k],tab0[2*k + 1]);       
        }               
    }                                       
}

}
/*******************************************************************************

  • 函 数 名 : HC595SendData
  • 函数功能 : 通过595发送四个字节的数据
  • 输 入 : BT3:第四个595输出数值
  • * BT2: 第三个595输出数值
  • * BT1:第二个595输出数值
  • * BT0:第一个595输出数值
  • 输 出 : 无 *******************************************************************************/

void HC595SendData( uchar BT3, uchar BT2,uchar BT1,uchar BT0)
{

uchar i;

//--发送第一个字节--//
for(i=0;i<8;i++)
{
    MOSIO = BT3 >> 7 ;  //从高位到低位
    BT3 <<= 1;

    S_CLK = 0;
    S_CLK = 1;      
}

//--发送第一个字节--//
for(i=0;i<8;i++)
{
    MOSIO = BT2 >>7;        //从高位到低位
    BT2 <<= 1;

    S_CLK = 0;
    S_CLK = 1;  
}

//--发送第一个字节--//
for(i=0;i<8;i++)
{
    MOSIO = BT1 >> 7;       //从高位到低位
    BT1 <<= 1;
    S_CLK = 0;
    S_CLK = 1;  
}

//--发送第一个字节--//
for(i=0;i<8;i++)
{
    MOSIO = BT0 >> 7;       //从高位到低位
    BT0 <<= 1;
    S_CLK = 0;
    S_CLK = 1;
}

//--输出--//
R_CLK = 0; //set dataline low
R_CLK = 1; //片选
R_CLK = 0; //set dataline low

}

顺便帮忙解释一下这个程序

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
基于74hc595和74hc138的点阵原理图及程序
基于74hc595和74hc138的点阵原理图及程序
继续树莓派GPIO:两片74HC595控制一个8x8LED点阵显示爱心
88LED点阵显示爱心图案
用 74hc138 和 74hc595 驱动 8x8 点阵显示
用STC89C52,74hc138驱动列,74hc595驱动行,8x8点阵显示问题。想显示箭头,......。悬赏分:30       解决时间:2010-12-10 08:58//=============================================最佳答案:题目给出的程序基本结构是正确的,稍有瑕疵,HC138的使能没有打开,关键是消隐做的不够好,导致余辉重叠,显示比较模糊。
74HC595驱动LED点阵或数码管的正确用法
这几天有些时间想做LED点阵玩玩,所以需要学习74HC595芯片,上网找了几个例程和关于74HC595的几篇应用,照猫画虎实际操作一下,哪知根本不可行,教程都是错误的。 于是自己潜心研究了 4天,现在已经可以对74HC595随心所欲的控制了,因此可以下结论了,网上关于74HC595的用法资料绝大多都是错的,误导严重。 网上最误导人的3个错误观点: 1、连续给8个SCK(11脚),最后给1个L
74hc595驱动8x8点阵
经典74hc595驱动8x8点阵,参考单片机技术
STM32 控制74HC595 驱动点阵 文字能移动
遇到了很奇怪的问题,程序明明没错但就是不显示,最后把在main函数中定义的变量count移动到main 外面就正常了 。仿真后发现,在main 函数中定义的局部变量 初始值不为0 ,超出控制范围 , 导致程序跑飞。按理说keil 定义变量默认初始化为0才对 。最后将定义count初始化为0,程序正常运行。下次定义变量一定要初始化啊!!! 在单步调试中,发现这个问题。不得不说一下,keil 在线仿
74HC595在【8x8LED点阵】中的使用
前几天学了点阵的显示,今天按自己的思路来总结一下。首先介绍一下点阵的显示原理。点阵的电路图和之前学过的矩阵按键的电路图是相似的。每个灯就相当于坐标图中的一个点,具有唯一独特的坐标位置,这样就可以通过引脚的信号来控制每个灯的关和开col管脚连接的是P0的八个引脚,row管脚连接的是595的八位并行输出端。实验中采取的是逐列显示,通过P0控制八列每列逐列显示,其间通过595位移缓存器控制每列要亮的le...
STM32 MAX7219驱动的8*8 LED点阵 填坑
STM32驱动8*8的点阵,按照之前的接法试验了很多次,依然还是调不通。已经意识到可能是延时的问题了,在初始化函数中加了延时,在写数据的函数中加了延时,还是搞不定。其实最后解决的方法也挺简单的,只不过自己没经验罢了。开始填坑! 解决方法:在main函数中,一步一步的进行函数初始化,在进行MAX7219初始化之前加一个50MS的延时,竟然正常工作了,真的是坑,哈哈哈。自己虽菜,但是最终解决了问题,
LED 四个8x8 组合 16X16点阵移位分析
-
树莓派研究:用Java实现Max7219 LED点阵的输出
入手了一个Raspberry Pi 3,同时配了一个微雪的RPi LED Matrix。所以,抽空研究一下如何在这个LED上显示点东西。