第12章-键盘接口技术课件_第1页
第12章-键盘接口技术课件_第2页
第12章-键盘接口技术课件_第3页
第12章-键盘接口技术课件_第4页
第12章-键盘接口技术课件_第5页
已阅读5页,还剩54页未读 继续免费阅读

下载本文档

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

文档简介

2008.10微机接口技术返回主目录键盘是计算机系统中最基本的输入设备,是人机对话不可缺少的纽带,人们通过它向计算机输入程序、数据等各种信息。本章将介绍键盘的分类、结构、工作原理,键盘接口的组成及其控制。第十二章键盘接口技术12.1概述

一、键开关与键盘的分类

1.键开关的分类键开关主要可分为两类:

有触点开关常见的有白金触点、导电橡胶、舌簧式开关等。

无触点开关有电容式、霍尔元件、触摸式开关等。

无触点开关是利用电子器件的导通与截止来接通或断开电路,其寿命长、可靠性好、响应速度快、工作频率高,在性能上比有触点的机械式开关优越。但它的结构复杂,成本高。

2.键盘的结构按照所用印刷电路板的不同,键盘可分为两类:硬板结构采用普通印刷电路板,按键直接焊接在电路板上。

软板结构采用聚酯薄膜作为印刷电路板的基底,使用导电橡胶作为接触材料。

软板结构多用于便携式微型机和袖珍计算器,其体积小、重量轻、成本低、不用金属弹簧,但使用时的手感不如硬板结构。

3.键盘分类

⑴按键盘功能分类分为两类:

编码键盘:键盘本身带有硬件电路,能够由硬件逻辑自动检测被按下的键,然后自动产生与被按键对应的键编码(ASCII码、BCD码等),并以并行或串行通信方式送往主机。它使用方便、接口电路简单,但自身电路复杂、成本较高。

非编码键盘:这种键盘由简单的键开关行列矩阵组成,只能提供键开关的行列位置(位置码或扫描码),按键的识别、键值的确定和输入到主机等工作全靠软件完成。这类键盘的硬件电路简单、成本低,被广泛地应用于计算机中。

⑵按键盘空间维数分类分为两类:线性键盘(一维键盘):最简单的键盘,如图所示。其中,每一个键连接到I/O端口的一位,无键闭合时各位均处于高电平。当有一个键按下时,就使对应位接地而成为低电平,其他位则仍为高电位。这样,CPU只要通过读I/O端口,检测端口中哪一位为低电平,便可识别出所按下的键。这种键盘结构简单,但当键盘上的键较多时,需使用的I/O端口太多,因此只能用于仅有几个键的小键盘中。

矩阵键盘(二维键盘):是指将所有按键按行和列排列成矩阵形式,如图所示。对于m×n个键的键盘,如果采用线性键盘结构,则需要m×n位I/O端口,而采用矩阵键盘结构只需要m+n位。在左图中,如果K7号键按下,则第0行线和第7列线接通而形成通路,如果第0行线为低电平,则由于键K7的闭合,会使第7列线也输出低电平。矩阵式键盘工作时,就是按照行线和列线交叉点上的电平值来识别按键的。

二、键盘接口的基本功能

1.消除键抖动

由于人的手指和有触点开关的弹性,每个键在按下和松开时,都会经历短时间的抖动后才能稳定地接通或断开,表现为键开关反复地闭合与断开,导致键开关接触电阻的波动。抖动持续时间因键的质量而有所不同,一般不超过20ms。如果在识别被按键和释放键时,不消除这段不稳定的抖动状态,就可能导致将一次按键错误地识别成多次按键。返回主目录

消除抖动的常用方法有两种:

软件延时法:一旦检测到有键按下或释放时,用软件产生约20ms的延时,等待键的输出已达到稳定状态后再去读取代码。

软件延时法的处理过程是:在检测到有键按下或释放时,延时20ms后再次进行检测。若第二次未检测到有键按下或释放,说明前一次结果为干扰或者抖动,不予处理。否则,说明信号已经稳定,然后才进入键值处理(读取代码)。完成后,一般还要延时等待鍵释放。

硬件消抖法:在键开关与计算机接口之间增加一个(如双稳态触发器、单稳态触发器、RC滤波电路等)消抖动电路。硬件消抖法电路复杂,因此大多数场合下采用软件延时法。

返回本章目录

2.重键处理

重键:在一次按键期间计算机多次检测到同一键值的情况。

重键处理方法两种:

锁定法:在确认有键按下后,必须检测到该键释放后才能进行下一次键盘检测。

延时法:在确认有键按下后,经过给定的延时时间后,如果检测被按键仍未释放,则予以连续检测与处理(例如连续递增、递减等操作)。

3.串键处理

串键:是指两个或两个以上按键同时按下,或者一个键按下后尚未释放又按下另一个键,从而会检测到2个或2个以上按键的情况。

串键处理方法两种:

串键合法:这种系统中,除了单个键之外,还定义了一些特定的多键组合来表示某些信息,使键盘的功能得到扩展。

例如,IBMPC中的Ctrl+C、Ctrl+P等两键组合,以及如Ctrl+Alt+Del等三键组合。处理时,系统首先确定第一个按键已经按下,在判定该键松开前,可能检测到另一个按键,则将这两个按键的组合与系统中给定的合法组合比较。如果合法,则进入后续处理,否则丢弃第二个按键信息。返回本章目录

串键非法:有的系统认定串键为非法情况,处理时主要有两种策略:

双键锁定:在检测到有多个键被按下时,只认定最后释放的键为合法键。

N键连锁:当一个键被按下后,在此键未稳定释放之前,对其它被按下的键不予理会,只产生最先按下键的编码。或根据键扫描顺序,一旦扫描到有按键按下则不再继续扫描。这种方法实现起来非常简单而经常使用。

4.识别键值识别键值是键盘接口所要解决的主要问题,一般通过软硬结合的方法来实现,典型的有行扫描法和线反转法两种方法,其中以行扫描法使用最为广泛。12.2非编码键盘接口及其控制

一、简单键盘接口与行扫描法

键盘接口电路可以使用中、小规模集成电路芯片组成,也可以使用可编程接口芯片实现。相对而言,前者比后者电路复杂,但成本较低。返回本章目录1.键盘及其接口的组成返回本章目录

图示为一种非编码键盘接口电路。该键盘由30个键排成6行5列的矩阵结构。芯片74LS273、75492P组成输出端口(地址90H),控制行线电平。芯片74LS244为输入端口(地址92H),读入列线电平。

图中,各列线在没有键被按下时为高电平(逻辑“1”);当有键被按下时,该键所在的行线、列线将被短接,相应列线的电平状态将取决于所短接行线的电平状态。

2.行扫描法原理原理:通过程序控制向键盘的所有行逐行输出低电平(即逐行扫描),若无按键按下闭合,则所有列的输出均为高电平。若有一个按键按下闭合,就会将所在的列钳位在低电平。通过程序读入列线的状态,就可以判断有无键按下及哪一个键按下,键所在的行、列位置的编码就是该键的位置码。流程:可分成键盘扫描、逐行扫描、键码生成、按键处理4个阶段。

返回本章目录

⑴键盘扫描:该阶段的功能是对键盘进行全扫描以检测是否有键被按下,方法是:向所有行线输出低电平,读入各列线电平值并判定,若为全“1”则无键按下,返回主程序;否则有键按下,继续向下执行。在此阶段还必须采用键消抖措施防止错误检测。

⑵逐行扫描:功能是通过逐行扫描确定被按键所在的行号与列号,方法是从第0行开始到最后一行依次进行扫描:向当前行输出低电平,其它行输出高电平,然后读入各列线电平值并判定,若不是全“1”则找到了被按键,其位置就在电平为“0”的行、列交叉点,结束本阶段工作,将相应行、列号带入下一阶段;若为全“1”,则说明当前行没有键被按下,接着扫描下一行。依此类推,直至找到被按的键。

⑶键值生成:将被按键的二维的行、列号转换成与行列坐标对应的、唯一的一维键编号。为避免出现重键,在这一阶段还要进行键释放检测和键消抖处理。

键值=行首键号+列号

⑷按键处理:根据键号转向相应的键处理程序,处理完毕后返回主程序。

行扫描法在识别被按键的同时,还具有防止串键的作用。如果在不同的行有几个键同时按下,就只能取位于先扫描行的键为有效键;如在同一行有多个键被同时按下,则读入的列数据必然有多位同时为“0”,据此可以认为这次按键无效,或者取列值最小的键作为有效按键。键扫描与处理功能一般是编写成子程序被调用的。3.行扫描法编程举例

下面是对上述电路采用行扫描法实现键盘控制的程序段举例,其键消抖采用软件延时法,重键处理采用锁定法,不考虑串键情况。

KEYSM:MOVAL,3FH;键盘扫描OUT90H,AL;使所有行为低电平INAL,92H;读入和提取列状态ANDAL,1FHCMPAL,1FH;有键按下否?JZKEYEND;无键按下返回主程序CALLD20MS;延时消除前沿抖动

KEYDN0:INAL,92H;读入和提取列状态ANDAL,1FHCMPAL,1FH;键仍然按下否?JZKEYEND

;无键按下为干扰,返回主程序MOVBL,01H;第一行的扫描码送BLMOVBH,00H;行首鍵号计数器赋初值KEYDN1:MOVAL,BL;逐行扫描OUT90H,AL;输出扫描码INAL,92HANDAL,1FHCMPAL,1FH;该行有键按下否?JNZKEYDN2;有键按下,转求键号INCBH;行首鍵号计数器加5SHLBL,1;求下一行的扫描码CMPBL,40H;所有行扫完?JNZKEYDN1;没有扫完,转下一行扫描JMPKEYEND;扫完,无键按下,返回主程序

KEYDN2:CMPAL,1EH;判0列JNZKEYDN3;MOVAH,0;列号为0JMPKEYDN7KEYDN3:CMPAL,1DH;判1列JNZKEYDN4;MOVAH,1;列号为1JMPKEYDN7KEYDN4:CMPAL,1BH;判2列JNZKEYDN5;MOVAH,2;列号为2JMPKEYDN7KEYDN5:CMPAL,17H;判3列JNZKEYDN6;MOVAH,3;列号为3JMPKEYDN7KEYDN6:MOVAH,4;列号为4KEYDN7:ADDAH,BH;键值=行首键号+列号MOVAL,AH;键值放入AL中保存CALLD20MS;延时消除后沿抖动

KEYDN8:MOVAL,3FH;键盘扫描OUT90H,AL;使所有行为低电平INAL,92H;读入和提取列状态ANDAL,1FHCMPAL,1FH;有键按下否?JZKEYEND;无键按下返回主程序JMPKEYDN8KEYEND:RET

二、可编程接口与线反转法

1.线反转法原理原理:将行线接一个并行端口,先工作在输出方式,列线接另一个并行端口,先工作在输入方式。编程通过行端口向全部行线输出“0”电平,再读入列线的值。如果有键被按下,则必有列线为“0”电平。然后进行线反转,编程改变两个并行端口的工作方式,列端口工作于输出方式,将刚才读入的列线值反转输出到列线;行端口工作在输入方式,读取行线的值,则闭合键所在的行线必为“0”电平。于是,当一个键被按下时,就可以读到一对惟一的列值和行值。

线反转法必须使用可编程并行接口(如8255、8155)来实现。

假定图中K11键被按下,第一次往行线输出全0后,读入的列值为11101;将该列值反转向各列线输出后,改从行线可以读到行值111011。分两次读入的行值和列值合并起来就唯一确定了K11键,从而不必再进行逐行扫描。

显然,线反转法比行扫描法的速度更快,但必须使用可编程接口芯片,并且没有防止串键的作用。2.线反转法编程举例

仍使用上图的按键电路,但不用74LS273、75492P、74LS244等TTL芯片,改用8255可编程接口芯片。其中行线接8255端口A,列线接8255端口B,使用行反转法编程实现对6×5键盘的控制。该程序也编写成子程序形式,出口参数为被按键的行号与列号,分别存放在AH和AL中。程序中取8255的端口地址分别为PA、PB、PC、PCTRL。返回本章目录KEYFZ:MOVAL,82H;设置8255端口A、B工作方式0MOVDX,PCTRL;端口A输出,端口B输入OUTDX,ALMOVDX,PA;行线输出全“0”MOVAL,0OUTDX,ALMOVDX,PB;读入列值INAL,DXCMPAL,1FH;有列线为0?(键盘扫描)JZKEYEND;没有则返回CALLD20MS;消除前沿抖动INAL,DXMOVBL,AL;保存列值CMPAL,1FH;仍然有列线为0?JZKEYEND;没有则返回返回本章目录MOVAL,90HMOVDX,PCTRL;设置8255端口A、B工作方式0OUTDX,AL;端口A输入,端口B输出MOVDX,PBMOVAL,BLOUTDX,AL;输出读入的列值MOVDX,PAINAL,DX;读入行值MOVBH,AL;保存行值CALLD20MS;消除后沿抖动

KEYFZ1:MOVDX,PA;行线输出全“0”MOVAL,0OUTDX,ALMOVDX,PB;读入列值INAL,DXCMPAL,1FH;有列线为0?(键盘扫描)JNZKEYFZ1;有则跳转MOVAH,BH:没有,则行、列值送AX,MOVAL,BL;AH中为行值、AL中为列值KEYEND:RET列号获得:LH:SHRAL,1JCL1MOVAL,0JMPL5L1:SHRAL,1JCL2MOVAL,1JMPL5L2:SHRAL,1JCL3MOVAL,2JMPL5L3:SHRAL,1JCL4MOVAL,3JMPL5L4:MOVAL,4L5:RET行首键号获得:HH:SHRAH,1JCH1MOVAH,0JMPH6H1:SHRAH,1JCH2MOVAH,5JMPH6H2:SHRAH,1JCH3MOVAH,10JMPH6H3:SHRAH,1JCH4MOVAH,15JMPH6H4:SHRAH,1JCH5MOVAH,20JMPH6H5:MOVAH,25H6:RET12.3IBMPC的键盘接口一、IBMPC的键盘1.概述在PC机中,PC/XT机采用83键标准键盘,PC/AT机采用84键键盘,286以上的机型一般使用增强型101键或102键扩展键盘。PC的键盘内部使用单片机来自动识别键的按下与释放,自动生成相应的扫描码(即行列位置码),并以串行通信方式送往主机。此外,它还具有多个键扫描码的缓冲能力和出错情况下的自动重发能力。PC系列键盘的主要特点为:返回本章目录⑴按键采用电容式开关,按键时的上下动作使电容量发生变化,从而实现键开关接通或者断开的目的;⑵属于非编码键盘,键盘上的按键排列成矩阵形式,对按下键的识别采用行列扫描原理,由键盘内部的Intel8048单片机完成;⑶键盘通过一根螺旋形的5芯电缆与主机相连。

IBMPC键盘接口示意图

返回本章目录PC键盘与主机的连接分成三个部分:⑴由按键组成的非编码键盘矩阵。⑵键盘控制器。它与键盘集成在一起,以8位单片机Intel8048为核心组成,负责识别按键和向主机发送键盘数据。⑶主机系统板上的键盘接口电路。在早期的IBMPC和IBMPC/XT中主要采用Intel8255并行接口芯片、74LS322移位寄存器和一些D触发器组成,在IBMPC/AT及以上档次的PC中则采用Intel8042单片机为核心组成。2.键盘的工作原理

返回本章目录8048单片机通过周期性执行固化在其ROM中的键盘扫描程序完成键盘扫描,消除抖动并生成键扫描码,对扫描码的并一串转换,将串行的键扫描码和时钟送到主机等功能。8048最多可以缓存20个键扫描码,P11和P10分别用于请求输入和命令输入。返回本章目录PC系列键盘主要由8048单片机、译码器和16行×8列的键开关矩阵三部分组成。8048单片机是8位CPU,有40个引脚,内部还包括1KB的ROM、64B的RAM、8位定时器/计数器等。

8048定时器每9.6微秒控制计数器增1一次,并从P20引脚输出一个选通信号,启动行、列译码电路工作。8位计数器的DB6~DB3位和DB2~DB0位分别作为行扫描码与列扫描码,经DB总线送至键盘阵列的行扫描与列扫描译码电路,进行行列扫描。检测电路检测有无键按下,并将检测信号送至8048的T1引脚。若有键按下,此时计数器的低七位值即为键扫描码,计数器最高位置0。八位键扫描码经P22引脚以异步串行方式输出,将按键的扫描码送往主机的键盘接口。与此同时,键盘的时钟信号也经P21引脚传送给主机。当键按下时,键盘向主机键盘接口发送的是1字节的键接通扫描码。当键弹起时,发送的则是键断开扫描码。3.键盘扫描码⑴PC与PC/XT机的键盘扫描码使用83键的标准键盘,其键位置号用十进制数表示,而键扫描码用l字节的2位十六进制数表示。例如,键符“D”的按键在键盘中的位置是第32号,它的接通扫描码为20H。因为32D=20H,可见接通扫描码与对应键的位置号是等值的。其断开扫描码也是1字节,是由接通扫描码加上80H而得。例如当“D”键按下后又松开,则从键盘控制器先输出20H,再输出A0H。按键的拍发速率是固定的,当一个键按下0.5秒后仍不松开,将重复输出该键的接通扫描码,其速率为10次/秒。⑵84/101/102键盘的扫描码在键盘按键的布局上,这些键盘与标准键盘有较大差别,两者对同一按键产生的键盘扫描码是不同的,扩展键盘的键位置号与该键的扫描码不同值。例如对于“D”键,扩展键盘的接通扫描码为1字节,键位置是33,接通扫描码是23H,仍然有33D=23H。但其断开扫描码为2字节,是在接通扫描码前加一前缀字节F0H组成。因此,当“D”键按下后又松开,则先输出23H,后输出F023H。这些键盘的按键拍发速率是可选的,从30次/秒到2次/秒,默认值则仍为10次/秒。由上可见,PC及PC/XT与PC/AT以上机型所用的键盘在硬件上是不兼容的,为保证二者键盘中断程序的兼容,要求它们的键盘接口送给CPU的扫描码应该是相同的。为了予以区别,我们将CPU接收到的扫描码称为系统扫描码,键盘设备送到键盘接口的扫描码称键盘扫描码。于是,在PC及PC/XT机中键盘扫描码就是系统扫描码,而且与对应键的位置号相同。而后者的键盘扫描码必须经过转换才能成为与PC/XT完全兼容的系统扫描码。例如,回车键“Enter”,PC及PC/XT键盘分配的键位置是第28号,接通扫描码为1CH,系统扫描码也是1CH;而PC/AT或101、102的扩展键盘将“Enter‘’分配在第43号键位置,键盘的接通扫描码为5AH,经系统板上的键盘接口转换后的系统扫描码仍是1CH。所以,在PC/AT及更高档次机器的键盘接口中,要有能将键盘扫描码转换成与PC/XT机兼容的系统扫描码的硬件支持,以实现对不同键盘的软件兼容。这也就是为什么在IBMPC/AT及以上的PC机型中,采用Intel8042单片机组成键盘接口的原因。返回本章目录二、PC扩展键盘的接口电路Intel8042是一种有40个引脚的单片微处理器,包括8位CPU、2KBROM、128BRAM两个8位I/O端口、一个8位定时器/计数器和时钟发生器。1.8042的主要引脚⑴时钟信号XTALT1、XTALT2_用于外接晶体振荡器。SYNC_用于输出时钟信号,每个指令周期输出一次,选通输出信号或单步操作输入信号。⑵复位与片选信号/RESET_复位信号。/CS_片选信号。⑶控制信号/RD_CPU读信号。/WR_是CPU写信号。A0_最低位地址输入信号;当A0=0时,传送数据;当A0=1时,传送命令。PROG_用于芯片编程的脉冲输入信号(此时VDD=21V);如果访问I/O扩展器8242时,该引脚作为计址数据选通信号。/SS_单步信号;当与SYNC引脚相连时,则芯片进入单步运行状态。EA_允许外部访问信号,用于芯片的仿真、测试或ROM校验,不用时接地。TEST0、TEST1_用于提供测试条件的输入定时信号。返回本章目录⑷I/O端口P17~Pl0_P1口的8条I/O引脚。P27~P20_P2口的8条I/O引脚。⑸电源与地线Vcc_+5V电源。VDD_正常操作接+5V,编程时接+21V。VSS_地线。⑴接收键盘输出的键扫描码通过TEST0和TEST1两个引脚分别接收来自键盘的时钟信号KBDCLK和数据信号KBDDATA。TEST1在键盘时钟同步下,以异步串行格式接收键盘发送的8位键扫描码。当键盘接口接收串行数据,完成串并转换。奇偶校验正确后,接口将键扫描码转换成系统扫描码,并保存在输出缓冲寄存器中。在CPU未取走扫描码期间,P26引脚为低电平,强制键盘时钟线变低,禁止键盘输出下一个扫描码。返回本章目录2.键盘接口的主要功能⑵产生键盘中断接口用P24引脚作为输出缓冲寄存器的标志。当系统扫描码送入输出缓冲寄存器后,P24引脚输出高电平,作为键盘中断请求信号(IRQ1)发给CPU。当IRQ1被CPU响应后,系统调用9号中断服务程序进行键盘代码的处理转换,最后存入键盘缓冲区。键盘中断服务程序先从输出缓冲寄存器中读取键盘扫描码,然后对按键进行判别。为了确保CPU读取扫描码,在读数期间,键盘控制器强制时钟线为低电平,禁止键盘输出下一个键盘扫描码。当输出缓冲寄存器为空后,时钟线变高,才允许键盘输出扫描码。⑶奇偶校验接口对所收到的数据进行奇偶校验,一旦检测到数据出现奇偶错,则将FFH送入输出缓冲寄存器,同时将状态寄存器的奇偶错位(D7)置“1”,通知键盘重新发送数据。⑷接收并执行系统命令键盘接口通过P26、P27引脚将系统发送给键盘的命令送往键盘。键盘中断处理有以下三种方式:⑴键盘接口的硬件中断。当键盘接口收到一个字节的数据后,立即向主机发09H号键盘硬件中断请求。当CPU响应中断请求后,执行相应中断服务程序,其功能如下:①从键盘接口的输出缓冲寄存器(60H)读取系统扫描码;②将系统扫描码转换成ASCII码或扩展码,存入键盘缓冲区;③对换挡键(如CapsLock,Ins等),将其状态存入BIOS数据区中的键盘标志单元;④对组合键(如Ctrl+Alt+Del),则直接执行、完成其相应的功能;⑤对中止组合键(如Ctrl+C或Ctrl+Break),强行中止应用程序的执行,返回DOS。三、键盘中断服务与调用⑵软件中断INT16H。读取键盘的内容可通过软件中断INT16H指令实现。INT16H中断调用功能有:0号,从键盘读一个字符;1号,读键盘缓冲区;2号,读键盘状态字节。⑶INT21H中断调用。在DOS功能调用中,也有多个功能调用号用于获得所需要的键盘信息。常用的键盘操作功能如表12.1和表12.2所示。常用的键盘操作功能

返回本章目录调用号入口参数出口参数功能

0AH=0AX存放

温馨提示

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

评论

0/150

提交评论