亚洲春色中文字幕久久久-三上亚,一吻二脱三床四吻胸,国产真实伦对白视频全集,在线毛片观看,精品成品入口黄网,国产毛aⅴ片久久久,亚洲AV色香蕉一区二区三区老师,萧皇后A级艳片,色情日本视频更新,99久久亚洲精品日本无码

標題: 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.denmoz.com/bbs/) Powered by Discuz! X3.1