单片机交通灯点阵显示小人代码

时间: 2023-07-27 09:06:58 浏览: 39
以下是一个基于51单片机的交通灯点阵显示小人的代码,你可以根据自己的需要进行修改: ```c #include <reg52.h> #define uchar unsigned char #define uint unsigned int // 数码管位选信号 sbit LSA=P2^2; sbit LSB=P2^3; sbit LSC=P2^4; // 8x8点阵位选信号 sbit X1=P2^5; sbit X2=P2^6; sbit X3=P2^7; // 8x8点阵图案 uchar code smgduan[16][8]={ {0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00}, // 空白 {0x00,0x00,0x18,0x3C,0x3C,0x18,0x00,0x00}, // 上方绿灯 {0x00,0x00,0x18,0x3C,0x3C,0x18,0x00,0x00}, // 下方绿灯 {0x00,0x00,0x18,0x18,0x7E,0x18,0x18,0x00}, // 上方黄灯 {0x00,0x00,0x18,0x18,0x7E,0x18,0x18,0x00}, // 下方黄灯 {0x00,0x00,0x18,0x18,0x18,0x18,0x18,0x00}, // 上方红灯 {0x00,0x00,0x18,0x18,0x18,0x18,0x18,0x00}, // 下方红灯 {0x00,0x08,0x1C,0x3E,0x7F,0x3E,0x1C,0x08}, // 小人 }; // 延时函数 void delay(uint i) { while(i--); } // 数码管位选函数 void DigDisplay(uchar num) { switch(num) { case(0): LSA=0;LSB=0;LSC=0;break; case(1): LSA=1;LSB=0;LSC=0;break; case(2): LSA=0;LSB=1;LSC=0;break; case(3): LSA=1;LSB=1;LSC=0;break; case(4): LSA=0;LSB=0;LSC=1;break; case(5): LSA=1;LSB=0;LSC=1;break; case(6): LSA=0;LSB=1;LSC=1;break; case(7): LSA=1;LSB=1;LSC=1;break; } } // 8x8点阵位选函数 void LED_X(uchar i) { switch(i) { case(1): X1=1;X2=0;X3=0;break; case(2): X1=0;X2=1;X3=0;break; case(3): X1=1;X2=1;X3=0;break; case(4): X1=0;X2=0;X3=1;break; case(5): X1=1;X2=0;X3=1;break; case(6): X1=0;X2=1;X3=1;break; case(7): X1=1;X2=1;X3=1;break; } } // 显示函数 void smg_display() { uchar i,j; for(i=1;i<9;i++) { LED_X(i); for(j=0;j<8;j++) { P0=smgduan[i][j]; delay(100); P0=0x00; } } } void main() { uchar i=0; while(1) { DigDisplay(0); // 显示0,即关闭数码管 smgduan[1][1]=0x18; // 上方绿灯 smgduan[6][1]=0x18; // 下方红灯 smg_display(); delay(1000); DigDisplay(0); smgduan[2][1]=0x18; // 上方黄灯 smgduan[5][1]=0x18; // 下方黄灯 smg_display(); delay(1000); DigDisplay(0); smgduan[3][1]=0x18; // 上方红灯 smgduan[4][1]=0x18; // 下方绿灯 smg_display(); delay(1000); for(i=0;i<3;i++) { DigDisplay(i+1); // 显示1~3,即显示小人在不同位置 smgduan[7][i]=0x3C; // 小人 smg_display(); delay(500); smgduan[7][i]=0x00; // 清除小人 } } } ``` 需要注意的是,该代码只是一个简单的示例,实际应用中你需要根据具体需求进行修改。

相关推荐

最新推荐

recommend-type

51单片机交通灯设计(汇编语言)

PDF报告里含有汇编代码和proteus仿真图,中断实验,参照实验电路,设计交通灯控制系统。模拟交通信号灯控制:一般情况下正常显示,东西-南北交替放行,各方向通行时间为 30 秒。有救护车或警车到达时,两个方向交通...
recommend-type

基于AT89C52单片机的智能交通灯系统设计

交通灯启动后,南北方向红灯和东西方向绿灯各亮十秒,然后红灯保持不变,黄灯闪烁五下,之后变为南北方向绿灯和东西方向红灯且各保持十秒,南北方向黄灯闪烁五秒之后转变回南北方向红灯、东西方向绿灯。
recommend-type

基于AT89C51单片机的交通灯控制系统设计与仿真

AT89C51单片机的交通灯控制系统是由AT89C51单片机、键盘电路、LED倒计时、交通灯显示等模块组成。系统除基本交通灯功能外,还具有通行时间手动设置、可倒计时显示、急车强行通过、交通特殊情况处理等相关功能,实验...
recommend-type

基于51单片机的十字路口交通灯控制系统设计(含源码及仿真图)

基于51单片机的十字路口交通灯控制系统设计(含源码及仿真图) (1)东西、南北方向各设有一个绿、黄、红指示灯,两个显示数码管。 (2)两个方向交替允许通行,基本放行时间为25s,另外有黄灯闪烁5s。 (3)控制人员可以...
recommend-type

运用定时器中断写的交通灯程序

这是一个运用51单片机写的交通灯的例子,可以显示时间,红黄蓝等,第一个按键是左右路通行20S,第二个按键是上下路通行20S,第一个按键是所有路都是红灯20S。这是从时钟该来的程序,与上一个始终的程序大体相同。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。