基于MAX7219移位寄存器工作原理及代码分析

一、基于MAX7219移位寄存器工作原理及代码分析

该图为芯片功能图表
首先要明白DIN管脚的含义,其为串行数据输入端口,在时钟上升沿时数据被载入内部的 16 位寄存器。 而CLK即为时钟序列输入端,所以当要输入数据时,先得把CLK脚的电位拉低,输入一位数据后,再把CLK的电位拉高,此时则产生了一个时钟上升沿,使数据被载入,此时用代码表示为(注意:通过时序图可知,CS为低电平时串行数据才会被载入移位寄存器,为高电平时会被锁存。):

void Write_Max7219_byte()         
{ 
             Max7219_CS=0;     //CS=0有效,CS=1锁存  
            Max7219_CLK=0;
            Max7219_DIN=0;
            Max7219_CLK=1;    //通过上升沿把数据送出去,即一个0——1的跳变
            Max7219_CLK=0;
            Max7219_DIN=1;
            Max7219_CLK=1; 
            Max7219_CLK=0;
            Max7219_DIN=0;
            Max7219_CLK=1; 
            Max7219_CLK=0;
            Max7219_DIN=1;
            Max7219_CLK=1; 
           }

这时会发现,在一个时钟上升沿只能传一位数据,如果想传8位甚至更多数据时,需要多次重复时钟上升的过程,特别繁琐,通过以上代码会发现一个规律,CLk的上升过程是重复的,这时就能够联想到C语言中的For循环,那如何将一字节强制转换成一位来使用呢?C语句又给出了很好的答案,因为串行数据输入端口一次只能读一位,且只能取该字节的最高位,如果强行给一个字节给它,那么它一次也只能读到最高位,可编程过程中就是需要给一位给它,如何读取到后面的字节,这是就巧妙的运用到了移位,可以每次通过左移一位的方式,让输入端口逐个接收,此时代码如下:

void Write_Max7219_byte(uchar DATA)         
{
      uchar i;    
    Max7219_CS=0;                   //CS=0有效,CS=1锁存  
      for(i=8;i>=1;i--)
          {      
            Max7219_CLK=0;
            Max7219_DIN=DATA&0x80; //即DATA&10000000
            DATA=DATA<<1;         //出问题的地方
            Max7219_CLK=1;       //通过上升沿再把数据送出去
           }

(1)对Max7219_DIN=DATA&0x80;进行分析:

由于串行数据输入端口一次只能读一位,且只能取该字节的最高位,那么通过与0x80的方式,可以使该字节最高位不变的情况下,后面七位全部置0(1字节强制转换成一位使用的缘故),此时的代码相对来说已经达到了最简。

在这里插入图片描述

二、如何移位

由数据手册知该芯片在传输数据过程中,首先接收到的是 D15 位,那么在传输数据的过程中,先接收到的数据会往后移,可以类比于后面接收的数据把先接收的数据挤了下去,直到填满寄存器为止。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值