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

2024-01-21 12:40

本文主要是介绍基于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&10000000DATA=DATA<<1;         //出问题的地方Max7219_CLK=1;       //通过上升沿再把数据送出去}

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

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

在这里插入图片描述

二、如何移位

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

这篇关于基于MAX7219移位寄存器工作原理及代码分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/629581

相关文章

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

Olingo分析和实践之EDM 辅助序列化器详解(最佳实践)

《Olingo分析和实践之EDM辅助序列化器详解(最佳实践)》EDM辅助序列化器是ApacheOlingoOData框架中无需完整EDM模型的智能序列化工具,通过运行时类型推断实现灵活数据转换,适用... 目录概念与定义什么是 EDM 辅助序列化器?核心概念设计目标核心特点1. EDM 信息可选2. 智能类

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程