1、. . . . 学院毕 业 论 文 (设 计)题目:51单片机教学实验系统设计学生王秋桐学 号084110122专 业计算机科学与技术班 级2008级1班指导教师洪涛学 部计算机科学与电气工程答辩日期2012年5月19日学院本科生毕业论文(设计)评语(一)王秋桐学号084110122专业班级计算机科学与技术08级1班总成绩毕业论文(设计)题目:51单片机教学实验系统设计答辩委员会评语答辩成绩主任签字: 年 月 日答辩委员会成员签字学部毕业论文(设计)领导小组意见组长签字: 年 月 日 学部公章学院本科生毕业论文(设计)评语(二)王秋桐学号084110122专业班级计算机科学与技术08级1班毕业
2、论文(设计)题目:51单片机教学实验系统设计指导教师评语指导教师成绩所选毕业论文题目难度适中,主要涉与高校单片机实践教学,具有较高的研究价值,设计容与方法较为典型,若进一步完善和创新并应用于高等教育工作,可获得较好效果。该同学在毕业设计期间,能积极地查阅相关资料,利用专业所学和相关软、硬件平台工具开展设计工作,设计目标明确,态度认真,方法得当,但由于工作原因,未能全部完成硬件设计,所设计目标模块的电子仿真运行正常。目标系统可进行实际教学所需要的实验项目。毕业论文各章节容明确,层次较为清晰,硬件系统核心采用STC89C52单片机,软件系统使用嵌入式C语言开发,采用模块化程序设计方法。硬件系统系统
3、包括51单片机主控制器模块、键盘模块、AD模块、DA模块、DS1302时钟模块、测温模块、MAX232模块、MAX485模块、数码管模块、LCD1602模块、LCD12864模块、下载器模块、流水灯模块、蜂鸣器模块。论文容充实,实现了开题报告中的预期设计目标,格式符合“学院本科生毕业设计(论文)规”基本要求,同意其按期参加答辩。指导教师签字: 年 月 日学院本科生毕业论文(设计)评语(三)王秋桐学号084110122专业班级计算机科学与技术08级1班毕业论文(设计)题目:51单片机教学实验系统设计评阅教师评语评阅教师成绩王秋桐同学所选毕业论文(设计)主要是关于单片机实践教学设备的研究与设计,在
4、论文的组织与设计中采用“自顶向下,逐步细化”的设计方法,利用相关软、硬件开发平台,根据开题报告中所确定的设计目标和研究方法开展了相关设计工作。系统硬件主要包括51单片机主控制器模块、键盘模块、AD模块、DA模块、DS1302时钟模块、测温模块、MAX232模块、MAX485模块、数码管模块、LCD1602模块、LCD12864模块、下载器模块、流水灯模块、蜂鸣器模块,采用模块化程序设计方法;软件设计主要应用KEIL编程开发环境,根据硬件需求编写相应程序。从论文设计中,体现出该同学具有一定的软、硬件分析与设计能力,以与嵌入式系统综合开发能力。毕业论文设计目标明确,结构合理,语言表达准确,容充实,
5、格式符合“学院本科生毕业设计(论文)规”基本要求,同意其按期参加答辩。评阅教师签字: 年 月 日学院本科生毕业论文(设计)任务书王秋桐学号084110122专业班级计算机科学与技术08级1班毕业论文(设计)题目:51单片机教学实验系统设计毕业论文(设计)的立题依据在现代大学教学当中,我们只注重了计算机专业的软件开发,从而很少关注计算机的硬件发展,就现在的发展来看微型计算机的发展也是占了很重要的一部分,例如基于ARM开发的linux和Android系统,而这一切的开发基础是微型计算机的应用,为使大学生充分了解和熟悉微型计算机而做了一款基础教学实验板。主要容与要求1、 51单片机的研究;2、 适于
6、计算机专业的学生了解学习;3、 51单片机的外部扩展;4、 51单片机相应教学实验软件编写;进度安排12月12日选题12月13日12月29日接受指导老师的指导12月30日1 月17日拟定论文大纲1 月18日2 月26日搜集、查阅、整理相关资料2 月27日3 月27日初稿形成3 月28日4 月8 日初稿审定4 月9 日4 月17日第一次修改4 月18日4 月22日第一次审定4 月23日5 月3 日第二次修改5 月4 日5 月9 日定稿5 月10 日5 月18日论文评阅小组评审论文(设计)5 月19日毕业论文(设计)答辩学生签字:指导教师签字:年 月 日- 54 - / 64基于51单片机教学实验
7、系统设计摘 要51系列单片机教学实验板既是一块用户实验板,又是一种功能强大而实用的单片机开发调试工具。采用本仿真开发实验板,可使初学者迅速掌握单片机原理与应用,熟习汇编语言甚至单片机C语言。用本仿真开发实验板,对用户源程序进行实时在线调试,可极大的缩短单片机应用系统的开发时间。本设计主要应用于现代大学教学实验,对于充实现代大学生的动手实践能力而制作这款以51单片机为基础的教学试验系统,他可以是学生将学习的软件网络知识联系到一起,实现嵌入式的基本操作。本系统包含了51单片机最小系统,LED流水灯,按键,温度控制,液晶显示等多重功能。主要是以汇编语言与嵌入式C语言为主。关键词:单片机;实验板;接口
8、;汇编语言;C语言The Designed of 51 Serial Single Chip Processor Teaching Experiment BoardAbstract51 serial single chip processor teaching experiment board is a user experiment board, and also a powerful and practical single chip processor develop and debug tools.With this experiment board, the beginners ca
9、n easily to grasp the principle and application of the MCU,be familiar with assemble languages , even the C51 languages. The character of on system debug can shorten the time to study Develop experiment board with emulation this, carry on to user source program real-time to debug online, can shorten
10、 construction period of the application system of the single chip processor greatly.This design mainly used in modern university teaching experiment, to enrich the modern college students practical ability and making this based on a 51 single chip microcomputer teaching test system, he can be the st
11、udents will learn the software network knowledge together, realizes the embedded basic operation. The system contains 51MCU minimum system, LED running lights, buttons, temperature control,liquid crystal display multiple functions such as. Mainly in the assembly language and C language embedded.Keyw
12、ords:single chip processor;experiment board;interface;assemble languages;C languages小提示:当需要从网站或者文档复制到本文档时,先将文字复制到文本文档,然后再从文本文档复制到本文档的相应位置,这样就能够保证格式是正确的!此行不会被打印千万不要删除行尾的分节符,此行不会被打印。(在word菜单-工具-选项-视图标签中,格式标记部分请全部打对号,这样就可以看到隐藏的分节符和空格等信息了)目录摘要IAbstractII第1章 绪论1第2章 51单片机系统设计方案22.1 总体设计方案22.2 设计原则22.3 本章小
13、结3第3章 51单片机硬件设计部分43.1 硬件结构框图43.2 硬件电路设计43.2.1键盘模块53.2.2 DA模块63.2.3 DS1302时钟模块73.2.4测温模块93.2.5串行通信模块103.2.6显示模块123.2.7下载器模块163.2.8其他模块183.3 本章小结19第4章 总体设计204.1 总体程序设计204.2 分模块程序设计204.2.1 键盘模块程序设计204.2.2 DA模块程序设计214.2.3 DS1302时钟模块程序设计234.2.4 测温模块程序设计264.2.5 串行通信模块程序设计294.2.6 显示模块程序设计304.2.7 其他模块374.3
14、本章小结39第5章 开发板设计测试405.1 开发板PCB设计405.2 开发板测试405.3 本章小结41结论42参考文献43附 录44致51千万不要删除行尾的分节符,此行不会被打印。在目录上点右键“更新域”,然后“更新整个目录”51单片机教学实验系统设计第1章 绪论单片机具有成本低、体积小、可靠性高、具有高附加值、通过更改软件就可以改变控制对象等优点,单片机越来越成为电子工程师设计产品时的首选器件之一。因此拥有一块单片机开发板对单片机学习具有着极其重要的意义。但是单片机学习效果的优劣直接取决于单片机的选择,C51系列单片机部具有128字节RAM、5个中断源、32条I/O口线、2个16位定时
15、器、4KB的程序存储器、一个全双工异步串行口。本开发板选择具有ISP在线编程功能的S51单片机,该单片机不需要烧写器,可在开发板上ISP在线编程,具有广泛的应用前景1。S51单片机除兼容C51单片机外,还具有工作频率0至33MHz的高工作频率;可以满足绝大多数的实际应用开发需求,在开发板上使用十分方便。本课题设计的S51单片机开发板,具有一般开发板通用结构,并基于硬件进行相关软件设计。利用程序开发语言开发程序并实现ISP在线下载到单片机,无需配置单独的下载器。单片机使用ISP在线下载程序,加快了程序设计者调试的进度,使设计者所设计的程序尽快得到验证。通过对开发板上的模块进行实验,可以提高针对不
16、同硬件进行编程的能力,同时通过实验现象对所用的硬件也有了更深一步的认识,因此该开发板具有一定的实用价值和现实意义。第2章 51单片机系统设计方案2.1 总体设计方案本开发板共分为十四个模块,分别是:51单片机主控制器模块、键盘模块、AD模块、DA模块、DS1302时钟模块、测温模块、MAX232模块、MAX485模块、数码管模块、LCD1602模块、LCD12864模块、下载器模块、流水灯模块、蜂鸣器模块。其中以S51单片机作为核心控制器;键盘模块用来向单片机输入特定编码的信息;AD模块用来实现模数转换;DA模块用来实现DA转换;DS1302时钟模块用来实现实时时钟;测温模块用来测量环境温度;
17、RS232模块和RS485模块通过电平转换实现通信;数码管模块用来显示简单的数字、字母;LCD1602模块用来显示字母、数字、符号;LCD12864模块用来显示图像、符号、汉字;下载器模块用来实现S51单片机的ISP在线编程;流水灯模块用来显示单片机I/O口电平的变化;蜂鸣器模块用来发出声音。2.2 设计原则开发板系统的扩展和配置应遵循以下设计原则: (1)尽可能选择典型电路,并符合单片机常规用法。为硬件系统的标准化、模块化打下良好的基础;(2)系统扩展与外围设备的配置水平应充分满足应用系统的功能要求,并留有适当余地,以便进行二次开发; (3)硬件结构应结合应用软件方案一并考虑。硬件结构与软件
18、方案会产生相互影响,考虑的原则是:软件能实现的功能尽可能由软件实现,以简化硬件结构。但必须注意,由软件实现的硬件功能,一般响应时间比硬件实现长,且占用CPU时间;(4)系统中的相关器件要尽可能做到性能匹配。如选用CMOS芯片单片机构成低功耗系统时,系统中所有芯片都应尽可能选择低功耗产品; (5)可靠性与抗干扰设计是硬件设计必不可少的一部分,它包括芯片、器件选择、去耦滤波、印刷电路板布线、通道隔离等;(6)单片机外围电路较多时,必须考虑其驱动能力。驱动能力不足时,系统工作不可靠,可通过增设线驱动器增强驱动能力或减少芯片功耗来降低总线负载; (7)尽量朝“单片”方向设计硬件系统。系统器件越多,器件
19、之间相互干扰也越强,功耗也增大,也不可避免地降低了系统的稳定性。2.3 本章小结本章主要注意单片机原理应用,对于单片机外围电路的设计要有正确的规划,考虑到影响系统工作的各种外在因素,还应注意系统整体运行时的流畅性与可调节性。注意:除第一章绪论外,其他每一章都应该有一个本章小结第3章 51单片机硬件设计部分3.1 硬件结构框图总体硬件结构主要包括:51单片机主控制器模块、键盘模块、AD模块、DA模块、DS1302时钟模块、测温模块、MAX232模块、MAX485模块、数码管模块、LCD1602模块、LCD12864模块、下载器模块、流水灯模块、蜂鸣器模块2。硬件结构框图如图3-1所示: 51单片
20、机主控制模块流水灯模块蜂鸣器模块AD模块数码管模块LCD12864模块LCD1602模块MAX23222模块键盘模块DS1302实时时钟模块测温模块图3-1 总体硬件结构框图硬件结构框图参考附录图D-1。3.2 硬件电路设计51单片机最小系统包括:MCU、复位电路、晶振电路。原理图如图3-2所示: 图3-251单片机主控制模块原理图采用按键复位方式,选取晶振为12MHZ,系统机器周期为1us3。3.2.1 键盘模块在键盘中按键数量较多时,为了减少I/O口的占用,通常将按键排列成矩阵形式,如图3-3所示:图3-3 键盘模块原理图JP7用来连接P2口与矩阵键盘模块,在矩阵式键盘中,每条水平线和垂直
21、线在交叉处不直接连通,而是通过一个按键加以连接。这样,一个端口(如P2口)就可以构成4*4=16个按键,比之直接将端口线用于键盘多出了一倍,而且线数越多,区别越明显,比如再多加一条线就可以构成20键的键盘,而直接用端口线则只能多出一键(9键),在需要的按键数较多时,采用矩阵法来做键盘是合理的4。3.2.2 DA模块1TLC5615简介TLC5615为美国仪器公司1999年推出的产品,是具有串行接口的数模转换器,其输出为电压型,最大输出电压是基准电压值的两倍。带有上电复位功能,即把DAC寄存器复位至全零。TLC5615性能价格比高,目前在国市场很方便购买。主要性能指标有:10位CMOS电压输出;
22、5V单电源供电;与CPU三线串行接口;最大输出电压可达基准电压的二倍;输出电压具有和基准电压一样极性;建立时间12.5s;部上电复位;低功耗,最大仅1.75mW。4TLC5615有小型和塑料DIP封装,DIP封装的TLC5615芯片引脚排列如图3-4所示:图3-4 TLC5615引脚排列图引脚功能说明如下: DIN串行数据输入端; SCLK串行时钟输入端; CS芯片选用通端,低电平有效; DOUT用于级联时的串行数据输出端; AGND模拟地; REFIN基准电压输入端; OUTDAC模拟电压输出端; VDD正电源端。 2硬件实现DA模块的原理图如图3-5所示:图3-5 DA模块原理图单片机与T
23、LC5615通过P2.0、P2.1、P2.2相连,分别为片选信号线、时钟信号线、数据输入信号线。TLC5615转换后的模拟信号通过OUT端输出。3.2.3 DS1302时钟模块1DS1302简介DS1302是美国DALLAS公司推出的一种高性能、低功耗、带RAM的实时时钟芯片,它可以对年、月、日、周日、时、分、秒进行计时,且具有闰年补偿功能,工作电压宽达2.55.5V。采用三线接口与MCU进行同步通信,并可采用突发方式一次传送多个字节的时钟信号或RAM数据。DS1302部有一个31*8的用于临时性存放数据的RAM寄存器。主要性能指标有:31字节带后备电池的RAM用于数据存储;串行I/O口,管脚
24、数量少;宽围工作电压:2.05.5V;工作电压2.0V时,电流小于300nA;读/写时钟或RAM数据时有两种传送方式单字节传送和突发模式传送;8 脚DIP封装或其他可选封装方式;简单的3线接口;与TTL 兼容(Vcc = 5V);可选工业级温度围:- 40+ 85;与DS1202 兼容4。DS1302 的引脚如图3-6所示:图3-6 DS1302引脚图Vcc1为后备电源,Vcc2为主电源。在主电源关闭的情况下,也能保持时钟的连续运行。DS1302由Vcc1或Vcc2两者中的较大者供电。当Vcc2高于Vcc1 + 0. 2V时,Vcc2给DS1302供电。当Vcc2低于Vcc1时,DS1302由
25、Vcc1 供电。X1、X2为振荡源,外接32. 768 kHz晶振。I/O为串行数据输入/输出端(双向),SCL K为时钟输入端。RST是复位片选线,通过把RST输入驱动置为高电平来启动所有的数据传送。RST输入有两种功能:RST接通控制逻辑,允许地址/命令序列送入移位寄存器;RST提供了终止单字节或多字节数据的传送手段。当RST为高电平时,所有的数据传送被初始化,允许DS1302进行操作。如果在传送过程中置RST为低电平,则会终止此次数据传送,并且I/ O引脚变为高阻态。上电运行时,在Vcc高于2. 5V之前,RST必须保持低电平。只有在SCL K为低电平时,才能将RST置为高电平。2硬件实
26、现DS1302时钟模块的原理图如图3-7所示:图3-7 DS1302时钟原理图单片机与DS1302通过P3.5、P3.6、P3.7相连,分别为时钟信号线、输入输出线、复位信号线。DS1302的晶振引脚连接32768HZ的晶振。3.2.4 测温模块1DS18B20简介DS18B20 是DALLAS 半导体公司生产的,是一种单总线温度传感器,属于新一代适配微处理器的智能温度传感器,有两种封装形式分别为3脚PR-35封装和16脚SSOP封装。本文采用的是3脚PR-35封装,其具有以下特点:采用了单总线技术,传感器直接以二进制输出被测温度,可通过串行口线,也可与单机通过I/O 口连接;测量温度围为:-
27、 55+125,测量精度高达+0.5;含寄生电源,在两线方式下可通过数据线提供寄生电源,而不需要再单独供电;转换时间在分辨率为12位(即0.0625)时最大为750ms;用户可分别对每个器件设定温度上下限;DS18B20 在使用时不需要任何外围元件,全部传感元件与转换电路集成在形如一只三极管的集成电路;电源极性接反时,芯片不会因发热而烧毁,但不能正常工作;每个DSl8B20 器件对应一个唯一的64 位长的序号,该序号值存放ROM中,可通过序号匹配实现多点测温。引脚排列如图3-8所示5:图3-8 DS18B20引脚图VDD:接电源引脚,电源供电3.05.5V;DQ:数据的输入和输出引脚;GND:
28、接地;2硬件实现DS18b20温度传感器模块的原理图如图3-9所示:图3-9 DS18b20温度传感器模块原理图单片机与DS18B20通过P3.7相连,作为数据/控制信号线。3.2.5 串行通信模块1RS232串行通信模块RS232是由电子工业协会(Electronic Industries Association,EIA) 所制定的异步传输标准接口。对于一般双工通信,仅需几条信号线就可实现,如一条发送线、一条接收线与一条地线6。RS232与TTL电路之间需要进行电平和逻辑关系的变换。实现这种变换的方法可用分立元件,也可用集成电路芯片。MAX232芯片可完成TTLRS232双向电平转换。MAX
29、232芯片是RS232标准接口芯片,使用+5v单电源供电。是PC机与单片机串口进行通讯的电平转换芯片。部结构基本可分三个部分:第一部分是电荷泵电路。由1、2、3、4、5、6脚和4只电容构成。功能是产生+12v和-12v两个电源,提供给RS232串口电平的需要。第二部分是数据转换通道。由7、8、9、10、11、12、13、14脚构成两个数据通道。其中13脚(R1IN)、12脚(R1OUT)、11脚(T1IN)、14脚(T1OUT)为第一数据通道。8脚(R2IN)、9脚(R2OUT)、10脚(T2IN)、7脚(T2OUT)为第二数据通道。TTL/CMOS数据从T1IN、T2IN输入转换成RS232
30、数据从T1OUT、T2OUT送到电脑DP9插头;DP9插头的RS232数据从R1IN、R2IN输入转换成TTL/CMOS数据后从R1OUT、R2OUT输出。第三部分是供电。15脚DNG、16脚VCC(+5V)。MAX232模块的原理图如图3-10所示:图3-10 MAX232模块的原理图MAX232模块参考过附录图D-4。单片机与MAX232通过P3.0、P3.1相连,分别为发送线、接收线,另外单片机要与MAX232共地。2RS485串行通信模块RS232由于传输速率慢,传输距离短,传输信号易受外界的干扰等缺点。新的串行通讯接口标准RS-449被制定出来,与之相对应的是RS-485的电气标准。
31、RS-485是美国电气工业联合会(EIA)制定的利用平衡双绞线作传输线的多点通讯标准。它采用差分信号进行传输;最大传输距离可以达到1.2 km;最大可连接32个驱动器和收发器;接收器最小灵敏度可达200 mV;最大传输速率可达2.5 Mb/s。由此可见,RS-485协议正是针对远距离、高灵敏度、多点通讯制定的标准。MAX485的引脚和结构如下图3-11所示:图3-11 MAX485的引脚和结构该芯片采用单一电源+5 V工作,额定电流为300 A,采用半双工通讯方式。它完成将TTL电平转换为RS-485电平的功能。MAX485芯片的结构和引脚都非常简单,部含有一个驱动器和接收器。RO和DI端分别
32、为接收器的输出和驱动器的输入端,与单片机连接时只需分别与单片机的RXD和TXD相连即可;/RE和DE端分别为接收和发送的使能端,当/RE为逻辑0时,器件处于接收状态;当DE为逻辑1时,器件处于发送状态,因为MAX485工作在半双工状态,所以只需用单片机的一个管脚控制这两个引脚即可;A端和B端分别为接收和发送的差分信号端,当A引脚的电平高于B时,代表发送的数据为1;当A的电平低于B端时,代表发送的数据为0。在与单片机连接时接线非常简单。只需要一个信号控制MAX485的接收和发送即可。同时将A和B端之间加匹配电阻,一般可选100的电阻。MAX485模块的原理图如图3-12所示:图3-12 MAX4
33、85模块原理图单片机与MAX485通过P3.0、P3.1、P3.2相连,分别为接收输出线、发送输入线、发送/接收使能信号线。3.2.6 显示模块1数码管模块(1) 数码管驱动采用8位数据缓冲器74HC573,其功能表如下表3-1所示7:表3-1 74HC573功能表OPERATINGMODESINPUTINTERNALLATCHESOUTPUTSOELEDNQ0 to Q7enable and read registerLHLLLLHHHHLatch and read registerLLILLLLhHHLatch register and disable outputsHLILZHLhHZ注
34、意:H=高电平h=要保持高电平到低电平转变时一个建立周期以上的高电平L=低电平I=要保持高电平到低电平转变时一个建立周期以上的低电平Z=高组态 选用74HC573增强驱动能力,提高数码管显示亮度。A-DP对应八段数码管的各段,当A-DP中有低电平输出时,被低电平片选中的数码管的相应段点亮。(2) 硬件实现:数码管模块的原理图如图3-13所示:图3-13 数码管模块原理图单片机与74HC573通过P0.0、P0.1、P0.2、P0.3、P0.4、P0.5、P0.6、P0.7相连,作为段码信号线;与74HC138通过P1.0、P1.1、P1.2相连,作为片选信号线。2LCD1602模块(1) LC
35、D1602简介:LCD1602点阵字符液晶模块是由点阵字符液晶显示器件和专用的行列驱动器,控制器与必要的连接件,结构件装配而成,可以显示数字和英文字符。LCD1602采用标准的14脚(无背光)或16脚(带背光)接口,各引脚接口说明如表3-2所示8:表3-2 LCD1602引脚接口图编号符号引脚说明编号符号引脚说明1VSS电源地9D2数据2VDD电源正极10D3数据3VL液晶显示偏压11D4数据4RS数据/命令选择12D5数据5R/W读/写选择13D6数据6E使能信号14D7数据7D0数据15BLA背光源正极8D1数据16BLK背光源负极(2) 硬件实现: LCD1602模块的原理图如图3-14
36、所示:图3-14 LCD1602模块原理图单片机与LCD1602通过P0.0、P0.1、P0.2、P0.3、P0.4、P0.5、P0.6、P0.7、P1.0、P1.1、P1.2相连,P0.0P0.7为数据线,P1.0、P1.1、P1.2为控制线。3LCD12864模块(1) LCD12864简介:LCD12864汉字图形点阵液晶显示模块可以显示汉字、图形、ASC码和自定义字形,置8192个16*16的中文汉字、128个8*16字符、以与64*256点阵显示RAM,控制器为ST7920,具有串/并接口方式,其部含有中文字库,LCD12864显示屏为128*64点阵,可显示4行,每行8个字,模块含
37、有多种软件功能:光标显示、画面移位、自定义字符、反白、清除、关闭显示和睡眠模式等,可方便地对模块进行控制。模块置升压电路,无需负压,配置LED背光。3V低电平工作时,只需一个20K的电阻与Vo的地相接。适用于3.3V5V宽围工作电压的系统。LCD12864的并行接口见表3-3:表3-3 LCD12864的并行接口管脚号管脚名称电平管脚功能描述1VSS0V电源地2VCC3.0+5V电源正3V0-对比度(亮度)调整4RS(CS)H/LRS=“H”,表示DB7DB0为显示数据RS=“L”,表示DB7DB0为显示指令数据5R/W(SID)H/LR/W=“H”,E=“H”,数据被读到DB7DB0R/W=
38、“L”,E=“HL”, DB7DB0的数据被写到IR或DR6E(SCLK)H/L使能信号7DB0H/L三态数据线8DB1H/L三态数据线9DB2H/L三态数据线10DB3H/L三态数据线11DB4H/L三态数据线12DB5H/L三态数据线13DB6H/L三态数据线14DB7H/L三态数据线15PSBH/LH:8位或4位并口方式,L:串口方式(见注释1)16NC-空脚17/RESETH/L复位端,低电平有效(见注释2)18VOUT-LCD驱动电压输出端19AVDD背光源正端(+5V)(见注释3)20KVSS背光源负端(见注释3)RS,R/W的配合决定的4种模式见表3-4:表3-4 RS、R/W决
39、定的控制模式RSR/W功能说明LLMPU写指令到指令暂存器(IR)LH读出忙标志(BF)与地址记数器(AC)的状态HLMPU写入数据到数据暂存器(DR)HHMPU从数据暂存器(DR)中读出数据E信号的状态产生的动作见表3-5:表3-5 E信号的状态产生的动作E状态执行动作结果高低I/O缓冲DR配合/W进行写数据或指令高DRI/O缓冲配合R进行读数据或指令低/低高无动作 (2) 硬件实现:开发板上LCD12864模块的原理图如图3-15所示:图3-15LCD12864模块原理图单片机与LCD12864通过P0.0、P0.1、P0.2、P0.3、P0.4、P0.5、P0.6、P0.7、P1.0、P
40、1.1、P1.2相连,P0.0P0.7为数据线,P1.0、P1.1、P1.2为控制线。3.2.7 下载器模块ATmega8是基于增强的AVR RISC结构的低功耗8位CMOS微控制器。由于其先进的指令集以与单时钟周期指令执行时间,ATmega8 的数据吞吐率高达 1MIPS/MHz,从而可以缓减系统在功耗和处理速度之间的矛盾。ATmega8有如下特点:8K字节的系统可编程 Flash(具有同时读写的能力,即 RWW),512 字节 EEPROM,1K 字节 SRAM,32个通用I/O口线,32 个通用工作寄存器,三个具有比较模式的灵活的定时器 / 计数器 (T/C), 片 / 外中断,可编程串
41、行 USART,面向字节的两线串行接口,10 位6 路(8 路为 TQFP与MLF 封装)ADC,具有片振荡器的可编程看门狗定时器,一个SPI 串行端口,以与五种可以通过软件进行选择的省电模式。工作于空闲模式时 CPU 停止工作,而 SRAM、T/C、SPI 端口以与中断系统继续工作;掉电模式时晶体振荡器停止振荡,所有功能除了中断和硬件复位之外都停止工作;在省电模式下,异步定时器继续运行,允许用户保持一个时间基准,而其余功能模块处于休眠状态;ADC噪声抑制模式时终止CPU 和除了异步定时器与ADC 以外所有 I/O 模块的工作,以降低ADC 转换时的开关噪声;Standby 模式下只有晶体或谐
42、振振荡器运行,其余功能模块处于休眠状态,使得器件只消耗极少的电流,同时具有快速启动能力。 ATMEGA8L的引脚配置如下图3-16所示: 图3-16 ATMEGA8L的引脚配置图下载器模块原理图如图3-17所示:图3-17下载器模块原理图下载器模块实现将USB信号转换为能通过SPI协议传输的信号,从而实现对单片机的编程。3.2.8 其他模块流水灯模块、蜂鸣器模块的原理图如图3-18、图3-19所示9:图3-18 流水灯模块原理图 图3-19蜂鸣器模块原理图如图3-18所示流水灯模块包含8个LED灯,单片机的P0口接10K上拉电阻,八个LED的负极依次连接单片机P0口的8个引脚,八个LED的正极
43、依次与510欧姆的排阻的八个端子相连,排阻的公共端连接短路插针的一端,短路插针的另一端与电源相连,因此,若将短路插针用短路帽短路,则八个LED的正极上拉到高电平, LED低电平点亮。如图3-19所示,单片机的P3.4与Q1的基极通过1K欧姆电阻连接,当P3.4为高电平时,Q1导通,Q1的发射极与集电极导通,将发射极下拉为低电平,蜂鸣器两端出现电位差,蜂鸣器发声;当P3.4为低电平时,Q1不导通,蜂鸣器两端没有电流流过,蜂鸣器不发声。3.3 本章小结对硬件的设计采用模块化设计方法,采用的电路为典型应用电路,资源配置合理,通过使用短路帽连接相应的功能模块,降低了功耗,减弱了器件之间的相互干扰,提高
44、了系统稳定性,硬件工作稳定可靠。注意:除第一章绪论外,其他每一章都应该有一个本章小结第4章 总体设计4.1 整体程序设计软件部分主要包括数码管程序、键盘程序、AD程序、DA程序、DS1302时钟程序、DS18b20温度传感器程序、串行通信程序、显示程序和其他简单模块程序10。4.2 分模块程序设计依据开发板上硬件资源,进行程序的开发,在软件的设计过程中,采用模块化的设计方法,依次分别为每个模块设计软件。下面分别介绍以上各个模块的程序设计。4.2.1 键盘模块程序设计矩阵式键盘的按键识别方法为:判断键盘中有无键按下:将全部行线KEY0-KEY3置低电平,然后检测列线的状态。只要有一列的电平为低,则表示键盘中有键被按下,而且闭合的键位于低电平线与4根行线相交叉的4个按键之中。若所有列线均为高电平,则键盘中无键按下。 判断闭合键所在的位置:在确认有键按下后,即可进入确定具体闭合键的过程。其方法是:依次将行线置为低电平,即在置某根行线为低电平时,其它线为