智能型充电器的电源和显示的设计_第1页
智能型充电器的电源和显示的设计_第2页
智能型充电器的电源和显示的设计_第3页
智能型充电器的电源和显示的设计_第4页
智能型充电器的电源和显示的设计_第5页
已阅读5页,还剩42页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、目录摘要iabstractii第1章 概述 1第一节 绪论11.1 课题背景 11.2 常见充电电池特性及其充电方式 11.3主要芯片的选择 41.4 液晶显示模块的选择 6第二节 毕业设计任务和要求 7第2章 硬件电路设计 9第一节 液晶显示模块的两种访问方式接口电路 9第二节 硬件电路主要芯片 112.2.1 atmega16l主要引脚说明 112.2.2 atmega16l的存储器 13 2.2.3 atmega16l的时钟电路 142.2.4 atmega16l的系统复位 14第三节 lcd液晶显示 163.3.1 lcd的显示原理 163.3.2 液晶显示控制驱动器173.3.3 液

2、晶显示模块的特点 18第四节 电源电路的设计 20 第五节 硬件电路设计 20第六节 protell99的应用简介 21第3章 软件设计 233.1 用c语言开发单片机的优势 233.2 液晶显示汉字或字符的原理243.3 lcd模块的指令说明 253.4 液晶显示界面 273.5 系统程序流程图27第4章 系统调试过程31第一节 系统调试软件介绍 314.1.1 iccavr编译器简介314.1.2 iccavr的设置32第二节 调试过程35第五章 毕业设计总结 40第一节 成果 40第二节 经验总结和感谢 40参考文献41附录1外文资料译文39附录2外文资料原文42附录3部分源代码45附录

3、4硬件原理图62 lcd液晶显示器控制毕业论文-单片机毕业设计论文 摘要lcd液晶显示已经是人机界面的关键技术。本文对基于单片机的lcd液晶显示器控制系统进行了研究。首先在绪论中介绍了本课题的课题背景、研究意义及完成的功能。本系统是以单片机的基本语言汇编语言来进行软件设计,指令的执行速度快,节省存储空间。为了便于扩展和更改,软件的设计采用模块化结构,使程序设计的逻辑关系更加简洁明了。使硬件在软件的控制下协调运作。正文中首先简单描述系统硬件工作原理,且附以系统硬件设计框图,并介绍了单片机微处理器的发展史,论述了本次毕业设计所应用的各硬件接口技术和各个接口模块的功能及工作过程, 并具体描述了805

4、2、8279及sed1520外接电路接口的软、硬件调试。其次阐述了程序的流程和实现过程。本文撰写的主导思想是软、硬件相结合,以硬件为基础,来进行各功能模块的编写。最后对我所开发的用单片机实现lcd液晶显示器控制原理的设计思想和软、硬件调试作了详细的论述。 关键词单片机;微处理器;lcd; 8279 abstractthe lcd manifestation has been the key technique of the man-machine interface. this text to basic proceeded the research in micro controller u

5、nit liquid crystal display control system.introduced the lesson a background of this lesson and study meaning and finished functions in introduction first.this system edits collected materials the language to proceed with single the basic language of a machine the software designs, the instruction c

6、arries out the speed quick, save memory. for the sake of easy to expand with the design adoption mold a logic for turning construction, making procedure designing relation that change, software more shorter and more easier to understand. make hardware control in software descended to moderate the op

7、eration.the text inside describes the system hardware work principle in brief first, and attach with the system hardware design frame diagram, combine development history that introduced the single a machine microprocessor, discuss this graduate design a function for applied each hardware connecting

8、 a people the technique connects with each one a mold piece and work processes, combine to describe in a specific way 8052,8279 and the sed1520 circumscribes the electric circuit connects oscular and soft, the hardware adjusts to try. expatiated the process of the procedure the next in order with re

9、alizes process. the predominance thought that this text compose is soft, the hardware combines together, regarding hardware as the foundation, proceed the plait of each function mold piece write.develop to me finally of use the single a machine realizes the design thought that the liquid crystal dis

10、play of lcd control principle with soft, the hardware adjusted to try to make the detailed treatise. keywords micro controller unit microprocessor lcd 8279前言随着越来越多的手持式电器的出现,对高性能、小尺寸、重量轻的电池充电器的需求也越来越大。电池技术的持续进步也要求更复杂的充电算法以实现快速、安全的充电。因此需要对充电过程进行更精确的监控,以缩短充电时间、达到最大的电池容量,并防止电池损坏。avr 已经在竞争中领先了一步,被证明是下一代充

11、电器的完美控制芯片。atmel avr 微处理器是当前市场上能够以单片方式提供flash、eeprom 和10 位adc的最高效的8 位risc 微处理器。由于程序存储器为flash,因此可以不用象mask rom一样,有几个软件版本就库存几种型号。flash 可以在发货之前再进行编程,或是在pcb贴装之后再通过isp 进行编程,从而允许在最后一分钟进行软件更新。eeprom 可用于保存标定系数和电池特性参数,如保存充电记录以提高实际使用的电池容量。10位a/d 转换器可以提供足够的测量精度,使得充好后的容量更接近其最大容量。而其他方案为了达到此目的,可能需要外部的adc,不但占用pcb 空间

12、,也提高了系统成本。avr 是目前唯一的针对像 “c”这样的高级语言而设计的8 位微处理器。c 代码似的设计很容易进行调整以适合当前和未来的电池,而本次智能型充电器显示程序的编写则就是用c语言写的。第一章概述第一节绪论1.1.1课题背景如今,随着越来越多的手持式电器的出现,对高性能、小尺寸、重量轻的电池充电器的需求也越来越大。电池技术的持续进步也要求更复杂的充电算法以实现快速、安全的充电。因此需要对充电过程进行更精确的监控,以缩短充电时间、达到最大的电池容量,并防止电池损坏。与此同时,对充电电池的性能和工作寿命的要求也不断地提高。从20世纪60年代的商用镍镉和密封铅酸电池到近几年的镍氢和锂离子

13、技术,可充电电池容量和性能得到了飞速的发展。目前各种电器使用的充电电池主要有镍镉电池(nicd)、镍氢电池(nimh)、锂电池(li-ion)和密封铅酸电池(sla)四种类型。电池充电是通过逆向化学反应将能量存储到化学系统里实现的。由于使用的化学物质的不同,电池有自己的特性。设计充电器时要仔细了解这些特性以防止过度充电而损坏电。目前,市场上卖得最多的是旅行充电器,但是严格从充电电路上分析,只有很少部分充电器才能真正意义上被称为智能充电器,随着越来越多的手持式电器的出现,对高性能、小尺寸、轻重量的电池充电器的需求也越来越大。电池技术的持续进步也要求更复杂的充电算法以实现快速、安全地充电,因此,需

14、要对充电过程进行更精确地监控(例如对充、放电电流、充电电压、温度等的监控),以缩短充电时间,达到最大的电池容量,并防止电池损坏。因此,智能型充电电路通常包括了恒流恒压控制环路、电池电压监测电路、电池温度检测电路、外部显示电路(led或lcd显示)等基本单元。其框图如下:图1-1 智能充电器基本框图atmel avr 微处理器是当前市场上能够以单片方式提供flash、eeprom 和10 位adc的最高效的8 位risc 微处理器。由于程序存储器为flash,因此可以不用象mask rom一样,有几个软件版本就库存几种型号。flash 可以在发货之前再进行编程,或是在pcb贴装之后再通过isp

15、进行编程,从而允许在最后一分钟进行软件更新。eeprom 可用于保存标定系数和电池特性参数,如保存充电记录以提高实际使用的电池容量。10位a/d 转换器可以提供足够的测量精度,使得充好后的容量更接近其最大容量。而其他方案为了达到此目的,可能需要外部的adc,不但占用pcb 空间,也提高了系统成本。avr 是目前唯一的针对象 “c”这样的高级语言而设计的8 位微处理器。1.1.2常见充电电池特性及其充电方式电池充电是通过逆向化学反应将能量存储到化学系统里实现的,由于使用的化学物质的不同,电池的特性也不同,其充电的方式也不大一样。电池的安全充电 现代的快速充电器( 即电池可以在小于3 个小时的时间

16、里充满电,通常是一个小时) 需要能够对单元电压、充电电流和电池温度进行精确地测量,在充满电的同时避免由于过充电造成的损坏。充电方法 sla 电池和锂电池的充电方法为恒定电压法要限流; nicd 电池和nimh 电池的充电方法为恒定电流法,且具有几个不同的停止充电的判断方法。最大充电电流 最大充电电流与电池容量(c) 有关。最大充电电流往往以电池容量的数值来表示。例如,电池的容量为750 mah,充电电流为750 ma,则充电电流为1c (1 倍的电池容量)。若涓流充电时电流为c/40,则充电电流即为电池容量除以40。过热 电池充电是将电能传输到电池的过程。能量以化学反应的方式保存了下来。但不是

17、所有的电能都转化为了电池中的化学能。一些电能转化成了热能,对电池起了加热的作用。当电池充满后,若继续充电,则所有的电能都将转化为电池的热能。在快速充电时这将使电池快速升温,若不及时停止充电就会造成电池的损坏。因此,在设计电池充电器时,对温度进行监控并及时停止充电是非常重要的。现代消费类电器主要使用如下四种电池: 密封铅酸电池 (sla) 镍镉电池 (nicd) 镍氢电池(nimh) 锂电池(li-ion)在正确选择电池和充电算法时需要了解这些电池的背景知识。密封铅酸电池(sla) 密封铅酸电池主要用于成本比空间和重量更重要的场合,如ups和报警系统的备份电池。sla 电池以恒定电压进行充电,辅

18、以电流限制以避免在充电过程的初期电池过热。只要电池单元电压不超过生产商的规定( 典型值为2.2v), sla 电池可以无限制地充电。镍镉电池(nicd) nicd 电池目前使用得很普遍。它的优点是相对便宜,易于使用;缺点是自放电率比较高。典型的nicd 电池可以充电1000 次。失效机理主要是极性反转。在电池包里第一个被完全放电的单元会发生反转。为了防止损坏电池包,需要不间断地监控电压。一旦单元电压下降到1.0v 就必须停机。nicd 电池以恒定电流的方式进行充电。镍氢电池(nimh) 在轻重量的手持设备中如手机、手持摄象机,等等镍氢电池是使用最广的。这种电池的容量比nicd 的大。由于过充电

19、会造成nimh 电池的失效,在充电过程中进行精确地测量以在合适的时间停止是非常重要的。和nicd 电池一样,极性反转时电池也会损坏。nimh 电池的自放电率大概为20%/ 月。和nicd 电池一样,nimh 电池也为恒定电流充电。锂电池 (li-ion) 和本文中所述的其他电池相比,锂电池具有最高的能量/ 重量比和能量/ 体积比。锂电池以恒定电压进行充电,同时要有电流限制以避免在充电过程的初期电池过热。当充电电流下降到生产商设定的最小电流时就要停止充电。过充电将造成电池损坏,甚至爆炸。1.1.3 主要芯片的选择 atmel公司是世界上有名的生产高性能、低功耗、非易失性存储器和各种数字模拟ic芯

20、片的半导体制造公司。在单片机微控制器方面,atmel公司有at89, at90和arm三个系列单片机的产品。由于8051本身结构的先天性不足和近年来各种采用新型结构和新技术的单片机的不断涌现,现在的单片机市场是百花齐放。atmel在这种强大市场压力下,发挥flash存储器的技术特长,于1997年研发并推出了个新配置的、采用精简指令集risc(reduced instruction set cpu)结构的新型单片机,简称avr单片机。 精简指令集risc结构是20世纪90年代开发出来的,综合了半导体案成技术和软例-性能的新结构。avr单片机采用risc结构,具有1mips/ mhz的高速运行处理

21、能力。为了缩短产品进入市场的时间,简化系统的维护和支持,对于由单片机组成的嵌入式系统来说,用高级语言编程已成为一种标准编程方法。avr结构单片机的开发日的就在于能够更好地采用高级语言(例如c语言、basic语言)来编写嵌入式系统的系统程序,从而能高效地开发出目标代码。为了对目标代码大小、性能及功耗进行优化,ayr单片机的结构中采用了大型快速存取寄存器组和快速的单周期指令系统。 avr单片机运用harvard结构,在前一条指令执行的时候就取出现行的指令,然后以一个周期执行指令。在其他的cisc以及类似的risc结构的单片机中,外部振荡器的时钟被分频降低到传统的内部指令执行周期,这种分频最大达12

22、倍(8051)。avr单片机是用一个时钟周期执行一条指令的,它是在8位单片机中第一个真正的risc结构的单片机。 由于avr单片机采用了harvard结构,所以它的程序存储器和数据存储器是分开组织和寻址的。寻址空间分别为可直接访问8m字节的程序存储器和8m字节的数据存储器。同时,由32个通用工作寄存器所构成的寄存器组被双向映射,因此,可以采用读写寄存器和读写片内快速sram存储器两种方式来访问32个通用工作寄存器。avr主要有单片机有attiny、at90和atmega三种系列,其结构和基本原理都相类似。本次设计所用到的atmega16l芯片便是atmega系列中的一种,在这里作为充电器的核心

23、部件。它是一种具有40引脚的高性能、低功耗的8位微处理器。其功能特性如下: (1) 8位cpu。(2) 先进的risc 结构:131 条指令 大多数指令执行时间为单个时钟周期32个8 位通用工作寄存器全静态工作(3) 非易失性数据和程序存储器:16k 字节的系统内可编程flash,擦写寿命可达到10,000 次以上。具有独立锁定位的可选boot代码区,通过片上boot程序实现系统内编程。512 字节的eeprom,可连续擦写100,000 次。1k字节的片内sram,可以对锁定位进行编程以实现用户程序的加密。(4) 可通过jtag接口实现对flash、eeprom的编程。(5) 32个可编程的

24、i/o引线,40引脚pdip封装。(6) 两个具有独立预分频器和比较器功能的8位定时器/ 计数器,一个具有预分频器、比较功能和捕捉功能的16位定时器/ 计数器。(7) 片内/ 片外中断源。(8) 具有一个10位的ad转换器,能对来自端口a的8位单端输入电压进行采样。(9) 工作电压:2.75.5v。速度等级:08mhz。avr单片机的主要特点如下:1.片内集成可擦写10000次以上的flash程序存储器。由于avr采用16位的指令,所以一个程序存储器的存储单元为16位,即xxxx*1116(也可理解为8位,即2*xxxx*8)。avr的数据存储器还是以8个bit(位)为一个单元,因此avr还是

25、属于8位单片机。2.采用cmos工艺技术,高速度(50ns)、低功耗、具有sleep(休眠)功能。avr的指令执行速度可达50ns (20mhz)。avr运用harvard结构概念,具有预取指令的特性,即对程序存储和数据存取使用不同的存储器和总线。当执行某一指令时,下一指令被预先从程序存储器中取出,这使得指令可以在每一个时钟周期内执行。3.高度保密(lock)。可多次擦写的flash具有多重密码保护锁死(lock)功能,因此可低成本高速度地完成产品商品化,并且可多次更改程序(产品升级)而不必浪费1c或电路板,大大提高了产品的质量及竞争力。4.超功能精简指令。具有32个通用作寄存器(相当于805

26、1中的32个累加器),克服了单一累加器数据处理造成的瓶须现象,1284k字节sram可灵活使用指令计算,并可用功能很强的c语言编程,易学、易写、易移植。5.程序写入器件可以并行写入(用编程器写入),也可使用串行在线编程(isp)方法下载写入,也就是说不必将单片机芯片从系统上拆下,拿到万用编程器上烧写,而可直接在电路板上进行程序的修改、烧写等操作,方便产品升级,尤其是采用smd封装,更利于产品微型化。6.工作电压范围为2.7v6.0v,电源抗干扰性能强。7.avr单片机还在片内集成了可擦写100000次的prom数据存储器,等于又增加了一个芯片,可用于保存系统的设定参数、固定表格和掉电后的数据,

27、既方便了使用,减小了系统的空间,又大大提高了系统的保密性。8.有8位和16位的计数器定时器(c/t),可作比较器、计数器、外部中断和pwm(也可作d/a )用于控制输出。1.1.4液晶显示模块的选择lcd显示模块是一种被动显示器,具有功耗低,显示信息大,寿命长和抗干扰能力强等优点,在低功耗的单片机系统中得到大量使用。液晶显示模块和键盘输入模块作为便携式仪表的通用器件,在单片机系统的开发过程中也可以作为常用的程序和电路模块进行整体设计。液晶显示的原理是利用液晶的物理特性,通过电压对其显示区域进行控制,有电就显示黑色,这样即可显示出图形。在单片机系统中使用液晶显示模块作为输出器件有以下优点:(1)

28、 显示质量高液晶显示器每一个点在收到信号后就一直保持那种色彩和亮度,恒定发光,因此液晶显示器画质高而且不会闪烁。(2) 数字式接口液晶显示器都是数字式的,和单片机系统的接口更加简单。(3) 体积小,重量轻(4) 功率消耗小液晶显示器的功耗主要消耗在其内部的电极和驱动ic上,因此耗电量比其它显示器要小得多。第二节毕业设计任务和要求智能充电器的设计包括硬件和软件两大部分,本人的主要任务是完成充电器设计的lcd显示部分,其主要涉及的知识包括:(1) 自学avr单片机的相关内容。(2) 设计电源电路。(3) 设计128*64液晶显示控制电路和用c语言编制lcd显示程序,用图形方式显示充电器电压、电流等

29、参数。(4) 手工焊接和iccavr编译器的应用。这次设计要解决的关键问题是如何用atmega16l芯片控制lcd模块及用c语言编制相应的显示程序随着单片机的开发应用,其相应的汇编编程和所暴露的问题也越来越多,逐渐引入了高级语言,c语言就是其中的一种。在大一时就曾接触过c语言,由于时间较短,重视程度不够,后来又一直没用过,只能对它有一个大概的了解。而对于avr单片机的相关知识和液晶显示模块的使用,则完全是一片空白。这次毕业设计,就不得不花大量的时间在这些基础知识的学习上。为了更有效地完成这个课题,特列出了如下计划:表1-1 毕业设计进度表 起止时间 工 作 内 容第12周熟悉课题的基本要求,查

30、阅相关资料,初步拟定设计的整体方案,完成开题报告。 第38周1. 自学这次课题所涉及的相关内容,包括c语言基础知识,avr单片机(主要是atmega16l芯片)和iccavr编译器的使用以及液晶显示的相关内容。并设计一些简单的实际电路,熟练所学内容并加以巩固。2. 熟悉绘图软件protel99的使用。 第912周1. 设计lcd显示电路,电源电路,用protel99绘制原理图,和同学一起完成整个充电电路原理图,并绘制印制电路板。2. 编写显示程序。 第1315周焊接调试电路,根据各部分的作用对硬件电路进行调试,最后联机调试。 最后数周写毕业设计论文,完成全部毕业设计。 这次毕业设计是由郭伟同学

31、和本人共同合作完成,由他完成充电部分的硬件电路的设计,和这边的显示部分相结合,共同完成智能充电器的设计。第二章 硬件电路设计经过前面对充电器原理、液晶模块、atmega16l等的总体了解和掌握以及对各种元器件和电路图的分析和比较后,现在就可以开始进入硬件电路的设计了。在本章里,首先将介绍一下液晶模块访问方式的两种接口电路,然后对lcd显示电路原理图作一个详细的介绍,接着介绍充电电路中所用到的各种芯片和元器件的原理和一些功能,最后对protel99的使用和pcb板的绘制以及焊接做一简单介绍,然后再将自己的设计思想和同组人所设计的两部分结合,达成统一。 第一节 液晶显示模块两种访问方式接口电路的选

32、择单片机与液晶显示模块之间的连接方式分为直接访问方式和为间接控制方式两种。如图2-1和图2-2所示,其中左为单片机,右为液晶显示模块。 (一) 直接访问方式pd0pd1pd2pd3pd4pd5pd6pd7rdwep2.3p2.2p2.1p2.0db0db1db2db3db4db5db6db7gndvccv0e/csa/csbr/wd/i10k 数据总线 gnd +5v电位器 负电源 1 32 74ls00a11a10a9a8mpu 图2-1 直接访问方式电路图 lcm接口直接访问方式就是将液晶显示模块的接口作为存储器或i/o设备直接挂在单片机总线上,单片机以访问存储器或i/o设备的方式操作液晶

33、显示模块的工作。直接访问方式的接口电路如图2-1所示,在图中,单片机通过高位地址a11控制csa,a10控制csb,以选通液晶显示屏上各区的控制器;同时用地址a9作为r/w信号控制数据总线的数据流向;用地址a8作为d/i信号控制寄存器的选择,e(使能)信号由rd和we共同产生,这样就实现了单片机对液晶显示模块的电路边接。电位器用于显示对比度的调节。(二)间接控制方式 p1.7 p1.6 p1.5 p1.4 p1.3 p1.2 p1.1 p1.0 p3.4 p3.3 p3.2 p3.1 p3.0db7db6db5db4db3db2db1db0/csa/csber/wd/ivccv0gnd电位器+

34、5v 10k 负电源 gnd mpu lcm接口图2-2 间接控制方式电路图间接控制方式是单片机通过自身的或系统中的并行接口与液晶显示模块连接。单片机通过对这些接口的操作,以达到对液晶显示模块的控制。这种方式的特点就是电路简单,控制时序由软件实现,可以实现高速单片机与液晶显示模块的接口。电路图如图2-2所示。在图中以 p1口作为数据口,p3.4为csa,p3.3为csb,p3.2为使能端,p3.1为r/w和p3.0为d/i信号。电位器用于显示对比度的调节。通过比较再结合本次设计的实际条件,由于atmega16l芯片没有wr、rd管脚,而且为了使电路简单且方便软件实现,所以最终决定采用间接控制的

35、方式来设计lcd显示电路。第二节 硬件电路主要芯片2.2.1 atmega16l主要引脚说明以下是atmega16l的引脚配置: 图2-3 atmega16l芯片引脚引脚说明:vcc 数字电路的电源gnd 地端口a(pa7pa0) 端口a 作为a/d 转换器的模拟输入端。端口a 为8 位双向i/o 口,具有可编程的内部上拉电阻。其输出缓冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,端口被外部电路拉低时将输出电流。在复位过程中,即使系统时钟还未起振,端口a 处于高阻状态。端口b(pb7pb0) 端口b 为8 位双向i/o 口,具有可编程的内部上拉电阻。其输出缓

36、冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,端口被外部电路拉低时将输出电流。在复位过程中,即使系统时钟还未起振,端口b 处于高阻状态。端口c(pc7pc0) 端口c 为8 位双向i/o 口,具有可编程的内部上拉电阻。其输出缓冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,端口被外部电路拉低时将输出电流。在复位过程中,即使系统时钟还未起振,端口c 处于高阻状态。如果jtag接口使能,即使复位出现引脚pc5(tdi)、pc3(tms)与pc2(tck)的上拉电阻被激活。端口d(pd7pd0) 端口d 为8 位双向i/o 口,具

37、有可编程的内部上拉电阻。其输出缓冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,则端口被外部电路拉低时将输出电流。在复位过程中,即使系统时钟还未起振,端口d处于高阻状态。reset 复位输入引脚。持续时间超过最小门限时间的低电平将引起系统复位。xtal1 反向振荡放大器与片内时钟操作电路的输入端。xtal2 反向振荡放大器的输出端。avccavcc是端口a与a/d转换器的电源。不使用adc时,该引脚应直接与vcc连接。使用adc时应通过一个低通滤波器与vcc相连。arefa/d 的模拟基准输入引脚。2.2.2 atmega16l的存储器avr结构有两个主要的存

38、储空间:数据存储器空间和程序存储器空间,此外,atmega16l还有一个eeprom存储器以保存数据。这三个存储器都为线性的平面结构。(1) atmega16l具有16k字节的在线编程flash,用于存储程序指令代码。因为avr指令为16位或32位,故flash组织成8k16的形式。用户程序的安全性要根据flash程序存储器的两个区:引导(boot) 程序区和应用程序区,分开来考虑。flash存储器至少可以擦写10,000次。atmega16l的程序存储器为13位,因此可以寻址8k的存储器空间。关于用spi 或jtag 接口实现对flash 的串行下载,将在软件部分作详细的介绍。(2) 数据存

39、储器的寻址方式分为5种:直接寻址、带偏移量的间接寻址、间接寻址、带预减量的间接寻址和带后增量的间接寻址。atmega16l的全部32个通用寄存器、64个i/o寄存器及1024个字节的内部数据sram可以通过所有上述的寻址模式进行访问。(3) atmega16l 包含512 字节的eeprom 数据存储器。它是作为一个独立的数据空间而存在的,可以按字节读写。eeprom 的寿命至少为100,000 次擦除周期。eeprom 的访问由地址寄存器、数据寄存器和控制寄存器决定。2.2.3 atmega16l的时钟电路单片机的时钟用于产生工作所需要的时序,其连接电路如下图: 图2-4 晶体振荡器连接图x

40、tal1 与xtal2 分别为用作片内振荡器的反向放大器的输入和输出,考虑到其最大频率不超过8mhz,这里选用的晶振为7.3728mhz。2.2.4 atmega16l的系统复位atmega16l有五个复位源:(1) 上电复位。电源电压低于上电复位门限vpot时,mcu复位。如果在单片机加vcc电压的同时,保持reset引脚为低电平,则可延长复位周期。vcc vpot vpotreset vrst vrsttime-outinterinal ttout ttout reset 图2-5 reset引脚与vcc相连时, 图2-6 reset引脚由外部控制时, 单片机的复位电平 单片机的复位电平(

41、2) 外电复位。引脚reset上的低电平持续时间大于最小脉冲宽度时mcu复位。vccreset vrsttime-out ttoutinternalreset 图2-7 外部复位时序图(3) 看门狗复位。看门狗使能并且看门狗定时器溢出时复位发生。看门狗计数器溢出时,将产生一个晶振的复位脉冲。vcc reset wdt 1 xtal cycletime-out reset ttout time-outinternal reset 图2-8 看门狗复位时序图(4) 掉电检测复位。掉电检测复位功能使能,且电源电压低于掉电检测复位门限vpot时mcu即复位。(5) jtag avr复位。复位寄存器为1

42、时mcu复位。第三节lcd液晶显示 2.3.1 lcd的显示原理液晶显示器是一种功耗极低的显示器。随着液晶显示技术的发展,lcd显示器的规格众多,其专用驱动芯片也相互配套,使lcd在控制和仪表系统中广泛应用提供了极大的方便。根据lcd显示原理的不同,常见和常用的lcd可以分为字符型lcd和点阵型lcd两种。不同的显示原理使得这两种lcd的指令系统、接口和功能等是不相同的,各有优缺点,但结合到本次设计的实际要求,经过比较还是选用点阵型lcd。现就点阵型lcd的显示原理、模块特点等做一简要介绍。要想在液晶模块上显示一个汉字或字符,需要3个最基本的控制操作:分别向3个控制器写指令代码、写显示数据和读

43、显示数据。这里要特别引起注意的是完成这3项操作的前提条件是ks0108b控制器处于准备好的状态,即busy=0,由模块的软件特性知道,当busy=1时,系统的接口电路处于被封锁的状态,是不能接受除读状态指令外的任何操作的。因此在访问控制器之前,一定要判断控制器的当前状态。具体到软件设计时,则需设计一判忙程序,在判断busy=0后,再往下进行操作。在本模块中,每个汉字的大小是1616点阵,而每个字符的大小是816点阵,即字符的宽度为汉字的1/2。它们都是以二维数组的格式存放在rom中。向液晶模块显示一个汉字的过程就是:由液晶屏显示区的指定字符行的指定列开始,连续输出该字符对应的字符库中的16个列

44、数据,如果是显示字符,则输出8个列数据即可。上面已经介绍到,mgls-19264液晶模块中液晶屏显示区为19264点阵,其中,它们的每8个像素行组成一页,整个显示区共分为8页,每64列为一个区,这样,它就有左、中、右3个区,它的显示区示意图如下:左区 中区 右区0 1 2 62 63 64 65 127128 129 191db0db7第0页第七页db0db7 图2-9 液晶屏显示区示意图液晶模块显示字符是从上到下,从左到右进行显示的。假设定义从最左上角开始显示,则先从上到下显示第0页的第一列,依次从左向右开始显示。mgls-19264lcm的显示部分为左、中、右3个区,可以由cs片选的取值分

45、别进行控制,其接口的片选定义如下:表2-1 mgls的片选定义表cs1cs2选中区域 0 0 左区 0 1 中区 1 0 右区 1 1 未选 有了上面的知识,就可以编写显示界面这一块程序。由于每个汉字或字符在图中位置是固定的,只要定义了相应的选区及x、y地址,就可以显示出具体的位置。用lr来表示汉字的区域,当lr=0,表示左区;lr=1,表示中区;lr=2,表示右区。x表示页面,y表示列地址。则(lr.x.y)就可以定义出这个字在屏上的实际位置。以第一行的“智”字为例,这个字位于模块的左区,则lr=0;它位于第一页和第二页,则x=0;它位于列地址的48-63字节,y=48,那么“智”就可以通过

46、(0.0.48)精确地表示出它的位置。这里要注意的是每个汉字占用的行地址是两页,如“智”字占的就是x0和x1,即第二行的汉字其x=2而不是1。因此,第二行的“电”就应该表示为(0.2.0),其它字符依此设计即可。2.3.2 液晶显示控制驱动器hd61202及其兼容液晶显示控制器是一种带有驱动输出的图形液晶显示控制器,而在小规模点阵液晶显示模块上使用液晶显示驱动器组成液晶显示驱动控制系统是非常有益的,这将使液晶显示模块的硬件电路简单化,从而降低模块的成本,同时也提高了对软件功能的要求。许多显示功能如光标、字符库、闪烁都需要由软件编制而成。hd61203和hd61202就是这类液晶显示驱动控制器套

47、件。之所以称它们为套件是因为hd61203和hd61202必须配套使用,通常有12864和19264两种规格。其特点如下:1内藏64*64=4096位显示ram,ram中每位数据对应lcd屏上的一个点的亮、暗状态。2hd61202及其兼容控制器是列驱动器,具有64路列驱动输出。3hd61202及其兼容控制驱动器读、写时序与68系列微处理妻相符,因此它可直接与68系列微处理器借口相联。4hd61202及其兼容控制器的占空比为1/321/64。2.3.3 液晶显示模块的特点mgls-12864图形液晶显示模块的驱动和控制系统是由一片ks0107b或兼容驱动器( hd61203 )作为行驱动器和两片

48、ks0108b或兼容驱动器(hd61203) 作为列驱动器组成的。它的主要技术参数及其供电特点如下:(1) 电源:dc+5v,模块内自带用于lcd驱动的负压电路。(2) 显示内容:12864全屏幕点阵。(3) 指令形式:七种指令。(4) 接口形式:与控制器采用8位数据总线和8位控制线相连。(5) 工作环境:10+50。(6) 模块应用有三种电源:逻辑电源、液晶驱动电压、背光电压。(7) 本次选用的模块是双电源供电(vdd/v0),需要提供一个液晶驱动电压,用以调节对比度,接在液晶模块的v0引脚上,由于液晶的对比度会随着温度的变化而相应变化,所以其液晶显示驱动电压值应随着温度作相应的调整,这里采

49、用了一个电位器,调整电压值。(8) 背光供电为3.8-4.1v的支流电源,选用电源太大不仅增加功耗,更有可能损坏背光灯和缩短模块的使用寿命。mgls-12864的逻辑电路图如下:hd61202 *lcd: vgls-1286412864 dots64hd61202 (1) hd61202 (2)6464vddvssv0/csa/csbdb0db7d/ir/we图2-8 mgls-12864的逻辑电路图mgls-12864液晶显示模块一共有20个引脚,它的接口定义如下:表2-2 mgls-12864的接口电路序号符号状态功能d7三态数据总线d6三态数据总线d5三态数据总线4d4三态数据总线5d3三态数据总线6d2三态数据总线7d1三态数据总线8d0三态数据总线9e输入r/w=“l”,e的下降沿锁存数据线r/w=“h”,e为“h”时,数据由控制器输出至数据线10r/w输入r/w=“l”,e=“h”数据由控制器输出数据线r/w=“h”,e的下降沿,数据由数据线输入到控制器11d/i输入d/i

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论