news 2026/4/15 9:16:28

8051单片机程序——矩阵键盘+led数码管实现密码锁

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
8051单片机程序——矩阵键盘+led数码管实现密码锁

以下通过8051实现密码锁的简单程序,并无实用价值,重在记录8051单片机编程的一些重要算法。

led数码管:8位共阳型数码管;

段码锁存器采用74HC245:8051与74HC245、LED的连接电路图如下:

位码锁存器采用74HC138:8051与74HC138、LED的连接电路图如下:

8051与矩阵键盘的连接电路图如下:

74HC138芯片的真值表如下:

根据以上电路图和74HC138芯片的真值表,可以确定出sec_table、pos_table、key_table、err_table、open_table的取值。

#include <reg51.h> #include <string.h> #define SEC P0 #define KEY P1 #define POS P2 #define TIMER0_RELOAD_HIGH 0xFC #define TIMER0_RELOAD_LOW 0x18 #define POS_SIZE 8 unsigned char code sec_table[] = {0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7f, 0x6f}; unsigned char code pos_table[] = {0x00, 0x04, 0x08, 0x0C, 0x10, 0x14, 0x18, 0x1C}; // 注意看74HC138与8051之间的连接电路图。 unsigned char data pos_num[POS_SIZE] = {0}; unsigned char code key_table[] = {0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06}; unsigned char code err_table[] = {0x72, 0x72, 0x79}; unsigned char code open_table[] = {0x37, 0x79, 0x73, 0x3F}; void delay_10us(unsigned char us) { while (--us); /* 12M晶振,--us等于10微秒。 */ } void delay_ms(unsigned char ms) { while (ms--) { delay_10us(100); } } void t0int_s(void) { TMOD = 0x01; /* TMOD寄存器,定时器位数为16位。 */ TH0 = TIMER0_RELOAD_HIGH; /* TH0寄存器。 */ TL0 = TIMER0_RELOAD_LOW; /* TL0寄存器。 */ EA = 1; /* IE寄存器,允许所有中断。 */ ET0 = 1; /* IE寄存器,允许定时器0中断。 */ TR0 = 1; /* TCON寄存器,开始触发定时器0中断。 */ } void t0int_z(void) interrupt 1 { static unsigned int i = 0; TH0 = TIMER0_RELOAD_HIGH; TL0 = TIMER0_RELOAD_LOW; SEC = 0; POS = pos_table[i]; SEC = pos_num[i]; i++; if (i >= POS_SIZE) { i = 0; } } unsigned char keys(void) { unsigned char keyz = 0xFF; KEY = 0x0F; if (KEY != 0x0F) { delay_ms(10); KEY = 0x0F; switch (KEY) // 确定列。 { case 0x07: keyz = 1; break; case 0x0B: keyz = 2; break; case 0x0D: keyz = 3; break; case 0x0E: keyz = 4; break; } KEY = 0xF0; switch (KEY) // 确定行。 { case 0x70: break; case 0xB0: keyz += 4; break; case 0xD0: keyz += 8; break; case 0xE0: keyz += 12; break; } while (KEY != 0xF0); } return keyz; } void main(void) { static signed char i = POS_SIZE - 1; unsigned char num = 0; t0int_s(); while (1) { num = keys(); if (num <= 0x0A) { num %= 0x0A; pos_num[i--] = sec_table[num]; if (i < 0) { i = POS_SIZE - 1; } } else if (num <= 0x10 ) { if ( memcmp(pos_num, key_table, sizeof(pos_num) ) == 0 ) { memset( pos_num, 0, sizeof(pos_num) ); memcpy( pos_num, open_table, sizeof(open_table) ); } else { memset( pos_num, 0, sizeof(pos_num) ); memcpy( pos_num, err_table, sizeof(err_table) ); } i = POS_SIZE - 1; } } }

程序功能:

按下是s1~s10输入8位0~9的任意数字,当按下s11~s16的任何键时,将校验密码是否正确,如果正确,则在数码管输出OPEN字样,如果失败,则在数码管输出Err字样。

重要函数说明:

1、led数码管显示采用定时器中断程序实现输出段码,参见t0int_z函数;

2、矩阵键盘使用线翻转扫描方法;参见keys函数;

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/9 4:50:50

EmotiVoice语音合成引擎的并发请求处理能力测试

EmotiVoice语音合成引擎的并发请求处理能力测试 在虚拟偶像直播中&#xff0c;粉丝发送弹幕“太棒了&#xff01;”&#xff0c;系统瞬间生成带有兴奋语调的主播声音回应&#xff1b;在智能客服平台&#xff0c;上百名用户同时发起咨询&#xff0c;每位客户听到的都是专属音色且…

作者头像 李华
网站建设 2026/4/14 18:31:57

EmotiVoice情感语音生成在心理剧治疗中的角色扮演支持

EmotiVoice情感语音生成在心理剧治疗中的角色扮演支持 在一场典型的心理剧治疗中&#xff0c;患者被引导回到某个关键的情感场景——也许是童年时与父亲的一次激烈争吵&#xff0c;或是在亲密关系中遭遇背叛的瞬间。治疗师鼓励他“成为那个时刻的自己”&#xff0c;并与其他角…

作者头像 李华
网站建设 2026/4/11 19:37:38

人类记忆 vs 大模型记忆,到底差在哪?

这是一篇发表于 2025 年 10 月《Trends in Cognitive Sciences》上的文章。文章的核心在于探讨如何利用认知神经科学&#xff08;Cognitive Neuroscience&#xff09;中关于人类“情景记忆”&#xff08;Episodic Memory, EM&#xff09;的研究成果&#xff0c;来改进现有的记忆…

作者头像 李华
网站建设 2026/4/10 21:52:03

百度网盘免费解析工具终极指南:彻底告别限速烦恼

百度网盘免费解析工具终极指南&#xff1a;彻底告别限速烦恼 【免费下载链接】baidu-wangpan-parse 获取百度网盘分享文件的下载地址 项目地址: https://gitcode.com/gh_mirrors/ba/baidu-wangpan-parse 还在为百度网盘那令人抓狂的几十KB下载速度而苦恼吗&#xff1f;重…

作者头像 李华