C51之74HC595的使用

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/plm199513100/article/details/79656920

/*
名称:74HC595的使用
说明:74HC595是一个8位串行输入、并行输出的位移缓存器:并行输出为三态输出。在SCK 的上升沿,串行数据由SDL输入到内部的8位位移缓存器,并由Q7’输出,而并行输出则是在LCK的上升沿将在8位位移缓存器的数据存人到8位并行输出缓存器。当串行数据输入端OE的控制信号为低使能时,并行输出端的输出值等于并行输出缓存器所存储的值。而当OE为高电位,也就是输出关闭时,并行输出端会维持在高阻抗状态。

这里需要注意一点的就是,在芯片需要产生上升沿或者下降沿的时候:本质上就是将其对应引脚进行高低电平的转换。当然中间需要根据需要保持一定的时间(可以用空指令)。

具体引脚及使用说明见:百度百
https://baike.baidu.com/item/74HC595/9886491?fr=aladdin

*/


//向HC595发送串行数据
void HC595SendData(unsigned char SendVal)
{  
  unsigned char i;

  for(i=0;i<8;i++) 
   {
        if((SendVal<<i)&0x80) Out=1; //set dataline high  0X80  最高位与SendVal左移的最高位 进行逻辑运算
            else Out=0;                // 如果为真 Out= 1  


        //产生数据移位信号
        S_CLK=0;  
        //delay_ms(1);
        NOP();   //短暂延时产生一定宽度的脉冲信号
        NOP();   //短暂延时
        S_CLK=1;

   }


 //产生数据输出信号
  R_CLK=0; //set dataline low
        //delay_ms(1);
  NOP();  //短暂延时
  NOP();  //短暂延时
    NOP();
  R_CLK=1;  //


}

// 头文件中定义的IO
sbit Out =P3^4;  //串行数据线
sbit R_CLK =P3^5;  //数据并行输出控制
sbit S_CLK =P3^6;  //串行时钟线


#define  NOP() _nop_()  /* 定义空指令 */

猜你喜欢

转载自blog.csdn.net/plm199513100/article/details/79656920
今日推荐