单片机课程设计-16个LED灯的多样显示控制器(13页).doc
《单片机课程设计-16个LED灯的多样显示控制器(13页).doc》由会员分享,可在线阅读,更多相关《单片机课程设计-16个LED灯的多样显示控制器(13页).doc(13页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、单片机课程设计单片机课程设计-16 个个 LED 灯的灯的多样显示控制器多样显示控制器信信 息息 工工 程程 学学 院院课课 程程 设设 计计 报报 告告设计题目:节日彩灯控制器设计名称:电子信息工程专业综合课程设计(1)班级:姓名:学号:设计时间:2016.06.22指导教师:评语:评阅成绩:评阅教师:目录目录一、课程设计的性质和目的.1二、课程设计的要求.12.1 设计题目.12.2 设计要求.1三、主要仪器设备及软件.1四、课题分析及设计.14.1 设计任务.24.2 设计方案.24.3 系统硬件设计.24.3.1 单片机最小系统.34.3.2 控制电路介绍.54.3.3 Proteus
2、 电路仿真图.54.4 软件设计.64.4.1 程序流程图.64.4.2 软件程序及分析.8五、组装调试.125.1 硬件.12六、总结.13一、课程设计的性质和目的一、课程设计的性质和目的学习基本理论在实践中综合运用的初步经验,掌握电路设计的基本方法、设计步骤,培养综合设计与调试能力;掌握汇编语言程序设计方法;培养实践技能,提高分析和解决实际问题的能力。二、课程设计的要求二、课程设计的要求2.1 设计题目节日彩灯控制器设计。2.2 设计要求设计一个16个LED灯的多样显示控制器。1.选择两个I/O端口控制16个LED流水灯。2.设置四个按键K1K4,按下K1跑马灯,K2鸳鸯戏水,K3双流水灯
3、,K4则循环三种控制方式。3.跑马灯:共16个LED逐次点亮,每隔100ms点亮一个LED,点亮100ms后关闭,然后继续上次操作。4.鸳鸯戏水灯:第一次单数灯点亮,延时100ms,关闭,然后双数灯点亮,延时100ms,关闭,然后继续上次操作。5.双流水灯:16个LED依次向中间点亮,间隔100ms,再依次向两边扩散点亮,间隔100ms,然后继续上次操作。三、主要仪器设备及软件三、主要仪器设备及软件计算机、KeilC51 软件、Proteus 软件、单片机 AT89C51、LED 灯、电阻、拨码开关、晶振。四、课题分析及设计四、课题分析及设计-第 2 页4.1 设计任务彩灯用 16 个发光二极
4、管代替;电路具有控制 16 个 LED 灯逐个点亮、单数点亮、双数点亮、扩散点亮等功能(用 4 个按键切换 LED 显示状态);彩灯两灯移动时间间隔为 100ms。4.2 设计方案本课题使用 AT89C51 单片机时无须外扩存储器。因此,本流水灯实际上就是一个带有 16 个发光二极管的单片机最小应用系统,即为由发光二极管、晶振、复位、电源等电路和必要的软件组成的单个单片机。如果要让接在 P0.0 口和 P2.0 口的 16 个 LED 亮起来,那么只要把 P0.0 口和P2.0 口的电平变为低电平就可以了;相反,如果要接在 P0.0 口的 LED 熄灭,就要把 P0.0 口的电平变为高电平;同
5、理,接在 P0.1P0.7 口的其他 7 个 LED 的点亮和熄灭的方法同以上 LED。因此,要实现流水灯功能,我们只要将发光二极管LED1LED16 依次点亮、熄灭,16 只 LED 灯便会一亮一暗的做流水灯或跑马灯了。同样的道理,可以让 16 个灯上移或下移点亮,全亮、全灭。在此我们还应注意一点,由于人眼的视觉暂留效应以及单片机执行每条指令的时间很短,我们在控制二极管亮灭的时候应该延时一段时间,否则我们就看不到“流水”效果了。4.3 系统硬件设计AT89C51 是一种带 4K 字节 FLASH 存储器(FPEROMFlash Programmable andErasable Read On
6、ly Memory)的低电压、高性能 CMOS8 位微处理器,俗称单片机。AT89C2051 是一种带 2K 字节闪存可编程可擦除只读存储器的单片机。单片机的可擦除只读存储器可以反复擦除 1000 次。该器件采用 ATMEL 高密度非易失存储器制造技术制造,与工业标准的 MCS-51 指令集和输出管脚相兼容。由于将多功能 8 位 CPU 和闪速存储器组合在单个芯片中,ATMEL 的 AT89C51 是一种高-第 3 页效微控制器,AT89C2051 是它的一种精简版本。AT89C51 单片机为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。外形及引脚排列如图 4.1 所示。图 4.1 AT8
7、9C51 单片机芯片引脚4.3.1 单片机最小系统(1)P0 口介绍P0 口为一个 8 位漏级开路双向 I/O 口,每脚可吸收 8TTL 门电流。当 P0 口的管脚第一次写 1 时,被定义为高阻输入。P0 能够用于外部程序数据存储器,它可以被定义 4 为数据/地址的低八位。在 FIASH 编程时,P0口作为原码输入口,当 FIASH 进行校验时,P0 输出原码,此时 P0 外部必须接上拉电阻(2)P1 口介绍P1 口是一个内部提供上拉电阻的 8 位双向 I/O 口,P1 口缓冲器能接收输出4TTL 门电流。P1 口管脚写入 1 后,被内部上拉为高,可用作输入,P1 口被外部下拉为低电平时,将输
8、出电流,这是由于内部上拉的缘故。在 FLASH 编程和校验时,P1 口作为低八位地址接收。(3)P2 口介绍P2 口为一个内部上拉电阻的 8 位双向 I/O 口,P2 口缓冲器可接收,输出 4个 TTL 门电流,当 P2 口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。并因此作为输入时,P2 口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。P2 口当用于外部程序存储器或 16 位地址外部数据存储器进行存取时,P2 口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2 口输出其特殊功能寄存器的内容。P2 口在FLASH 编程和校验时
9、接收高八位地址信号和控制信号。(4)P3 口介绍P3 口管脚是 8 个带内部上拉电阻的双向 I/O 口,可接收输出 4 个 TTL 门电流。当 P3 口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3 口将输出电流(ILL)这是由于上拉的缘故。P3 口也可作为 AT89C51 的一些特殊功能口。复位系统-第 4 页(5)上电复位电路AT89C51 的上电复位电路如图 4.2 所示,只要在 RST 复位输入引脚上接一电容至 Vcc 端,下接一个电阻到地即可。对于 CMOS 型单片机,由于在 RST 端内部有一个下拉电阻,故可将外部电阻去掉,而将外接电容减至
10、1F。上电复位的工作过程是在加电时,复位电路通过电容加给 RST 端一个短暂的高电平信号,此高电平信号随着 Vcc 对电容的充电过程而逐渐回落,即 RST 端的高电平持续时间取决于电容的充电时间。为了保证系统能够可靠地复位,RST 端的高电平信号必须维持足够长的时间。上电时,Vcc 的上升时间约为 10ms,而振荡器的起振时间取决于振荡频率,如晶振频率为 10MHz,起振时间为 1ms;晶振频率为 1MHz,起振时间则为 10ms。在如图的复位电路中,当 Vcc 掉电时,必然会使 RST 端电压迅速下降到 0V 以下,但是,由于内部电路的限制作用,这个负电压将不会对器件产生损害。另外,在复位期
11、间,端口引脚处于随机状态,复位后,系统将端口置为全“l”态。如果系统在上电时得不到有效的复位,则程序计数器 PC 将得不到一个合适的初值,因此,CPU 可能会从一个未被定义的位置开始执行程序。图 4.2 上电复位电路(6)手动复位电路手动按钮复位需要人为在复位输入端 RST 上加入高电平。一般采用的办法是在 RST 端和正电源 Vcc 之间接一个按钮。如图 4-3 所示,当人为按下按钮时,则Vcc 的+5V 电平就会直接加到 RST 端。手动按钮复位的电路如所示。由于人的动作再快也会使按钮保持接通达数十毫秒,所以,完全能够满足复位的时间要求。图 4.3 手动复位电路(7)晶振系统晶振是给单片机
12、提供工作信号脉冲的.这个脉冲就是单片机的工作速度.比如 12M 晶振.单片机工作速度就是每秒 12M.单片机内部也有晶振,接外部晶振可以或得更稳定的频率。因为晶振与单片机的脚 XTAL0 和脚 XTAL1 构成的振荡电路中会产生偕波(也就是不希望存在的其他频率的波),这个波电路的影响不大,但会降低电路的时钟振荡器的稳定性,如图 4.4 所示。80C51 型单片机内有一高增益反相放大器,按如图连接可构成自激振荡电路,振荡频率取决于石英晶体的振荡频率,范围可取 1.212MHz,C01.C02 主要起频率微调和稳定作用,电容值可取 530Pf。-第 5 页图 4.4 晶振电路4.3.2 控制电路介
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 单片机 课程设计 16 LED 多样 显示 控制器 13
限制150内