欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    单片机的接口技术.ppt

    • 资源ID:5937951       资源大小:2.98MB        全文页数:152页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    单片机的接口技术.ppt

    51单片机的I/O外设的接口,本章内容,51单片机的键盘与显示器接口键盘、显示器接口芯片8279,9.1 LED数码管的接口,LED(Light Emitting Diode)发光二极管缩写。LED数码管是由发光二极管构成的。,9.1.1 LED数码管的结构常见的LED数码管为“8”字型的,共计8段。每一段对应一个发光二极管。有共阳极和共阴极两种,如图9-1所示。共阴极发光二极管的阴极连在一起,通常公共阴极接地。当阳极为高电平时,发光二极管点亮。共阳极LED数码管的发光二极管的阳极连接在一起,公共阳极接正电压,当某个发光二极管的阴极接低电平时,发光二极管被点亮,相应的段被显示。,图9-1 8段LED数码管结构及外形,8段LED数码管结构,8段LED数码管的字型码,为了使数码管显示不同的符号或数字,要把某些段发光二极管点亮,就要为LED数码管提供段码(字型码)。LED数码管共计8段。正好是一个字节。习惯上是以“a”段对应段码字节的最低位。各段与字节中各位对应关系如表9-1所示。,按照上述格式,显示各种字符的8段LED数码管的段码如表10-2所示。,显示各种字符的8段LED数码管的段码如表9-2所示,表9-2 8段LED段码,其它显示器,除“8”字型的LED数码管外,市面上还有“1”型、“米”字型和“点阵”型LED显示器,如图9-2所示。本章均以“8”字型的LED数码管为例。,图9-2 其他各种字型的LED显示器,9.1.2 LED数码管工作原理,图9-3所示为显示4位字符的LED数码管的结构原理图。N位位选线和8N条段码线。段码线控制显示字型,而位选线控制着该显示位的LED数码管的亮或暗。,图9-3 4位LED数码管的结构原理图,LED静态显示方式无论多少位LED数码管,同时处于显示状态。静态显示方式,各位的共阴极(或共阳极)连接在一起并接地(或接+5V);每位的段码线(adp)分别与一个8位的I/O口锁存器输出相连。如果送往各个LED数码管所显示字符的段码一经确定,则相应I/O口锁存器锁存的段码输出将维持不变,直到送入另一个字符的段码为止。正因为如此,静态显示方式的显示无闪烁,亮度都较高,软件控制比较容易。图9-4为4位LED数码管静态显示器电路,各位可独立显示,静态显示方式接口编程容易,但是占用口线较多。对图9-4电路,若用I/O口线接口,要占用4个8位I/O口。因此在显示位数较多的情况下,所需的电流比较大,对电源的要求也就随之增高,这时一般都采用动态显示方式。,LED数码管有静态显示和动态显示两种显示方式,图9-4 4位LED静态显示电路,LED静态显示方式,LED动态显示方式,无论在任何时刻只有一个LED数码管处于显示状态,即单片机采用“扫描”方式控制各个数码管轮流显示。在多位LED显示时,为简化硬件电路,通常将所有显示位的段码线的相应段并联在一起,由一个8位I/O口控制,而各位的共阳极或共阴极分别由相应的I/O线控制,形成各位的分时选通。图9-5所示为一个4位8段LED动态显示电路。其中段码线占用一个8位I/O口,而位选线占用一个4位I/O口。必须采用动态的“扫描”显示方式。即在某一时刻,只让某一位的位选线处于选通状态,而其他各位的位选线处于关闭状态,同时,段码线上输出相应位要有显示的字符的段码。,图9-5 4位8段LED动态显示电路,LED动态显示方式,虽然这些字符是在不同时刻出现,而在同一时刻,只有一位显示,其他各位熄灭,由于余辉和人眼的“视觉暂留”作用,只要每位显示间隔足够短,则可以造成“多位同时亮”的假象,达到同时显示的效果。LED不同位显示的时间间隔(扫描间隔)应根据实际情况而定。显示位数多,将占大量的单片机时间,因此动态显示的实质是以牺牲单片机时间来换取I/O端口的减少。图9-6所示为8位LED动态显示的过程。图9-6(a)所示为显示过程,某一时刻,只有一位LED被选通显示,其余位则是熄灭的;图9-6(b)所示为实际的显示结果,人眼看到的是8位稳定的同时显示的字符。动态显示的优点是硬件电路简单,显示器越多,优势越明显。缺点是显示亮度不如静态显示的亮度高。如果“扫描”速率较低,会出现闪烁现象。,LED动态显示方式,图9-6 8位LED动态显示过程和结果,LED动态显示方式,9.2 单片机键盘接口技术,键盘输入需解决三个问题(1)判别是否有键按下?若有,进入下一步工作。(2)识别哪一个键被按下,并求出相应的键值。(3)根据键值,找到相应键值的处理程序入口。,9.2.1 键盘接口的任务,键盘输入的特点,常见键盘:触摸式键盘、薄膜键盘和按键式键盘,最常用的是按键式键盘。按键实质上就是一个开关。如图9-7(a)所示,按键开关的两端分别连接在行线和列线上,通过键盘开关机械触点的断开、闭合,其行线电压输出波形如图9-7(b)所示。,图9-7 键盘开关及其行线波形,键盘输入的特点,图9-7(b)所示的t1和t3分别为键的闭合和断开过程中的抖动期(呈现一串负脉冲),抖动时间长短与开关的机械特性有关,一般为510ms,t2为稳定的闭合期,其时间由按键动作确定,一般为十分之几秒到几秒,t0、t4为断开期。,图9-7 键盘开关及其行线波形,按键的识别,键的闭合与否,行线输出电压上就是呈现高电平或低电平。高电平,表示键断开,低电平则表示键闭合,通过对行线电平的高低状态的检测,可确认按键按下以及按键释放与否。为了确保对一次按键动作只确认一次按键有效,必须消除抖动期t1和t3的影响。通常t1和t3小于10ms。按键闭合时的电压抖动波形见图9-8。,图9.8 键闭合和断开时的电压抖动,如何消除按键的抖动,按键去抖动的方法有两种:一种软件延时,思想是:在检测到有键按下时,该键所对应的行线为低电平,执行一段延时10ms的子程序后,确认该行线电平是否仍为低电平,如果仍为低电平,则确认该行确实有键按下。当按键松开时,行线的低电平变为高电平,执行一段延时10ms的子程序后,检测该行线为高电平,说明按键确实已经松开。采取本措施,可消除两个抖动期t1和t3的影响。另一种是采用专用的键盘/显示器接口芯片,这类芯片中都有自动去抖动的硬件电路,9.2.2 键盘工作原理,键盘可分为两类:非编码键盘和编码键盘。非编码键盘非编码键盘是利用按键直接与单片机相连接而成,它通常使用在按键数量较少,系统功能较简单,需处理的任务较少的场合,可以降低成本、简化电路设计。非编码键盘可分为独立式和矩阵式。(1)独立式键盘:结构:一组相互独立的键盘,每个键盘都与单片机的I/O口的一条口线连接,相互独立。独立式键盘的结构见图9-9。原理:当任何一个键被按下时,与其相连的输入线被置成“0”,平时该线为“1”。通过检测I/O输入线的电平状态,判断哪个按键被按下。特点:接口简单,但若键较多,将占用许多I/O线。,图9-9 独立式键盘结构,对于图9-8的键盘,图中的上拉电阻保证按键释放时,输入检测线上有稳定的高电平。,键处理子程序,KEYIN:MOVA,#0FFH;置P1口为“1”,设置P1口为输入状态MOVP1,AMOVA,P1;输入键状态CJNEA,#0FFH,QUDOU;有键按下,跳去抖动LJMPRETURN;无键按下,返回QUDOU:MOV R3,A;8个按键的状态送R3保存LCALL DELAY10;调用延时子程序,软件去键抖动MOVA,P1;再一次读入8个按键的状态CJNEA,R3,RETURN;两次键值比较,不同,是抖动引起,转RETURNJNBACC.0,P0F;查询0号键JNBACC.1,P1F;查询1号键JNBACC.2,P2F;查询2号键JNBACC.3,P3F;查询3号键JNBACC.4,P4F;查询4号键JNB ACC.5,P5F;查询5号键JNB ACC.6,P6F;查询6号键JNB ACC.7,P7F;查询7号键,键处理程序(续),LJMPRETURN P0F:LJMPPROM0;入口地址表P1F:LJMPPROM1 P6F:LJMPPROM6 P7F:LJMPPROM7PROM0:;0号键功能程序LJMPRETURN;0号键处理完返回键盘扫描 PROM7:;7号键功能程序LJMPRETURN;7号键处理完返回键盘扫描RETURNRET,(2)矩阵式(行列式)键盘,结构:键的数目多,将键按行列排成矩阵形式。矩阵式键盘由行线和列线组成,按键位于行、列线的交叉点上。图9-10为44的矩阵式键盘结构。优点:在按键数目较多的场合,节省I/O口线,图9-10 44矩阵式键盘结构,矩阵式(行列式)键盘的按键识别,矩阵式键盘按键的识别方法分为扫描法和反转法。扫描法第1步,识别键盘有无键按下:列线输出全0然后输入行线状态,若行线状态为全1(1111)则没有键按下;若行线状态一定不为全为1,则一定有任一键按下。第2步,识别出具体的键位:逐列扫描,先第一列输出为0,其他列为1,列编码为1110。然后输入行线状态,若行线状态为全1(1111),即按键不在此列线交叉点上,继续扫描。第二列输出为0,其他列为1,列编码为1101,再输入行线状态,若行状态不是全1,即按键在该列交叉点上,否则继续扫描。,扫描法识别按键,将此时的扫描列码与行码组合得到的按键码,即可确定按键的位置。如图9-10所示的“3”键,它位于第4列和第1行交叉点上,其列码为:0111,行码为:1110,键码为:0111,1110B=7EH,图9-10 44矩阵式键盘结构,每个键的键码,负逻辑表示-行列线数据求反组合,上例中的各键值分别为:88H84H82H81H48H44H42H41H28H24H22H21H18H14H12H11H,正逻辑表示-行列线数据直接组合,图9-10中的各键码分别为:77H7BH7DH7EHB7HBBHBDHBEHD7HDBHDDHDEHE7HEBHEDHEEH,线反转法,让行线编程为输入线,列线编程为输出线,并使输出线输出为全低电平,则行线中电平由高变低的所在行为按键所在行。再把行线编程为输出线,列线编程为输入线,并使输出线输出为全低电平,则列线中电平由高变低所在列为按键所在列。线反转法只需经过两步便能获得此按键所在的行列值,比较简练。下面以图9-11所示的矩阵式键盘为例,介绍线反转法的具体步骤。,图9-11 采用线反转法的矩阵式键盘,线反转法,假设键3被按下。第一步,P1.0P1.3输出全为“0”,然后,读入P1.4P1.7线的状态,结果P1.4=0,而P1.5P1.7均为1,因此,第1行出现电平的变化,说明第1行有键按下;第二步,让P1.4P1.7输出全为“0”,然后,读入P1.0P1.3位,结果P1.0=0,而P1.1P1.3均为1,因此第4列出现电平的变化,说明第4列有键按下。综上所述,即第1行、第4列按键被按下,此按键即键3按下。,图9-11 采用线反转法的矩阵式键盘,键盘接口完成的主要功能:,键盘扫描:判断是否有键按下;键识别:确定闭合键的行列位置;产生闭合键键码;排除多键、串键(复按)及去抖动。,键的识别和键功能实现,键的识别由接口电路完成,即键盘接口问题;键的功能实现由中断程序完成。,键处理子程序,在计算机中每一个键都对应一个处理子程序,得到闭合键的键码后,转相应的健处理子程序,实现该键所设定的功能。,键处理程序的流程如图9-12,图9-12键处理流程图,9.3 51单片机键盘接口和键功能的实现,单片机的键盘键接口可以有多种方法实现。使用单片机本身的并行口或串行口;使用通用接口芯片(8255、8155等);使用专用接口芯片如8279,周立功公司的ZLG7289A,ZLG7290B,MAX7219,南京沁恒公司的CH451,HD7279和BC7281等。在单片机应用系统设计中,一般都是把键盘和显示器放在一起考虑。也有的系统仅单独需要键盘或显示器。介绍几种实用的键盘/显示器接口的设计方案。,9.3.1 利用AT89S51串行口实现的键盘/显示器接口(举例),使用AT89S51的串行口的方式0的输出方式,构成键盘/显示器接口,如图9-13所示。8个74LS164:74LS164(0)74LS164(7)作为8位LED数码管的段码输出口,AT89S51的P3.4、P3.5作为两行键的行状态输入线,P3.3作为TXD引脚同步移位脉冲输出控制线,P3.3=0时,与门封死,禁止同步移位脉冲输出。这种方案主程序可不必扫描显示器,软件设计简单,使单片机有更多的时间处理其他事务。下面列出显示子程序和键盘扫描子程序。,图9-13 用AT89S51串行口扩展键盘/显示器,显示子程序:,DIR:SETBP3.3;P3.3=1,允许TXD脚同步移位脉冲输出 MOVR7,08H;送出的段码个数 MOVR0,7FH;7FH78H为显示数据缓冲区DL0:MOV A,R0;取出要显示的数送A ADD A,0DH;加上偏移量 MOVC A,APC;查段码表SEGTAB,取出段码 MOV SBUF,A;将段码送串行口的SBUFDL1:JNB TI,DL1;查询1个字节的段码输出完否?CLRTI;1字节的段码输出完,清TI标志 DECR0;指向下一个显示数据单元,DJNZR7,DL0;段码个数计数器R7是否为0,如不;为0,继续送段码 CLR P3.3;8个段码输出完毕,关闭显示器输出 RET;返回SEGTAB:DB 0C0H,0F9H,0A4H,0B0H;共阳极段码表DB99H,92H,82H,0F8H,90HDB88H,83H,0C6H,0A1H,86HDB8FH,0BFH,8CH,0FFH,0FFH,显示子程序:,键盘扫描子程序:,KEYI:MOVA,00H;判断有无键按下,使所有列线为0 MOVSBUF,A;扫描键盘的(8)号74LS164输出为;00H,使所有列线为0KL0:JNBTI,KL0;串行输出完否?CLRTI;串行输出完毕,清TIKL1:JNBP3.4,PK1;第1行有闭合键吗?如有,跳PK1进行处理 JB P3.5,KL1;在第2行键中有闭合键吗?无闭合键跳KL1PK1:ACALL DL10;调用延时10ms子程,软件消抖动 JNB P3.4,PK2;判断是否由抖动引起?JB P3.5,KL1PK2:MOV R7,08H;不是抖动引起的 MOV R6,0FEH;判别是哪一个键按下,FEH为最左1列为低MOV R3,00H;R3为列号寄存器 MOV A,R6KL5:MOV SBUF,A;列扫描,列扫描码从串行口输出,KL2:JNB TI,KL2;等待串行口发送完 CLR TI;串行口发送完毕,清TI标志 JNB P3.4,PKONE;读第1行线状态,第1行有键闭合跳PKONEJB P3.5,NEXT;读第2行状态,2行某键否?MOV R4,08H;2行中有键被按下,行首键号08H送R4 AJMP PK3PKONE:MOV R4,00H;1行键中有键按下,行首键号00H送R4PK3:MOV SBUF,00H;等待键释放,发送00H使所有列线为低KL3:JNB TI,KL3;判1个字节是否发送完毕 CLR TI;发送完毕,清标志KL4:JNB P3.4,KL4;判行线状态 JNB P3.5,KL4 MOV A,R4;两行线均为高,说明键已释放 ADD A,R3;计算得键码A RET,键盘扫描子程序:,NEXT:MOV A,R6;列扫描码左移一位,判下一列键 RL A MOV R6,A;记住列扫描码于R6中 INC R3;列号增1 DJNZ R7,KL5;列计数器R7减1,8列键都检查完否?AJMP KEYI;8列扫描完,开始下一个键盘扫描周期DL10:MOV R7,0AH;延时10ms子程序DL:MOV R6,0FFHDL6:DJNZ R6,DL6 DJNZ R7,DL RET,键盘扫描子程序:,本例中,如只需LED数码管显示部分,可把键盘部分的电路去掉即可;如只需键盘,可把LED数码管部分的电路去掉。,9.3.2 使用8155作为键盘接口,接口电路逻辑图(见图9-14),图9-14 8031用8155扩展I/O口组成的矩阵式键盘连线图,8155PA口地址7F01HPC口地址7F03H,判断有无键按下,PA口输出00H,PC口输入行状态信号;若PC3PC01111,有键按下,去抖动,延时510ms后再判断有无键按下,确认哪个键被按下及其键号,8155的PA口依次输出下列扫描字:,键扫描及识别过程,8155:PA口输出列扫描信号,PC口输入行状态信号,,,则每个键的键值(列行组合),FE E、FD E、FB E、F7 E、EF E、DE E、BF E、7F E FE D、FD D、FB D、F7 D、EF D、DE D、BF D、7F D FE B、FD B、FB B、F7 B、EF B、DE B、BF B、7F B FE 7、FD 7、FB 7、F7 7、EF 7、DE 7、BF 7、7F 7,每个键的键号(自己安排),N=行首键号+列号,确认哪个键被按下及其键号(续),8155的PC口输入行状态可能为下列之一:,等待键释放后再进行进一步处理。,键扫描程序框图,入口,有键按下?,延时12ms,有键按下?,N,Y,N,Y,键号入栈保存,按键抬起?,N,Y,键号送A,返回,判断按键是否抬起(以防止重复进行键处理),键扫描程序,ORG1000H KEY1:ACALLKS1;调用判断有无键按下子程序JNZLK1;有键按下,转去抖动AJMPKEY1;无键按下,返回LK1:ACALLTM12S;延时12msACALLKS1;再查有无键按下JNZLK2;确实有键按下,逐行扫描,确定具体键AJMPKEY1;无键按下,返回LK2:MOVR2,#0FEH;首列扫描字送R2MOVR4,#00H;首列号R4LK4:MOVDPTR,#7F01H;首列扫描字送8155的PA口MOVA,R2;第一列扫描MOVXDPTR,A;使第i列为0(R2中Di位为0),键扫描程序(续),INCDPTRINCDPTR;指向8155的PC口MOVXA,DPTR;读入行状态JBACC.0,LONE;0行无键按下,转查1行MOVA,#00H;0行有键按下,行首键号#00H送AAJMPLKP;求键号LONE:JBACC.1,LTWO;1行无键按下,转查2行MOVA,#08H;1行有键按下,行首键号#08H送AAJMPLKP;求键号LTWO:JBACC.2,LTHR;2行无键按下,转查3行MOVA,#10H;2行有键按下,行首键号#10H送AAJMPLKP;求键号LTHR:JBACC.3,NEXT;3行无键按下,转查下一列MOVA,#18H;3行有键按下,行首键号#18H送A,键扫描程序(续),LKP:ADDA,R4;求键号=行首键号+列号PUSHACC;键号入栈LK3:ACALLKS1;等待键释放JNZLK3;未释放,继续等待POPACC;已释放,键号送ARETNEXT:INCR4;指向下一列,列号加1MOVA,R2;判断8列扫描完没有JNBACC.7,KND;8列扫描完,返回RLA;没扫描完,置下一列扫描字MOVR2,A;扫描字送AAJMPLK4;继续下列扫描KND:AJMPKEY1;8列扫描完,返回,键扫描程序(续),KS1:MOVDPTR,#7F01H;查有无键按下子程序MOVA,#00HMOVXDPTR,A;8155 PA口输出全扫描字#00HINCDPTRINCDPTR;指向8155的PC口MOVXA,DPTR;读入行状态,若有键按下,则A0FFHCPLA;改成正逻辑,若有键按下,则A00HANLA,#0FH;屏蔽高四位RET;子程序返回,当有键按下时,AA00HT12sm:MOVR7,#18H;12sm延时子程序TM:MOVR6,#0FFH TM6:DJNZR6,TM6;td=1+(1+255*2+2)*24+2*MCDJNZR7,TMRET,键操作及功能处理,求出键号后要进行键处理:先判断是何种键,然后:对数字键-送显示缓冲区显示;对功能键-执行相应的功能键处理程序。,设:015号键为数字键,即键号10H的是数字键;1631号键为功能键,即键号10H的是功能键;其功能键处理程序入口地址分别为:AAA、BBB、CCC、PPP。,键操作及功能处理(续),ORG8000HKEYADR:MOVA,BUFF;键号送ACLRCSUBBA,#10H;Y与10H比较JCDIGPRO;10H,数字键,转KEYTBL:MOV DPTR,#JMPTBLRLA;使键值为0、2、4、6、偶数AJMPA+DPTR,则转入功能键处理程序清单如下:,键操作及功能处理(续),JMPTBL:AJMPAAA;2 字节指令散转到16个功能键处理AJMPBBB;程序入口AJMPCCCAJMPDDDAJMPEEE AJMPFFFAJMPGGGAJMPHHHAJMPIIIAJMPJJJAJMPKKKAJMPLLLAJMPMMMAJMPNNNAJMPOOOAJMPPPP,9.3.2 各种专用的键盘/显示器接口芯片简介,使用键盘接口专用芯片,可省去编写键盘/显示器动态扫描程序以及键盘去抖动程序编写的繁琐工作。目前各种专用接口芯片种类繁多,各有特点,总体趋势是并行接口芯片逐渐退出,串行接口芯片越来越多的得到应用。早期的较为流行的键盘/显示器芯片8279,目前流行的键盘/显示器接口芯片均采用串行通信方式,占用口线少。常见的芯片有:周立功公司的ZLG7289A、ZLG7290B、MAX7219、南京沁恒公司的CH451、HD7279和BC7281等。,可编程键盘/显示器接口芯片8279,8279是一种专用于键盘/显示器的可编程接口电路,能对键盘自动扫描,给出闭合键的键码,能自动向数码管显示器输出显示代码和位代码。其中键盘接口电路可与64键点阵式键盘联接,具有二键封锁或N键巡回功能,可自动消除按键抖动。显示器接口电路可与8位或16位数码管显示器联接。,8279内部结构,电路逻辑分为三个部分:(1)芯片接口控制逻辑数据缓冲器I/O控制电路(2)键盘接口控制逻辑扫描计数器扫描回送电路键盘去抖动与控制电路88FIFO/传感器RAM与状态电路控制与时序寄存器及时序控制电路,8279内部结构,(3)显示器接口控制逻辑168显示用RAM显示寄存器显示地址寄存器,电路逻辑结构示于图9-15,8279内部结构,图9-15 8279的逻辑结构,8279内部结构图,控制与定时寄存器:寄存键盘及显示器工作方式,完成控制功能 定时控制:包括基本的计数器是可编程N计数器,N由编程指定(231),对CLK分频,获得内部所需100kHz工作时钟;其他再分频,为键盘及显示器扫描提供扫描时钟,4位的计数器,有译码、编码两种方式,由编程设定译码方式:最低两位经译码,由SL03输出,作为键盘及显示器的扫描信号.(任何时刻,SL03只有一个信号有效,实现4选1)编码方式:计数器的状态由SL03直接输出,再经外部译码,才能作为扫描信号.(实现16选1),(1)芯片接口控制逻辑,实现 8279 和单片机接口,主要包括:数据缓冲器双向、三态的数据缓冲器用于芯片内部总线和系统总线的连接,进行单片机和 8279 之间的数据传送,信号引脚为 DBODB7。I/O控制电路I/O 控制电路用于接收单片机方面送来的控制信号,并产生所需的8279内部控制信号,例如控制数据缓冲器的数据输入输出等。中断请求产生电路根据键盘存储区的状态产生中断请求信号。,(2)键盘接口控制逻辑,扫描计数器扫描计数器电路用于为键盘提供扫描信号,4 位扫描信号从扫描线 SL3SL0输出,并具有两种输出形式 译码方式(也称内部译码形式)指扫描代码直接由扫描线SL0SL3输出,每次只有1位是低电平(4选1)编码方式(也称外部译码形式)指扫描代码经SL0SL3外接译码器输出SL3SL0输出波形见图9-16,图9-16 扫描输出波形,(2)键盘接口控制逻辑(续),控制与时序寄存器及时序控制电路用于对键盘扫描进行控制。时序控制部件包括基本定时计数器,其中第一个N计数器是一个N预分频定标器,可通过编程使内部时序与CPU相适应。预分频定标器的分频系数可由程序设定为231。使内部计数频率为100KHz时,给出5.1mS的键盘扫描时间和10.3mS的去抖动时间。其它计数器将此基本计数频率再分频,以提供适当的键扫描、行扫描、键盘矩阵扫描及显示器扫描时间。,(2)键盘接口控制逻辑(续),回送缓冲器与键盘去抖动和控制电路输入每次扫描的列线RL0 RL7状态,以进行闭合键的搜索。回送缓冲器具有锁存功能,对回送线RL7RL0上的信息进行缓冲和锁存。在键盘工作方式下,对回送线逐条扫描,以确定该行中哪一个键闭合。当去抖动电路测得某一按键闭合后,等待10mS,然后再重新检查该键是否闭合,如果仍然闭合,那么该键在阵列中的地址及SHIFT和CNTL的状态被送入先进先出寄存器FIFO。在扫描传感器矩阵方式下,每次扫描按键时直接把回送线上的内容送入传感器RAM的相应单元中去。在选通输入方式下,回送线的状态将在控制/选通线上的脉冲上升沿送入先进先出寄存器。,(2)键盘接口控制逻辑(续),FIFO/传感器RAM与状态电路 FIFO/传感器RAM是一个双功能88 RAM,在键盘或选通输入方式下是一个先进先出寄存器(FIFO);信息输入时,每一组信息写入RAM中的下一单元,然后按写入顺序读出;FIFO状态电路存放FIFO中的字符数目以及FIFO满或空的状态;FIFO写入或读出次数超过FIFO的容量时,视为出错;在扫描传感器矩阵方式下,该存储器用作传感器RAM;当检测到一个传感器状态发生变化时,IRQ变为高电平,向CPU发中断请求,(3)显示器接口控制逻辑,显示存储区8279 可连接8位和16位的 LED 显示器;为给每位显示器提供显示数据,在8279 芯片中有一个168的RAM存储区,其中每一个8位 RAM 单元对应一位LED显示器,即0 到 15 地址对应 LED 显示器的015 位,显示器的0位在最左边,15 位在最右边。显示缓冲器(显示更新寄存器)用于为显示器提供段控数据;使用时,8279 自动对显示器扫描,将显示缓冲器中的数据输出在显示器上显示出来。,显示器地址寄存器及显示用RAM,显示器地址寄存器用来存放CPU正在读/写的字节地址,以及正在显示的两个4位的半字节地址。读/写地址由编程设定,也可设定每次读/写后地址自动加1。在设定适当的工作方式和地址以后,CPU可直接读出显示用RAM中的内容。A、B两个半字节地址由8279自动刷新,以便与CPU输出值相对应。A、B两半字节可以分别输出,也可作为一个字节输出,由工作方式确定。数据送显示器的方式可设定为左端送入,也可以设定为右端输入。,8279 的信号引脚,8279共有40个引脚,采用双列直插式封装(见图9-17),图9-17 8279引脚与逻辑符号图,8279的引脚功能如下:,(1)数据线DB7DB0:数据输入/输出线,双向,在接口电路中与系统数据总线相连,用以传送CPU和8279之间的数据和命令。(2)地址线 CS#:片选线。CS#=0,选中8279。A0:信息特征线。当A0=1时,为命令字及状态字地址;当A0=0时,为片内数据地址,故8279芯片占用2个端口地址。(3)控制线 CLK:时钟脉冲输入端。,(3)控制线,RD#:读信号,输入,低电平有效,将缓冲器中的数据读出,送外部数据总线。WR#:写信号,输入,低电平有效,将外部数据总线上的数据写入内部单元。IRQ:中断请求,输出,高电平有效。当键被按下,FIFO RAM中有数据时,该信号有效。SL3SL0:扫描输出线,用来扫描按键开关或传感器矩阵以及显示器的各位数字。RL7RL0:键扫描输入(回送)线,通过按键或传感器开关与扫描线联接,内设上拉电路,使之保持为高电平。当某一按键闭合时,其中一条变为低电平。在选通输入方式下可作为8条输入线。,(3)控制线,SHIFT:换档线。来自外部键盘或传感器矩阵的输入信号,它是8279键盘数据的次高位即D6位的状态,该位状态控制键盘上/下档功能。在传感器方式和选通方式中,该引脚无用。CNTL/STB:控制/选通输入线,高电平有效。键盘方式时,键盘数据最高位(D7)的信号输入到该引脚,以扩充键功能;选通方式时,当该引脚信号上升沿到时,把RL0RL7的数据存入FIFO RAM中。OUTA30,OUTB30:是164显示器更新寄存器的两个输出端,输出数据与扫描线(SL3SL0)同步,以供多路转换数字显示器使用。两个端口可并为一个8位端口使用。OUTA30:通常作为显示信号的高4位输出线;OUTB30:通常作为显示信号的低4位输出线。,(3)控制线,BD#:空格显示,输出,低电平有效。在数字切换过程中使显示器熄灭,或者由显示熄灭命令使显示器熄灭。RESET:复位信号输入端,高电平有效。Vcc:5V电源。Vss:地。,8279的工作方式,(1)键盘工作方式 8279在键盘工作方式时,可设置为双键互锁方式和N键循回方式双键互锁方式:若有两个或多个键同时按下时,不管按键先后顺序如何,只能识别最后一个被释放的键,并把该键值送入FIFO RAM中。N键循回方式:一次按下任意个键均可被识别,按键值按扫描次序被送入FIFO RAM中。,(2)传感器(扫描)方式,FIFO RAM中8个单元用于寄存传感器的现时状态,又称传感器RAM,其地址编号与扫描线顺序一致;传感器方式是把传感器的开关状态送入传感器RAM中。当CPU对传感器阵列扫描时,一旦发现传感器阵列(最多为88位)中某一位状态发生变化时,产生IRQ(高电平),中断响应后转入中断处理程序。,(3)选通输入方式与8255A通输入端口的功能完全一样,CNTL/STB作为选通信号,上升沿锁存RL0RL7到FIFO RAM;,(4)显示方式,8279的显示方式又可分为左端入口和右端入口方式;显示数据只要写入显示RAM则可由显示器显示出来,因此显示数据写入显示RAM的顺序,决定了显示的次序;左端入口方式:显示位置从显示器最左端1位(最高位)开始,以后显示的字符逐个向右顺序排列;显示器位置编号与显示RAM地址一一对应(0号单元显示在0号显示器上);右端入口方式:显示位置从显示器最右端1位(最低位)开始,已显示的字符逐个向左移位。但无论左右入口,后输入的总是显示在最右边。,8279的寄存器,8279共有三个寄存器:命令寄存器状态寄存器数据寄存器命令和状态寄存器对应同一个地址。(1)命令寄存器命令寄存器是8位寄存器,只能写,不能读;高3位(D7、D6、D5)是命令的特征位,8种不同的状态组合代表着不同的命令。命令的格式见表9-8,8279的寄存器(续),(2)状态寄存器 8279 的状态寄存器为 8 位寄存器,只能读,不能写;用于在键输入及选通输入方式中,指出键数据缓冲器 FIFO RAM 中的数据字节个数和是否出错。状态字格式如表9-3,DU:显示无效标志,当清除命令尚未完成时,该位置1 S/E:键盘输入方式下作特殊错误标志,=1:多键同时按下O:溢出标志,向已满的FIFO RAM写时置1U:不足标志,从已空的FIFO RAM读时置1F:表示 FIFO RAM 已满(存有 8 个键码)N2N1N0:FIFO RAM中字符的个数,表9-3 8279的状态字格式,8279的寄存器(续),状态寄存器各位的意义 D2,D1,D0(N2,N1,N0):其值为 FIFO RAM 中数据的个数;D3(F):D3=1,表示 FIFO RAM 已满(存有 8 个键码)D4(U):D4=1,表示“不足”错误;D5(O):D5=1,表示“超出”错误;D6(S/E):用于传感器矩阵输入方式,D6=1表示多键同时闭合;D7(Du):显示无效标志。当清除命令尚未完成时,该位置1。,8279的寄存器(续),(3)数据寄存器数据寄存器实际上就是 FIFO RAM 中最前面的那个单元,其内容为被按键的信息,通过读它把键盘信息输入单片机。该寄存器的数据格式如表9-4所示:D2D1D0:闭合键的列号(由RL7 RL0值确定);D5 D4D3:闭合键的行号(扫描计数值);D6:换挡健 SHIFT 的状态;D7:控制健 CNTL 的状态。注意,在传感器扫描方式和选通输入方式中,输入数据即为 RL7RL0的输入状态。,8279数据输入/输出格式,输入/输出数据不仅要先确定地址口,而且数据存放也要按一定格式,其格式在键盘和传感器方式有所不同。,(1)键盘扫描方式数据输入格式(见表9-4),D7:控制键“CNTL”状态 D6:控制键“SHIFT”状态 D5 D4 D3:被按键所在列号(由SL0-SL2)状态确定)D2 D1 D0:被按键所在行号(由RL0-RL7)状态确定,表9-4 键盘扫描方式数据输入格式,8279数据输入/输出格式(续),(2)传感器方式及选通方式数据输入格式,此种方式8位输入数据为RL0-RL7的状态数据输入格式见表9-5,表9-5 传感器及选通方式的数据输入格式,8279的命令字及其格式,8279的各种工作方式都要通过对命令寄存器的设置来实现。8279共有8种命令,通过这些命令设置工作寄存器,选择各种工作方式。命令寄存器共8位,格式如下:,8279的命令字及其格式(续),8279的一条命令由两大部分组成;命令寄存器高3位D7D5为命令特征位,表征命令类型。D7D5三位的状态可组合出8种形式,对应8类命令。命令寄存器的低5位D4D0为命令的具体内容。,8279的命令字类型设置,每种特征所代表的命令如表9-6所示,表9-6 8279命令特征,(1)键盘/显示命令:(特征位 D7D6D5=000),D4、D3两位用来设定4种显示方式;D2、D1、D0三位用以设定8种键盘/显示扫描方式键盘/显示命令格式见表9-7,设置工作方式,00:8字符,左入口01:16字符,左入口10:8字符,右入口11:16字符,右入口,00:键盘,双键锁定01:键盘,N键轮回10:传感器扫描11:选通输入,0:编码扫描 1:译码扫描,表9-7 8279的键盘/显示命令格式,显示器方式设置(见表9-8),(1)键盘/显示命令(续),键盘方式设置:,(1)键盘/显示命令(续),译码扫描(内译码):指扫描代码直接由扫描线SL0SL3输出,每次只有1位是低电平(4选1);编码扫描(外译码):是指扫描代码经SL0SL3外接译码器输出由于键盘最大88=64个键,由SL0SL2接3:8译码器,译码器的8位输出作为键盘扫描输出线(列线),RL0RL7为输入线(行线)。8279最多驱动16位显示器,故可由SL0SL3接4:16译码器,译码器的16位输出作为显示扫描输出线(16选1),决定第几位显示。显示字段码由OUTA0OUTA3和OUTB0OUTB3输出。,例9-1:若希望设置8279为键盘译码扫描方式、N键轮回,显示8个字符、右端入口方式,确定其命令字。根据题目要求可进行分析,因为具有下列条件:是键盘/显示命令特征位:D7 D6 D5=000(表9-6);8个字符右端入口显示:D4 D3=10(表9-8);键盘译码扫描,N键轮回:D2 D1 D0=011(表9-9);所以8位命令器存器状态D7D0=00010011B,即该命令字13H送入命令寄存器口地址则可满足题目要求。例9-2:若已知命令字为08H,判断8279工作方式。因为命令字为08H,即D7D0=00001000B,显然D7 D6 D5=000,该条命令为键盘/显示命令,D4D3=01为16字符左端入口显示方式,D2D1D0=000,键盘为编码扫描、双键锁定方式。,(2)内部时钟设置命令(D7D6D5001),例9-3:若8279 CLK的输入信号频率为3.1 MHz,则分频系数应为31D=1FH,于是D4D0=11111,控制字为:D7D0=00111111B=3FH,分频目的:得到100KHz的基本工作时钟,(2)内部时钟设置命令(续)(D7D6D5001),8279的内部时钟信号是由外部输入的时钟信号经过分频产生;分频系数由D4D0来设定,分频系数范围在231之间有的设计会用单片机的ALE端接8279的CLK端,但ALE端输出的脉冲频率比8279所需工作时钟频率(10

    注意事项

    本文(单片机的接口技术.ppt)为本站会员(小飞机)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开