news 2026/3/2 10:47:07

基于51单片机的交通灯设计之旅

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于51单片机的交通灯设计之旅

基于51单片机交通灯设计 单片机模拟交通灯 信号灯 十字路口信号灯51单片机交通灯proteus仿真 仿真图protues 8.0 程序编译器:keil 4/keil 5 程序 仿真 原理图 报告 功能如下: 1.红绿灯时间可显示,正常红绿灯切换 2.可以按键设置红绿灯时间 3.有交通管制按键(按下默认全部红灯)

在嵌入式开发的世界里,51单片机是很多爱好者入门的经典选择。今天咱们就来聊聊基于51单片机的交通灯设计,这个项目不仅有趣,还能让你对单片机原理有更深入的理解。

工具准备

咱们这次的设计,会用到两个重要工具:Proteus 8.0用于电路仿真,Keil 4或者Keil 5来编写和编译程序。Proteus就像是一个虚拟的面包板,能让我们在电脑上搭建电路模型并进行测试;而Keil则是程序的“加工厂”,把我们写好的代码变成单片机能够识别和执行的机器语言。

功能实现剖析

1. 红绿灯时间显示与正常切换

这是交通灯最基本的功能啦。我们需要让红、绿、黄灯按照一定的时间规律切换,并且把剩余时间显示出来。

先看看硬件连接,假设我们使用数码管来显示时间,P0口连接数码管段选,P2口连接位选。

// 定义数码管段码表,0 - 9的显示代码 unsigned char code seg_table[] = {0x3F, 0x06, 0x5B, 0x4F, 0x66, 0x6D, 0x7D, 0x07, 0x7F, 0x6F}; void display_time(unsigned char time) { unsigned char tens, units; tens = time / 10; units = time % 10; P0 = seg_table[tens]; // 显示十位 P2 = 0x01; // 选中第一个数码管 delay(1); P0 = seg_table[units]; // 显示个位 P2 = 0x02; // 选中第二个数码管 delay(1); }

这段代码中,displaytime函数接受一个时间参数,将其拆分为十位和个位,然后通过数码管显示出来。segtable数组定义了每个数字对应的段码,通过给P0口赋值段码,P2口选择数码管位,就能实现时间显示。

而对于红绿灯的切换,我们可以通过定时器来精确控制时间。

void timer0_isr(void) interrupt 1 { TH0 = (65536 - 50000) >> 8; // 重新赋值定时器初值,50ms定时 TL0 = (65536 - 50000) & 0xFF; time_count++; if (time_count >= 20) { // 50ms * 20 = 1s time_count = 0; if (green_time > 0) { green_time--; } else if (yellow_time > 0) { yellow_time--; } else if (red_time > 0) { red_time--; } // 根据剩余时间切换信号灯状态 // 代码省略 } }

定时器0每50ms中断一次,timecount累计到20次就是1秒,然后相应的信号灯剩余时间减1。根据不同的剩余时间状态,来切换信号灯亮灭,这里省略了具体的信号灯状态切换代码,主要思路就是根据redtimegreentimeyellowtime的值来控制P1口(假设信号灯连接在P1口)的电平。

2. 按键设置红绿灯时间

为了实现这个功能,我们需要连接几个按键到单片机,比如设置键、加键、减键。

sbit set_key = P3^0; // 设置键连接到P3.0 sbit add_key = P3^1; // 加键连接到P3.1 sbit sub_key = P3^2; // 减键连接到P3.2 void key_scan() { if (set_key == 0) { // 设置键按下 delay(20); // 消抖 if (set_key == 0) { // 进入设置模式 // 代码省略 } while (!set_key); // 等待按键释放 } if (add_key == 0) { delay(20); if (add_key == 0) { // 当前设置的时间加1 // 代码省略 } while (!add_key); } if (sub_key == 0) { delay(20); if (sub_key == 0) { // 当前设置的时间减1 // 代码省略 } while (!sub_key); } }

keyscan函数不断扫描按键状态,当检测到按键按下时,先延时消抖,确认按键确实按下后进入相应的处理逻辑。比如设置键按下,进入设置模式,加键和减键按下,对当前设置的红绿灯时间进行增减操作,这里具体的设置模式和时间增减代码省略,核心就是根据按键状态改变redtimegreentimeyellowtime的值。

3. 交通管制按键

这个按键功能很简单,按下后所有灯变为红灯。

sbit control_key = P3^3; // 交通管制键连接到P3.3 void control_traffic() { if (control_key == 0) { delay(20); if (control_key == 0) { red_time = 60; green_time = 0; yellow_time = 0; // 设置所有灯为红灯,假设P1口控制信号灯 P1 = 0x0C; // 假设红灯对应的二进制值为0x0C } while (!control_key); } }

control_key按键按下并经过消抖确认后,将所有时间设置为红灯时间,同时通过对P1口赋值,点亮所有红灯。

Proteus仿真与Keil程序整合

在Proteus中搭建好交通灯的电路原理图,包括51单片机、数码管、按键、信号灯等元件的连接。然后在Keil中编写上述功能的代码,编译通过后生成hex文件,将hex文件加载到Proteus中的51单片机模型里,就能进行仿真测试啦。如果在仿真过程中发现问题,就需要回头检查硬件连接和代码逻辑,不断调试优化。

通过这个基于51单片机的交通灯设计项目,我们可以学到单片机的定时器应用、按键扫描、数码管显示等基础知识,希望大家都能动手尝试一下,享受嵌入式开发带来的乐趣!

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

你真的会用VSCode吗?揭秘顶尖开发者都在用的行内聊天策略

第一章:VSCode 行内聊天的本质与演进交互模式的重新定义 VSCode 的行内聊天功能并非简单的对话框叠加,而是将 AI 协同编程能力深度集成到编辑器上下文中。它允许开发者在不离开当前代码文件的前提下,直接对选中代码块发起语义问询、生成补全建…

作者头像 李华
网站建设 2026/2/28 19:58:57

多模态Grounding任务新突破!支持边界框生成的训练实例

多模态Grounding任务新突破!支持边界框生成的训练实例 在智能视觉应用日益普及的今天,一个看似简单却极具挑战的问题正被重新审视:如何让AI真正“看懂”图像中的一句话?比如用户指着一张照片说“帮我找到那个穿红裙子的女孩”&…

作者头像 李华
网站建设 2026/2/25 14:56:13

【DevOps安全必修课】:在VSCode中实现敏感文件变更追踪的5种方法

第一章:VSCode中敏感文件编辑差异查看的核心意义在现代软件开发与系统运维中,敏感文件(如配置文件、密钥文件、权限策略等)的管理至关重要。任何未经授权或未被察觉的修改都可能引发安全漏洞、服务中断甚至数据泄露。VSCode 作为广…

作者头像 李华
网站建设 2026/2/25 14:20:37

为什么顶尖程序员都在用VSCode管理语言模型?真相令人震惊

第一章:VSCode语言模型编辑器管理的崛起随着人工智能技术的深入发展,VSCode 正逐步从传统代码编辑器演变为支持语言模型集成的智能开发环境。其灵活的插件架构与开放的 API 接口,使得开发者能够无缝接入各类语言模型服务,实现代码…

作者头像 李华
网站建设 2026/2/26 23:16:15

深度解析:使用Netron可视化DeOldify神经网络架构的完整指南

深度解析:使用Netron可视化DeOldify神经网络架构的完整指南 【免费下载链接】DeOldify A Deep Learning based project for colorizing and restoring old images (and video!) 项目地址: https://gitcode.com/gh_mirrors/de/DeOldify 在深度学习领域&#x…

作者头像 李华
网站建设 2026/2/24 1:00:27

MediaPipe技术迁移终极指南:从Legacy到Tasks的高效升级方案

MediaPipe技术迁移终极指南:从Legacy到Tasks的高效升级方案 【免费下载链接】mediapipe Cross-platform, customizable ML solutions for live and streaming media. 项目地址: https://gitcode.com/GitHub_Trending/med/mediapipe 架构变革的必然性&#xf…

作者头像 李华