【洋桃一号板】STM32F103CBT6标准库函数驱动TM1640点亮数码管

一、今天介绍如何使用STM32F103CBT6驱动TM1640点亮数码管,硬件用的洋桃开发板,点亮后效果如下,六个数码管依次显示0.1.2.3.4.5.6.7
在这里插入图片描述
硬件原理图如下,只用到了单片机的两个IO口即可实现上图的效果,该开发板上用的是PA11和PA12两个IO口,用来模拟IIC通信,其中PA11接SCLK,PA12接DIN。另外可以看到TM1640的VDD接的是5V,规格书里面也是说需要接5V电压,但实际我试过了,接3.3V也是可以驱动的。在这里插入图片描述

二、TM1640介绍
TM1640通信方式其实就是常用的的IIC通信,这点可以在规格书里面看到相关介绍
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

三、写程序
1、先将重要的一些参数进行宏定义
a.固定地址模式上面分析过了,是0x44,后面进行配置会用到
b.设置亮度,上面也分析过了
c.通过上面的数据通信的过程我们知道需要用到SCLK和DIN两个信号,我们在硬件上接的是PA11和PA12两个脚,所以用TM1640_DIN_HTM1640_DIN_HTM1640_SCLK_LTM1640_SCLK_H来表示DIN和SCLK为高低电平。

#include "TM1640.h"
#include "delay.h"
#define DEL  1   //宏定义 通信速率(默认为1,如不能通信可加大数值)
//地址模式的设置
//#define TM1640MEDO_ADD  0x40   //宏定义	自动加一模式
#define TM1640MEDO_ADD  0x44   //宏定义 固定地址模式(推荐)

//显示亮度的设置
//#define TM1640MEDO_DISPLAY  0x88   //宏定义 亮度  最小
//#define TM1640MEDO_DISPLAY  0x89   //宏定义 亮度
//#define TM1640MEDO_DISPLAY  0x8a   //宏定义 亮度
//#define TM1640MEDO_DISPLAY  0x8b   //宏定义 亮度
#define TM1640MEDO_DISPLAY  0x8c   //宏定义 亮度(推荐)
//#define TM1640MEDO_DISPLAY  0x8d   //宏定义 亮度
//#define TM1640MEDO_DISPLAY  0x8f   //宏定义 亮度 最大
#define TM1640MEDO_DISPLAY_OFF  0x80   //宏定义 亮度 关

#define TM1640_DIN_H    GPIO_WriteBit(TM1640_GPIOPORT,TM1640_DIN,(BitAction)(1))
#define TM1640_DIN_L    GPIO_WriteBit(TM1640_GPIOPORT,TM1640_DIN,(BitAction)(0))

#define TM1640_SCLK_H 	GPIO_WriteBit(TM1640_GPIOPORT,TM1640_SCLK,(BitAction)(1))
#define TM1640_SCLK_L 	GPIO_WriteBit(TM1640_GPIOPORT,TM1640_SCLK,(BitAction)(0))

2、通信的开启和结束代码
在这里插入图片描述

void TM1640_start()
{ 
	//通信时序 启始
	TM1640_DIN_H; //DIN输出高电平1	
	TM1640_SCLK_H; //SCLK输出高电平1	
	delay_us(DEL);//延时一段时间
	TM1640_DIN_L; //DIN输出低电平0	
	delay_us(DEL);//延时一段时间
	TM1640_SCLK_L; //SCLK输出低电平0	
	delay_us(DEL);//延时一端时间
}
void TM1640_stop()
{ //通信时序 结束
	TM1640_DIN_L; //DIN输出低电平0	
	TM1640_SCLK_L; //SCLK输出低电平0	
	delay_us(DEL);//延时一段时间
	TM1640_SCLK_H; //SCLK输出高电平1	
	delay_us(DEL);
	TM1640_DIN_H; //DIN输出高电平1	
	delay_us(DEL);
}

3、底层函数,信号传输,写8位数据

void TM1640_write(u8 date)
	{	//写数据(低层)
		u8 i;
		u8 aa;
		aa=date;
		TM1640_DIN_L; //DIN输出0	
		TM1640_SCLK_L; //SCLK输出0	
		for(i=0;i<8;i++)
		{
			TM1640_SCLK_L; //SCLK输出0		
			delay_us(DEL);

			if(aa&0x01)
			{
				TM1640_DIN_H; //DIN输出1
				delay_us(DEL);
			}
			else
			{
				TM1640_DIN_L; //DIN输出0
				delay_us(DEL);
			}
				TM1640_SCLK_H; //SCLK输出1
				delay_us(DEL);
				aa=aa>>1;//右移一位
		 }
			TM1640_DIN_L; //DIN输出0
			TM1640_SCLK_L; //SCLK输出0
	}

安装上面的代码传输二进制10110001的时序图如下,左边为高位,右边为低位。所以实际是从低位开始传输数据。
在这里插入图片描述
4、TM1640驱动函数
a、GPIO初始化、配置固定地址,设置亮度

void TM1640_Init(void)
	{ //TM1640接口初始化
		GPIO_InitTypeDef  GPIO_InitStructure; 	
		RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOC,ENABLE);       
		GPIO_InitStructure.GPIO_Pin = TM1640_DIN | TM1640_SCLK; //选择端口号(0~15或all)                        
		GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //选择IO接口工作方式       
		GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //设置IO接口速度(2/10/50MHz)    
		GPIO_Init(TM1640_GPIOPORT, &GPIO_InitStructure);

		GPIO_WriteBit(TM1640_GPIOPORT,TM1640_DIN,(BitAction)(1)); //接口输出高电平1	
		GPIO_WriteBit(TM1640_GPIOPORT,TM1640_SCLK,(BitAction)(1)); //接口输出高电平1	
		
		TM1640_start();
		TM1640_write(TM1640MEDO_ADD); //设置数据,0x40,0x44分别对应地址自动加一和固定地址模式
		TM1640_stop();
		TM1640_start();
		TM1640_write(TM1640MEDO_DISPLAY); //设置亮度
			//控制显示,开显示,0x88,  0x89,  0x8a,  0x8b,  0x8c,  0x8d,  0x8e,  0x8f分别对应脉冲宽度为:
			//------------------1/16,  2/16,  4/16,  10/16, 11/16, 12/16, 13/16, 14/16	 //0x80关显示
		TM1640_stop();					
}

b、TM1638显示函数
在这里插入图片描述

void TM1640_display(u8 address,u8 date)
	{ //固定地址模式的显示输出
 	const u8 buff[21]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef,0x00};//数字0~9及0~9加点显示段码表
    //---------------   0    1    2    3    4    5    6    7    8    9    0.   1.   2.   3.   4.   5.   6.   7.   8.   9.   无   
   TM1640_start();
   TM1640_write(0xC0+address);//传显示数据对应的地址
   TM1640_write(buff[date]);//传1BYTE显示数据
   TM1640_stop();
}

5、主函数
有了上面的铺垫,主函数就很简单了,只需要初始化TM1640,然后调用显示函数即可

int main ()
{
	TM1640_Init(); //TM1640初始化
	while(1)
		{
			TM1640_display(0,0);	
			TM1640_display(1,1);
			TM1640_display(2,2); 
			TM1640_display(3,3);
			TM1640_display(4,4);	
			TM1640_display(5,5);
			TM1640_display(6,6);
			TM1640_display(7,7);
		}
}
以下是51单片机驱动TM1640点亮数码管的完整代码,包括TM1640驱动代码: ```c #include <reg51.h> #define TM1640_DIN P1_0 #define TM1640_SCLK P1_1 #define DEL 1 void delay_us(unsigned int us) { while (us--) { // 延时一微秒 } } void TM1640_start() { TM1640_DIN = 1; TM1640_SCLK = 1; delay_us(DEL); TM1640_DIN = 0; delay_us(DEL); TM1640_SCLK = 0; delay_us(DEL); } void TM1640_stop() { TM1640_DIN = 0; TM1640_SCLK = 0; delay_us(DEL); TM1640_SCLK = 1; delay_us(DEL); TM1640_DIN = 1; delay_us(DEL); } void TM1640_write(unsigned char data) { unsigned char i; for (i = 0; i < 8; i++) { TM1640_SCLK = 0; TM1640_DIN = data & 0x01; data >>= 1; delay_us(DEL); TM1640_SCLK = 1; delay_us(DEL); } } void TM1640_display(unsigned char *data) { unsigned char i; TM1640_start(); TM1640_write(0x40); TM1640_stop(); TM1640_start(); TM1640_write(0xC0); for (i = 0; i < 16; i++) { TM1640_write(data\[i\]); } TM1640_stop(); } void main() { unsigned char displayData\[16\] = {0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; TM1640_display(displayData); while (1) { // 循环显示 } } ``` 这段代码使用了51单片机的GPIO口来驱动TM1640点亮数码管。其中,TM1640_start()函数用于启动通信时序,TM1640_stop()函数用于结束通信时序,TM1640_write()函数用于向TM1640写入数据,TM1640_display()函数用于显示数据。在main()函数中,我们定义了一个显示数据的数组displayData,并通过TM1640_display()函数将数据显示在数码管上。你可以根据需要修改displayData数组中的数据来实现不同的显示效果。 #### 引用[.reference_title] - *1* *2* *3* [【洋桃一号STM32F103CBT6标准库函数驱动TM1640点亮数码管](https://blog.csdn.net/wsq_666/article/details/130093966)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值