STM32f1之8*8点阵驱动+取模方法(安排)

目录

前言

一、8*8点阵

二、显示代码详解

三、取模方法

四、总结


前言

之前呢,考虑到要参加全国电子设计大赛,就专门投入到MSP430的学习海洋中去,结果延期了,那咱就先回归老本行,主要还是记录一下自己的收获嘛,暑假这段期间内除了特殊情况,我坚持每天写一篇博客,基本上我都会围绕STM32f1和MSP430F5529这两款单片机来,但是呢,要回家了嘛,所以不会把所有模块的演示图片都截上来,但是代码肯定会尽量按照自己的理解给大家讲一下,哪里讲的不对也恳请大家批评指正,谢谢。

一、8*8点阵

其实,8*8点阵是一个很好上手的模块,原理也相当简单,它有6个接口,分别是GND、VCC、NC、CLK、LE、DI 

其中GND和VCC就不说了,NC这个接口不用接线,常闭口,CLK移位时钟控制端,LE储存时钟控制端,DI数据输入控制端

简单来说吧,把CLK和LE位先拉低,再打开DI口(拉高),然后再设置8个循环写入数据,之后拉高CLK,处于上升沿状态来发送数据,然后置0,最后拉高LE锁存,然后置0。具体代码和取模方法下面再介绍。

下图是演示:用的是系统板这里我是用PG0、1、2来接DI、LE、CLK

 后面学会了取模,就可以自己随意显示自己想要的东西了,自己画才有成就感。

二、显示代码详解

点阵头文件

#ifndef __DZ_H
#define __DZ_H	 
#include "sys.h"

#define LEDARRAY_DI   PGout(0)// DI
#define LEDARRAY_LAT  PGout(1)// LE
#define LEDARRAY_CLK  PGout(2)//CLK

 
void Send_Byte( unsigned char dat);//发送字节
void DZ_Init(void);//点阵初始化

		 				    
#endif

 点阵函数

#include "88dz.h"
#include "delay.h"

void DZ_Init()//初始化PG0、1、2
{
	GPIO_InitTypeDef  GPIO_InitStructure;
 	
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOG, ENABLE);	
	
 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2;				 
 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; 		
 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;		
 GPIO_Init(GPIOG, &GPIO_InitStructure);					 
 GPIO_SetBits(GPIOG,GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2);						 

}
void Send_Byte( unsigned char dat)
{
	unsigned char i;
	LEDARRAY_CLK = 0;//拉低
	LEDARRAY_LAT = 0;//拉低
	for( i = 0 ; i < 8 ; i++ ) //循环8次发送字节
	{
		if( dat&0x01 )
		{
			LEDARRAY_DI = 1;	
		}
		else
		{
			LEDARRAY_DI = 0;
		}
		
		LEDARRAY_CLK = 1;				//上升沿发送数据
		LEDARRAY_CLK = 0;

				
		dat >>= 1;			
	}		
	
	
}

主函数

#include "sys.h"
#include "delay.h"
#include "led.h"
#include "88dz.h"

//这里自己可以自行更改
unsigned char  Display_word[7][8] = {
0x00,0x1C,0x14,0xFF,0x14,0x1C,0x00,0x00,//中
0x00,0xFF,0x81,0xCB,0xFF,0xEB,0x81,0xFF,//国
0x00,0x10,0x54,0x3F,0x14,0x3F,0x54,0x10,//共
0x80,0x84,0xEC,0x35,0x26,0x34,0x2C,0x04,//产
0x00,0x06,0x83,0xFA,0x2B,0xFA,0x83,0xC6,//党
0x42,0x22,0x1E,0x0A,0x4A,0x4A,0x7A,0x02,//万
0x40,0x26,0x34,0xDC,0x57,0x34,0x14,0x06	//岁
};

 int main(void)
 {	
	unsigned char k, temp;
    unsigned char i;
	delay_init();	  
	LED_Init();		  
    DZ_Init();
	 
	while(1)
	{

        for(i=0;i<100;i++)//这里i<100的取值越大,显示时间越久
         {
			temp = 0x7f;//接下来进行列选择
			for(k = 0 ; k < 8 ; k++)		
			{
				Send_Byte(temp);			//进行列选择
				Send_Byte(Display_word[0][k]);			//发送行数据
				LEDARRAY_LAT = 1;					//	锁存	
				delay_ms(1);
				LEDARRAY_LAT = 0;
		      	delay_ms(1);
				temp = (temp>>1)|0x80;
    	}
		}
		
for(i=0;i<100;i++)
{
			temp = 0x7f;
			for(k = 0 ; k < 8 ; k++)		
			{
				Send_Byte(temp);			
				Send_Byte(Display_word[1][k]);			
				LEDARRAY_LAT = 1;					
						delay_ms(1);
				LEDARRAY_LAT = 0;
						delay_ms(1);
				temp = (temp>>1)|0x80;
			}
	}

for(i=0;i<100;i++)
{
			temp = 0x7f;
			for(k = 0 ; k < 8 ; k++)		
			{
				Send_Byte(temp);			
				Send_Byte(Display_word[2][k]);			
				LEDARRAY_LAT = 1;					
						delay_ms(1);
				LEDARRAY_LAT = 0;
						delay_ms(1);
				temp = (temp>>1)|0x80;
			}
	}

for(i=0;i<100;i++)
{
			temp = 0x7f;
			for(k = 0 ; k < 8 ; k++)		
			{
				Send_Byte(temp);			
				Send_Byte(Display_word[3][k]);			
				LEDARRAY_LAT = 1;				
						delay_ms(1);
				LEDARRAY_LAT = 0;
						delay_ms(1);
				temp = (temp>>1)|0x80;
			}
	}

	for(i=0;i<100;i++)
{
			temp = 0x7f;
			for(k = 0 ; k < 8 ; k++)		
			{
				Send_Byte(temp);		
				Send_Byte(Display_word[4][k]);			
				LEDARRAY_LAT = 1;					
						delay_ms(1);
				LEDARRAY_LAT = 0;
						delay_ms(1);
				temp = (temp>>1)|0x80;
			}
	}

	for(i=0;i<100;i++)
{
			temp = 0x7f;
			for(k = 0 ; k < 8 ; k++)		
			{
				Send_Byte(temp);			
				Send_Byte(Display_word[5][k]);			
				LEDARRAY_LAT = 1;					
						delay_ms(1);
				LEDARRAY_LAT = 0;
						delay_ms(1);
				temp = (temp>>1)|0x80;
			}
	}

	for(i=0;i<100;i++)
{
			temp = 0x7f;
			for(k = 0 ; k < 8 ; k++)		
			{
				Send_Byte(temp);			
				Send_Byte(Display_word[6][k]);			
				LEDARRAY_LAT = 1;					
						delay_ms(1);
				LEDARRAY_LAT = 0;
						delay_ms(1);
				temp = (temp>>1)|0x80;
			}
	}

	
}
}

具体代码解释也在上面讲了,希望能对大家有所帮助

三、取模方法

首先你得有个取模软件,上上上讲MSP430F5529之1.44寸OLED显示(附源码)_ZJ Sky的博客-CSDN博客     我就给大家附上了文字取模和图片取模软件了,大家如果没有可以到上面链接里面下载,好了接下来详细讲一下怎么用

第一步:点开软件后,左上角新建

第二步:弹出这个窗口,输入8*8

 第三步:打开设置 

第四步:设置参数(可以自己设置各种方式,但是要统一) 

 

第五步:自己画图,然后生成代码,搬到自己的工程中去就行

四、总结

快乐时光总是短暂的,学习总是永无止境的,到这里基本上已经把该讲的都讲的差不多了,剩下的就靠你自己剖析了,多试试,不试试怎么知道自己做不做的到,马上去上手8*8点阵模块的使用了吧,冲冲冲!欢迎大家一起来探讨交流,共同进步!

题外话

挺喜欢彭于晏说的一句话:“我就是没有才华,所以才用命去拼!”

学习32之路固然辛苦,但要是坚持下来了,那不是很酷?哈哈哈

  • 12
    点赞
  • 61
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
以下是一个简单的例子,使用STM32的GPIO口控制8*8 LED点阵。您可以根据自己的需求进行修改。 ```c #include "stm32f10x.h" // 定义引脚 #define LED_LAT_GPIO GPIOA #define LED_LAT_PIN GPIO_Pin_0 #define LED_OE_GPIO GPIOA #define LED_OE_PIN GPIO_Pin_1 #define LED_SCLK_GPIO GPIOA #define LED_SCLK_PIN GPIO_Pin_2 #define LED_SDA_GPIO GPIOA #define LED_SDA_PIN GPIO_Pin_3 // 控制LED点阵的函数 void led_write_byte(unsigned char dat) { unsigned char i; for (i = 0; i < 8; i++) { if (dat & 0x80) { GPIO_SetBits(LED_SDA_GPIO, LED_SDA_PIN); } else { GPIO_ResetBits(LED_SDA_GPIO, LED_SDA_PIN); } dat <<= 1; GPIO_ResetBits(LED_SCLK_GPIO, LED_SCLK_PIN); GPIO_SetBits(LED_SCLK_GPIO, LED_SCLK_PIN); } } void led_write(unsigned char address, unsigned char dat) { GPIO_ResetBits(LED_LAT_GPIO, LED_LAT_PIN); led_write_byte(address); led_write_byte(dat); GPIO_SetBits(LED_LAT_GPIO, LED_LAT_PIN); } void led_init() { GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); GPIO_InitStructure.GPIO_Pin = LED_LAT_PIN | LED_OE_PIN | LED_SCLK_PIN | LED_SDA_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA, &GPIO_InitStructure); GPIO_SetBits(LED_LAT_GPIO, LED_LAT_PIN); GPIO_SetBits(LED_OE_GPIO, LED_OE_PIN); GPIO_ResetBits(LED_SCLK_GPIO, LED_SCLK_PIN); GPIO_ResetBits(LED_SDA_GPIO, LED_SDA_PIN); } int main() { led_init(); // 在此处添加要显示的图案的代码 // 例如:led_write(0x00, 0x00); while (1); } ``` 在 `main` 函数中,您可以使用 `led_write` 函数来控制LED点阵。函数的第一个参数表示要写入的地址,第二个参数表示要写入的数据。此外,您还可以在 `led_init` 函数中进行引脚的初始化。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不说二话的自家人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值