STM32F103ZET6是一款基于ARM Cortex-M3内核的32位微控制器,广泛应用于各种嵌入式系统和工业控制领域。TM1638则是一种常用的LED驱动和键盘扫描控制器,它通过简单的串行接口与微控制器连接,能够有效减少所需的I/O端口数量,并支持多个按键输入,因此在需要显示和按键输入功能的嵌入式系统中非常实用。 在基于STM32F103ZET6的TM1638点亮项目中,主要目标是通过STM32F103ZET6微控制器来控制TM1638显示设备,实现LED的点亮和按键输入的检测。该项目涉及硬件连接和软件编程两个方面。在硬件连接方面,需要将STM32F103ZET6的相应I/O端口与TM1638的串行数据输入/输出端口(DIO)、时钟端口(CLK)以及键盘扫描输入端口(STB)连接起来。在软件编程方面,则需要编写相应的程序代码来初始化STM32F103ZET6和TM1638,并通过编写数据传输函数来实现对TM1638的控制。 项目开始时,首先需要对STM32F103ZET6的硬件资源进行配置,包括时钟系统、GPIO端口以及外设(如USART、I2C等,如果使用这些作为通信接口)。然后,编写程序初始化TM1638,包括设置其工作模式、亮度等。接下来,通过编写数据发送函数来向TM1638发送控制命令,点亮LED灯或读取按键状态。在点亮LED时,需要通过TM1638发送特定的显示数据指令,使LED显示预设的字符或图案;在读取按键输入时,则需要读取TM1638返回的按键状态数据,根据数据判断哪个按键被按下,并进行相应的处理。 在项目实施过程中,还需要注意电路设计的安全性和稳定性。例如,保证电源供应的稳定性,防止过压或欠压对微控制器或TM1638造成损坏;同时,还需要确保硬件连接的正确性,避免因接线错误导致的设备损坏或功能异常。 基于STM32F103ZET6的TM1638点亮项目是一个实践性强的嵌入式系统应用案例,它不仅涉及到硬件的连接和配置,还包括软件程序的设计和调试。通过该项目的实施,可以加深对STM32F103ZET6微控制器和TM1638显示模块的理解,为开发更为复杂的嵌入式系统打下坚实的基础。
2026-03-16 13:47:57 2.13MB tm1638
1
W79E824串行通信楼宇对讲系统,完速的代码,主机端
2022-12-15 20:21:27 40KB W79E824. Tm1638 AP89080
1
使用ESP32通过五芯线(两根电源+3根信号)连接TM1638显示模块做成的计时闹钟,ARDUINO程序,模块化设计。其中包括ESP32内部RTC时钟源的写入和读出;NTP网络时间同步;微信配网。包括通常LED时钟的所有调校功能和定闹设置功能。连上WIFI网络就可以校准时间,非常精确,即使断网也可正常走时,正常定闹,正常调校,不影响各功能实现(网络校时除外)。并且定闹次数没有限制,稍加修改就可以实用化。本资源是练习ESP32时钟功能的很好的参考资料,非常具有借鉴价值。其中包括四个文件:TM1638.C为显示驱动模块,提供LED灯珠、数码管、按键处理功能。TIMERS.C是时钟处理模块,用于设置和读取ESP32内部RTC时钟源,以及时区设置,NTP校时功能。ESP32OBJ.C则提供微信配网及WIFI自动连接功能。主程序NTP_TIME.INO整合各模块,进行初始化,并负责实现各设计功能。
2022-10-24 20:47:01 8KB ESP32 STM32 TM1638 NTP
1
#include //1638he165合并程序 2018/5/26 #include <tm1638.h> #include #define uchar unsigned char #define uint unsigned int sbit SU0=P2^0; //计数脉冲识别 sbit SU1=P2^1; //计数脉冲识别 sbit SU2=P2^2; sbit DJ1=P1^0; sbit DJ2=P1^1; sbit QH=P3^2; //输出端 sbit CK=P3^3; //时钟 上升沿有效 sbit PL=P3^4; //移位控制 低电平有效 uchar temp; uchar temp1; uchar tempH; uchar tempL; bit weia; bit weib; bit ding; unsigned char num[8]; //各个数码管显示的值 unsigned int dingshiqi=0; unsigned int num1,num2; unsigned int su1_a,su1_b; unsigned int su2_a,su2_b; unsigned int su2,su4,su1; unsigned char wei,wei1; unsigned int k; void delay1ms(uint i) //1ms延时程序 { uchar j; while(i--) { for(j=0;j<115;j++) { ; } } } void delay(unsigned int i) { unsigned char j; while(i--) for(j=120; j>0; j--); } uint read_int165(void) { uchar i=0; uint read_data=0; PL=0; //置数,读入并行输入数据 _nop_(); PL=1; //移位,并口被锁存,串行转换开始 _nop_(); for(i=0;i<16;i++) //设定16位输入 { read_data<<=1; if(QH) { read_data|=QH; } CK=0; //下降沿 _nop_(); CK=1; _nop_(); //上升沿 } return read_data; } void init_t0() { TMOD = 0x02; //8位自动载定时器 TH0 = 0x06; TL0 = 0x06; TR0 = 1; //启动定时器 ET0=1; //允许定时器0中断 EA=1; //开总中断 } void main(void) { unsigned char i; init_t0(); init_TM1638(); for(i=0;i<8;i++) Write_DATA(i<<1,tab[0]); weia = 0; weib = 0; ding = 0; ///初始化 { if(SU2==0) //如果是按键S1按下 { delay(10); //延时20ms,软件消抖 if(SU2==0) //如果是按键S1按下 DJ1=0; while(!SU2); } } { uint temp=0; //初始化 uchar tempH=1; uchar tempL=1; CK=0; } while(1) { { temp=read_int165(); tempH=(uchar)(temp>>8); //获取高八位,存在tempH tempL=(uchar)temp; //获取低八位存在tempL P2=tempH; //接收的字节高八位显示在P2 P1=tempL; //接收的低八位显示在P1 } { i=Read_key(); switch(i) { case 0: //1--1 { while(Read_key()==i); //等待按键释放 su1_a = 0; su2_a = 0; wei=0; weia=1; ding=0; }break; case 1: { while(Read_key()==i); //等待按键释放 weia=0; wei++; if(wei>=3)wei = 0; }break; case 2: { while(Read_key()==i); //等待按键释放 if(wei==1) su1_b++; if(su1_b>5500) su1_b=0; if(wei==2) su2_b++; if(su2_b>5500) su2_b=0; }break; case 3: { while(Read_key()==i); //等待按键释放 if(wei==1) { if(su1_b>0)su1_b--; } if(wei==2) { if(su2_b>0)su2_b--; } }break; case 4: { while(Read_key()==i); //等待按键释放 ding=~ding; }break; case 5:{ while(Read_key()==i); }break; case 6:{ while(Read_key()==i); } break; case 7:{ while(Read_key()==i); }break; } if(wei==0) //脉冲输入计数 { if((ding==0)&&(weia==1)) { if(SU0 ==0) { delay(1); if(SU0==0) { while(!SU0); su1_a++; } } if(SU1 ==0) { delay(1); if(SU1==0) { while(!SU1); su2_a++; } } if(su1_a==su1_b) su1_a = 0; if(su2_a==su2_b) { ding = 1; } } Write_DATA(3*2,tab[su1_a]); Write_DATA(2*2,tab[su1_a0/10]); Write_DATA(1*2,tab[su1_a00/100]); Write_DATA(0*2,tab[su1_a000/1000]); Write_DATA(7*2,tab[su2_a]); Write_DATA(6*2,tab[su2_a0/10]); Write_DATA(5*2,tab[su2_a00/100]); Write_DATA(4*2,tab[su2_a000/1000]); } if(wei==1) //左边数码管设置 { k++; if(k>40)k = 0; if(k>10) { Write_DATA(3*2,tab[su1_b]); Write_DATA(2*2,tab[su1_b0/10]); Write_DATA(1*2,tab[su1_b00/100]); Write_DATA(0*2,tab[su1_b000/1000]); } else { Write_DATA(0*2,tab[20]); Write_DATA(1*2,tab[20]); Write_DATA(2*2,tab[20]); Write_DATA(3*2,tab[20]); } } if(wei==2) //右边数码管设置 { Write_DATA(3*2,tab[su1_a]); Write_DATA(2*2,tab[su1_a0/10]); Write_DATA(1*2,tab[su1_a00/100]); Write_DATA(0*2,tab[su1_a000/1000]); k++; if(k>40)k = 0; if(k>10) { Write_DATA(7*2,tab[su2_b]); Write_DATA(6*2,tab[su2_b0/10]); Write_DATA(5*2,tab[su2_b00/100]); Write_DATA(4*2,tab[su2_b000/1000]); } else { Write_DATA(4*2,tab[20]); Write_DATA(5*2,tab[20]); Write_DATA(6*2,tab[20]); Write_DATA(7*2,tab[20]); } } } } } void time0() interrupt 1 //使用的是定时器T0 { dingshiqi++; if(dingshiqi>=3686) { dingshiqi = 0; } }
2022-07-28 19:34:00 52KB tm1638
1
LED驱动 TM1638驱动程序 完整TM1638显示芯片底层驱动,1639,1640通用,适用于任何单片机。
2021-12-19 19:25:25 3KB TM1638  TM1639 LED显示
1
数码管显示板驱动芯片TM1638数据手册
2021-11-24 11:03:33 657KB 数据手册
1
TM1638共阳极数码管STM32F407例程
2021-11-12 15:32:05 3KB TM1638 STM32例程
1
TM1638 按键数码管模块(带小数点), TM1638 -按键-8位数码管显示
2021-11-12 03:31:44 9KB 51单片机
1
这段时间因为设计项目需要用到数码管和按钮,因为数码管过多,没有办法使用IO扫描方式,所以就是使用了专用IC驱动芯片,TM1638芯片可以驱动数码可以驱动矩阵键盘。
2021-10-08 22:18:46 342KB TM1638 芯片使用 心得 文章
1
在keil5平台用STM32F103驱动QYF-TM1638,是个完整的工程,方面改动。
2021-08-01 11:20:48 2.29MB TM1638 stm32
1