资源描述
单片机系统综合设计报告 课题名称:艺术彩灯控制系统设计指导教师:学生班级:应电08301班学生姓名:学号: 同组人: 学生院系:法商学院电子工程系2010年6月10日 目 录.一 概述1 1.1 艺术彩灯的设计背景及意义1 1.2 系统设计功能概述1 .二 彩灯设计内容简要1 2.1 彩灯设计内容1 2.2 彩灯设计要求1 2.3 彩灯设计原理1 2.4 彩灯总体控制框图2.三 硬件电路设计2 3.1 硬件组成2 3.2 AT89C51单片机硬件结构3 3.3 系统的硬件构成及功能4.四 系统的软件设计54.1 程序流程图64.2 软件程序7.五 设计体会8.六 参考文献9 艺术彩灯控制系统设计一 概述11 艺术彩灯的设计背景及意义彩灯是人们日常生活中的一种装饰用品,它美观大方,尤其在节日期间,倍增节日气氛。它蕴涵着丰富的文化底蕴,被广泛地应用于各种店面的装饰。变换无穷的彩灯样式,给城市增添活力,吸引着人们的注意力,深受人民的喜爱。在日常生活中,人们还将彩灯摆放成各种图案,增添美感。随着电子技术的发展,应用系统向着小型化、快速化、大容量、重量轻的方向发展。科学技术更加贴近人们的生活,向着满足人们需求的方向发展。节日彩灯的设计与制作工艺也一步一步的走向成熟。1.2 系统设计功能概述本设计是以AT89C51单片机为基础的彩灯控制方案,来实现对LED彩灯的控制。以AT89C51单片机作为主控核心,与键盘、显示、驱动等模块组成核心主控制模块。在主控模块上设有5个按键和8位LED状态显示器,根据实验要求编写若干种亮灯模式,利用其内部定时器T0实现一个基本单位时间为5ms的定时中断,根据各种亮灯时间的不同需要,在不同时刻输出灯亮或灯灭的控制信号,然后驱动各种颜色的灯亮或灭。二彩灯设计内容简要:2.1彩灯设计内容:1设计并实现具有复位功能的单片机小系统;2利用单片机进行灯光的场景开关控制;3利用单片机进行灯光的循环点亮控制及速度变化控制;4利用单片机进行灯光的色彩连续变化效果控制。5利用单片机进行灯光的三色联动定时控制。2.2彩灯设计要求:1能启动、停止;2能通过开关进行功能选择;3要体现循环、组合和色彩变化的控制功能和效果,实现三色联动定时控制,控制变化规律的类型或功能不少于5种;2.3彩灯设计原理: 主控模块主要设计器件有89C51,8个LED状态显示器,6个按键,3个稳压器(提供5 V电压)。通过软件设计,使单片机P1口作为三色LED驱动信号输出口及移位时钟CLOCK信号,P0口为按键输入口,P2口、P1口与8位七段码LED相接作为显示器的输出口。2.4彩灯总体控制框图:LED显示电路时钟电路复位电路按键电路AT89C51单片机三硬件电路设计:3.1硬件组成按照单片机系统扩展与系统配置状况,单片机应用系统可分为最小系统、最小功耗系统及典型系统等。AT89C51单片机是美国ATMEL公司生产的低电压、高性能CMOS 8位单片机,具有丰富的内部资源:4kB闪存、128BRAM、32根I/O口线、2个16位定时/计数器、5个向量两级中断结构、2个全双工的串行口,具有4.255.50V的电压工作范围和024MHz工作频率,使用AT89C51单片机时无须外扩存储器。因此,本流水灯实际上就是一个带有八个发光二极管的单片机最小应用系统,即为由发光二极管、晶振、复位、电源等电路和必要的软件组成的单个单片机3.2 AT89C51单片机硬件结构:AT89C51是一种带4K字节闪存可编程可擦除只读存储器(FPEROMFlash Programmable and Erasable Read Only Memory)的单片机芯片,它采用静态CMOS 工艺制造8位微处理器,最高工作频率位24MHZ。AT89C5外形及引脚排列如图所示: 管脚说明: RST:复位输入。当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。 P0口:P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。当P1口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在FIASH编程时,P0 口作为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。 P1口:P1口是一个内部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。P1口管脚写入1后,被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在FLASH编程和校验时,P1口作为第八位地址接收。 P2口:P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器的内容。P2口在FLASH编程和校验时接收高八位地址信号和控制信号。 P3口:P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3口将输出电流(ILL)这是由于上拉的缘故。 ALE/PROG:当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可用作对外部输出的脉冲或用于定时目的。然而要注意的是:每当用作外部数据存储器时,将跳过一个ALE脉冲。如想禁止ALE的输出可在SFR8EH地址上置0。此时, ALE只有在执行MOVX,MOVC指令是ALE才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ALE禁止,置位无效。 PSEN:外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机器周期两次PSEN有效。但在访问外部数据存储器时,这两次有效的PSEN信号将不出现。 EA/VPP:当EA保持低电平时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。注意加密方式1时,EA将内部锁定为RESET;当EA端保持高电平时,此间内部程序存储器。 XTAL1和XTAL2:反向振荡放大器的输入及内部时钟工作电路的输入。 33系统的硬件构成及功能描述:控制系统硬件设计电路图如图所示: 系统硬件设计电路图功能描述:系统硬件设计电路主要由四部分组成:按键复位电路、时钟振荡电路、按键电路、LED显示电路。按键复位电路:复位是单片机的初始化操作,其作用是使CPU中的各个部件都处于一个确定的初始状态,并从这个状态开始工作。在接电瞬间RST端的电位与Vcc相同,随着电容充电电流的减小,+5V立即加到了RST/VPD端,RST的电位逐渐下降。 时钟振荡电路:在AT89C51的外部,XTAL1和XTAL2之间跨越晶体振荡器和微调电容,从而构成一个自激振荡器,形成时钟振荡电路。时钟电路产生的振荡脉冲经过触发器二分频后,形成单片机的时钟脉冲信号。按键电路:用P0.0P0.5五个I/O口作为输入口,按键输入均采用低电平有效。独立式按键的软件可采用中断方式和查询方式,本设计中按键程序的就是采用中断方式。图中P0.0的按键是场景开关,即控制整个系统。LED显示电路:发光二极管与单片机的P1口相连接,其电路图如图所示。发光二极管接+5V电源,其他管脚分别接P1口的8个端口.此次设计发光二极管可显示两种状态,适合用于显示系统状态。此处用到8个,红、绿、黄三种LED彩灯控制器(89C51主控模块)和LED彩灯管(管内LED板模块)。 四系统的软件设计 4.1程序流程图: 程序如下:ORG 0000H AJMP START ;指向主程序 ORG 0010HMAIN:MOV P1,#0FFH ;设置P1口为输入口START: MOV P0,#0FFH ;初始状态,选择场景控制开关 JNB P0.0,KEY0 SJMP STARTKEY0: JNB P0.1, KEY1 JNB P0.2, KEY2 JNB P0.3, KEY3 JNB P0.4, KEY4 SJMP STARTSTART1: MOV P0, #0FFH ACALL DELAY MOV A, P1 ;送显示初值 JNB ACC.1, KEY1 ;ACC.1=0?若为0则P1.1对应的键按下,转KEY1 JNB ACC.2, KEY2 ;ACC.2=0?若为0则P1.2对应的键按下,转KEY2 JNB ACC.3, KEY3 ;ACC.3=0?若为0则P1.3对应的键按下,转KEY3 JNB ACC.4, KEY4 ;ACC.1=0?若为0则P1.4对应的键按下,转KEY4 SJMP START1 KEY1:MOVR2,#08H MOVR5,#0FEHNEXT0:MOVA,P0 JNB ACC.3,KEY4 JNB ACC.4,KEY3 JB ACC.0,MAIN MOVA,R5 MOVP1,A ;点亮灯 ACALLDELAY MOVA,R5 RL A ;左移,下一个灯亮 MOVR5,A DJNZR2,NEXT0 SJMPKEY1KEY2: MOV A,P0 ;按键2,三色联动,JB ACC.0,MAIN ;检测开关是否按下 JNB ACC.4, KEY3 JNB ACC.3, KEY4 MOV P1,#0DAH ACALL DELAY2 MOV P1,#0C7H ACALL DELAY2 MOV P1,#06EH ACALL DELAY2 AJMP KEY2LP1: JBC TF1, LP2 SJMP LP1LP2: MOV TH1, #0B1H MOV TL1, #0E0H DJNZ R3, LP1 RETKEY3: ACALL DELAY MOV A,R6 ;循环点亮加速 ADD A,#3H MOV R6,A SJMP NEXT0KEY4 : ACALL DELAY ;循环点亮减速 MOV A,R6 MOV A,#3H MOV R6,A SJMP NEXT0DELAY: MOV R3, #14H ;加速减速,延时程序 MOV TMOD, #10H MOV TH1, #0B1H MOV TL1, #0E0H SETB TR1DELAY2:CALLDELAY CALL DELAY RET END五设计体会:历时五个星期的单片机课程设计,我从中受益匪浅。因为对我而言学到的不仅是专业知识,而且是团队的合作精神。在本次课程设计中,我主要感触最深的当属查阅大量的设计资料了。为了让自己的设计更加完善,查阅这方面的设计资料是十分必要的,同时也是必不可少的。作为一个团队,分工就显得尤为重要,我主要负责系统硬件电路设计和最终调试的任务,我和搭档互相帮助,彼此勉励,有问题一起寻求解决之道。虽然一开始我们就对方案的选择发生分歧,但这丝毫不影响我们的交流、探讨。因为大家初衷是一样的。开始设计的功能不能全部实现出来,于是拿着程序反复分析和修改,在老师和同学的帮助指导下最终找出错误所在。经过总结和分析,我和组员一致认为要做好一个课程设计,就必须做到:在设计程序之前,对所用单片机的内部结构有一个系统的了解,知道该单片机内有哪些资源;要有一个清晰的思路和一个完整的的软件流程图;在设计程序时,不能妄想一次就将整个程序设计好,反复修改、不断改进是程序设计的必经之路;要养成注释程序的好习惯,一个程序的完美与否不仅仅是实现功能,而应该让人一看就能明白你的思路,这样也为资料的保存和交流提供了方便;在设计课程过程中遇到问题是很正常,但我们应该将每次遇到的问题记录下来,并分析清楚,以免下次再碰到同样的问题。 这次课程设计使我明白理论与实际相结合的重要,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从而提高自己的实际动手能力和独立思考的能力。同时在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固。在接下来的复习中我会再接再厉,加深对单片机相关知识的理解。六参考文献:单片机应用技术张晔王玉民出版社:高等教育出版社 出版日期:2006.6跟我学用单片机. 肖洪兵 北京航空航天大学出版社 出版日期:2002.8 单片机实践应用与技术马长林、陈怡 北京大学出版社 出版日期:2008单片机高级教程第1版 何立民 北京航空航天大学出版社 出版日期:2001单片机课程设计指导 程成 出版社 清华大学出版社 出版日期:2009单片机原理及接口技术 李朝清 北京航空航天大学出版社出 版日期:1999
展开阅读全文