标题: 4个8*8LED点阵合并成一个16*16LED点阵 [打印本页]

作者: 蒋瑞康    时间: 2017-9-28 13:29
标题: 4个8*8LED点阵合并成一个16*16LED点阵
这是我经过网上资料视频的总结以及自己的实践做出来的
四个点阵通过四个74HC595芯片进行连接 简单易懂也容易操作
希望能给大家一点帮助
/**************************************************************************************
*                              单片机IO扩展--74HC595实验                                                                                                  *
实现现象:下载程序后,LED灯从左往右点亮,类似流水灯效果

                       
注意事项:必须将74HC595模块的JP595短接片短接,否则不会出现现象                                                                                                                                                                  
***************************************************************************************/

#include "reg51.h"                         //此文件中定义了单片机的一些特殊功能寄存器
#include "intrins.h"

typedef unsigned int u16;          //对数据类型进行声明定义
typedef unsigned char u8;


//--定义使用的IO口--//
sbit SRCLK=P3^2;
sbit RCLK=P3^5;
sbit SER=P3^4;
/*u8 code ledwei[]={
0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,
0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe,
};*/
u8 code ledwei[]={
0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe,
0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,

};
u8 code ledduan[]={
0x00,0x00,0xC0,0x26,0x90,0xCA,0x6C,0x08,0x08,0x6C,0xCA,0x90,0x26,0xC0,0x00,0x00,
0x00,0x00,0x0F,0x10,0x20,0x44,0x49,0x48,0x48,0x49,0x44,0x60,0x30,0x0F,0x00,0x00,                   //镜像取模

};

void delay(u16 i)
{
        while(i--);       
}


void Hc595SendByte(u8 dat1,u8 dat2,u8 dat3,u8 dat4 )
{
        u8 a;
                SRCLK = 1;
                RCLK = 1;
                                                                                               
                for(a=0;a<8;a++)                 //发送8位数
                {
                        SER = dat1 >> 7;                 //从最高位开始发送
                        dat1 <<= 1;
                                                                                               
                        SRCLK = 0;                         //发送时序
                        _nop_();
                    _nop_();
                        SRCLK = 1;       
                                                }
                 for(a=0;a<8;a++)                 //发送8位数
                {
                        SER = dat2 >> 7;                 //从最高位开始发送
                        dat2 <<= 1;
                                                                                               
                        SRCLK = 0;                         //发送时序
                        _nop_();
                    _nop_();
                        SRCLK = 1;       
                                                }
                    for(a=0;a<8;a++)                 //发送8位数
                {
                        SER = dat3 >> 7;                 //从最高位开始发送
                        dat3 <<= 1;
                                                                                               
                        SRCLK = 0;                         //发送时序
                        _nop_();
                    _nop_();
                        SRCLK = 1;       
                                                }
          for(a=0;a<8;a++)                 //发送8位数
                {
                        SER = dat4 >> 7;                 //从最高位开始发送
                        dat4 <<= 1;
                                                                                               
                        SRCLK = 0;                         //发送时序
                        _nop_();
                    _nop_();
                        SRCLK = 1;       
                                                }
         
                                               
                        RCLK = 0;
                        _nop_();
                        _nop_();
                        RCLK = 1;
}




void main()
{       
        u8 i ;
        while(1)
        {       
          
                for(i=0;i<16;i++)
        {
                Hc595SendByte(ledwei[i+16],ledwei[i],ledduan[i+16],ledduan[i]);
                  
                delay(10);
                                  }               
}

                                  }


新建 Microsoft Word 文档.docx

50.71 KB, 下载次数: 21, 下载积分: 黑币 -5


作者: 电子FSY    时间: 2017-10-20 08:56
非常好,谢谢分享




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1