stm32之点阵模式

利用MAX7219芯片可以最多控制64个led灯,可以控制数码管BCD码模式

接线只需DIN, VCC,GND,CS,CLK连接pin脚

对 MAX7219 来说,串行数据在DIN输入16位数据包,无论LOAD端处于何种状 态,在时钟的上升沿数据均移入到内部16位移位寄存器。对MAX7221来说,无论数 据输入或输出cs必须为低电平。然后数据在 LOAD/cs的上升沿被载入数据寄存器或 控制寄存器。LOAD/cs端在第 16 个时钟的上升沿同时或之后,下个时钟上升沿之前 变为高电平,否则数据将会丢失。在DIN端的数据传输到移位寄存器在16.5个时钟 周期之后出现在DOUT端。在时钟的下降沿数据将被输出。数据位标记为D0-D15。D8-D11为寄存器地址位。D0-D7为数据位。D12-D15为无效位。在传输 过程中,首先接收到的是D15位,是非常重要的一位(MSB)。

总之就是时序为CS拉低,数据传输前CLK拉低,数据在CLK上升沿传输,最后CS拉高结束传输

void Write_Max7219_byte(uint8_t DATA)      //发送一个8位数据   
{     	
    	uint8_t i;    
			CS(0);		
	    for(i=8;i>=1;i--)
			{		  
						CLK(0);				
						if(DATA&0x80)//按位与
						{
								DIN(1);
						}
						else
						{
								DIN(0);
						}
			
						DATA=DATA<<1;//左移
						CLK(1);			
			 }                                 
}

串行数据总共16位 ,数据位标记为D0-D7,D8-D11为寄存器地址位。D0-D7为数据位。D12-D15为无效位。在传输 过程中,首先接收到的是D7位,是非常重要的一位(MSB)。

所以发送为先发地址再发数据两次发送

Digit0-7就是控制LED灯珠的寄存器,分别0x0---0x08

D11-D8地址位+D7-D0数据位=8位

主程序

#include "stm32f10x.h"                  // Device header
#include "Delay.h"
#include "OLED.h"
#include "MAX7219.h"
char  disp1[38][8]={//38行,8列
{0x3C,0x42,0x42,0x42,0x42,0x42,0x42,0x3C},//0
{0x10,0x18,0x14,0x10,0x10,0x10,0x10,0x10},//1
{0x7E,0x2,0x2,0x7E,0x40,0x40,0x40,0x7E},//2
{0x3E,0x2,0x2,0x3E,0x2,0x2,0x3E,0x0},//3
{0x8,0x18,0x28,0x48,0xFE,0x8,0x8,0x8},//4
{0x3C,0x20,0x20,0x3C,0x4,0x4,0x3C,0x0},//5
{0x3C,0x20,0x20,0x3C,0x24,0x24,0x3C,0x0},//6
{0x3E,0x22,0x4,0x8,0x8,0x8,0x8,0x8},//7
{0x0,0x3E,0x22,0x22,0x3E,0x22,0x22,0x3E},//8
{0x3E,0x22,0x22,0x3E,0x2,0x2,0x2,0x3E},//9
{0x8,0x14,0x22,0x3E,0x22,0x22,0x22,0x22},//A
{0x3C,0x22,0x22,0x3E,0x22,0x22,0x3C,0x0},//B
{0x3C,0x40,0x40,0x40,0x40,0x40,0x3C,0x0},//C
{0x7C,0x42,0x42,0x42,0x42,0x42,0x7C,0x0},//D
{0x7C,0x40,0x40,0x7C,0x40,0x40,0x40,0x7C},//E
{0x7C,0x40,0x40,0x7C,0x40,0x40,0x40,0x40},//F
{0x3C,0x40,0x40,0x40,0x40,0x44,0x44,0x3C},//G
{0x44,0x44,0x44,0x7C,0x44,0x44,0x44,0x44},//H
{0x7C,0x10,0x10,0x10,0x10,0x10,0x10,0x7C},//I
{0x3C,0x8,0x8,0x8,0x8,0x8,0x48,0x30},//J
{0x0,0x24,0x28,0x30,0x20,0x30,0x28,0x24},//K
{0x40,0x40,0x40,0x40,0x40,0x40,0x40,0x7C},//L
{0x81,0xC3,0xA5,0x99,0x81,0x81,0x81,0x81},//M
{0x0,0x42,0x62,0x52,0x4A,0x46,0x42,0x0},//N
{0x3C,0x42,0x42,0x42,0x42,0x42,0x42,0x3C},//O
{0x3C,0x22,0x22,0x22,0x3C,0x20,0x20,0x20},//P
{0x1C,0x22,0x22,0x22,0x22,0x26,0x22,0x1D},//Q
{0x3C,0x22,0x22,0x22,0x3C,0x24,0x22,0x21},//R
{0x0,0x1E,0x20,0x20,0x3E,0x2,0x2,0x3C},//S
{0x0,0x3E,0x8,0x8,0x8,0x8,0x8,0x8},//T
{0x42,0x42,0x42,0x42,0x42,0x42,0x22,0x1C},//U
{0x42,0x42,0x42,0x42,0x42,0x42,0x24,0x18},//V
{0x0,0x49,0x49,0x49,0x49,0x2A,0x1C,0x0},//W
{0x0,0x41,0x22,0x14,0x8,0x14,0x22,0x41},//X
{0x41,0x22,0x14,0x8,0x8,0x8,0x8,0x8},//Y
{0x0,0x7F,0x2,0x4,0x8,0x10,0x20,0x7F},//Z
{0x8,0x7F,0x49,0x49,0x7F,0x8,0x8,0x8},//中
{0xFE,0xBA,0x92,0xBA,0x92,0x9A,0xBA,0xFE},//国
};
void show_number(uint8_t j)
{ uint8_t i;
  
   for(i=1;i<9;i++)//0x01-0x08
    Write_Max_LED(i,disp1[j][i-1], i,disp1[j][i-1], i,disp1[j][i-1],i,disp1[j][i-1]);  //行1-8地址   列数据
   
  
}
int j,i;
int main(void)
{
	Max7219_init();

	Max7219_CLS();
	while (1)
	{
		i=j=2;
    Write_Max_LED(i,disp1[j][i-1], i,disp1[j][i-1], i,disp1[j][i-1],i,disp1[j][i-1]);  //行1-8地址   列数据
	
	}
}

子程序

#include "stm32f10x.h"                  // Device header
#include "MAX7219.h"  


//MAX7219写入16位数据(依据时序):
 /**

*@功能 :写入16位串行数据

*@参数1:add地址位

*@参数2:dat数据位

*@返回 :无

*/

void Max7219_write_16bit(unsigned char add,unsigned dat)

{

   unsigned char i;

   CS(0);

   CLK(0);

   for(i=0;i<8;i++)

   {

   DIN(add&0x80);

   CLK(1);

  CLK(0);

   add=add<<1;

   }

   for(i=0;i<8;i++)

   {

   DIN(dat&0x80);

   CLK(1);

   CLK(0);

   dat=dat<<1;

   }

}

// 3.MAX7219锁存

/**

*@功能 :数据传输完成后将数据锁存入芯片 

*@参数1:无

*@返回 :无

*/

void Max7219_Lock()

{

  CS(1); 

  CS(0);

}

//4.MAX7219初始化:

/**

*@功能 :MAX7219初始化,实现4个子模块分别初始。

*@参数1:  无

*@返回 : 无

*/

void Max7219_init()

{
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOF, ENABLE);
	
	GPIO_InitTypeDef GPIO_InitStructure;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3 | GPIO_Pin_4 | GPIO_Pin_5;
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(GPIOF, &GPIO_InitStructure);
   	Write_Max_LED(0x09,0x00 , 0x09,0x00 , 0x09,0x00 , 0x09,0x00);       //译码方式:BCD码
		 Write_Max_LED(0x0a,0xFF , 0x0a,0xFF , 0x0a,0xFF , 0x0a,0xFF);       //亮度 
		 Write_Max_LED(0x0b,0x07 , 0x0b,0x07 , 0x0b,0x07 , 0x0b,0x07);       //扫描界限;8个数码管显示
		 Write_Max_LED(0x0c,0x01 , 0x0c,0x01 , 0x0c,0x01 , 0x0c,0x01);       //掉电模式:0,普通模式:1
		 Write_Max_LED(0x0f,0x00 , 0x0f,0x00 , 0x0f,0x00 , 0x0f,0x00);       //显示测试:1;测试结束,正常显示:0

}


void Write_Max7219_byte(uint8_t DATA)         
{     	
    	uint8_t i;    
			CS(0);		
	    for(i=8;i>=1;i--)
			{		  
						CLK(0);				
						if(DATA&0x80)
						{
								DIN(1);
						}
						else
						{
								DIN(0);
						}
			
						DATA=DATA<<1;
						CLK(1);			
			 }                                 
}

void Write_Max_LED(uint8_t address1,uint8_t dat1,uint8_t address2,uint8_t dat2,
										uint8_t address3,uint8_t dat3,uint8_t address4,uint8_t dat4)
{ 
//     uchar i;
     CS(0);
     Write_Max7219_byte(address1);           //写入地址,即数码管编号
     Write_Max7219_byte(dat1);              //写入数据,即数码管显示数字 
			
	   Write_Max7219_byte(address3);           //写入地址,即数码管编号
     Write_Max7219_byte(dat3);      //写入数据,即数码管显示数字 
			
	   Write_Max7219_byte(address2);           //写入地址,即数码管编号
     Write_Max7219_byte(dat2);      //写入数据,即数码管显示数字 
		 
	   Write_Max7219_byte(address4);           //写入地址,即数码管编号
     Write_Max7219_byte(dat4);      //写入数据,即数码管显示数字 
	   
     CS(1);                        
}

//5.MAX7219清屏

/**

*@功能 :实现清屏

*@参数1:  无

*@返回 :无

*/

void Max7219_CLS()

{

  unsigned char i;

  for(i=8;i>=1;i--)

  {

    Write_Max_LED(i,0x00,i,0x00,i,0x00,i,0x00);
  }

}

















#ifndef __MAX7219_H
#define __MAX7219_H

void Max7219_Lock();
void Max7219_CLS();
void Max7219_init();
void Write_Max_LED(uint8_t address1,uint8_t dat1,uint8_t address2,uint8_t dat2,
										uint8_t address3,uint8_t dat3,uint8_t address4,uint8_t dat4);

void Max7219_write_16bit(unsigned char add,unsigned dat);
#define CLK(x)			GPIO_WriteBit(GPIOF, GPIO_Pin_3, (BitAction)(x));
#define CS(x)			GPIO_WriteBit(GPIOF, GPIO_Pin_4, (BitAction)(x));
#define DIN(x)			GPIO_WriteBit(GPIOF, GPIO_Pin_5, (BitAction)(x));
#endif







原理就是void Write_Max_LED(uint8_t address1,uint8_t dat1,uint8_t address2,uint8_t dat2,
                                        uint8_t address3,uint8_t dat3,uint8_t address4,uint8_t dat4)函数

地址0x01-0x08  +需要点亮灯珠

例如需要显示数字0               

则需要0x3C,0x42,0x42,0x42,0x42,0x42,0x42,0x3C的数据位

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值