基于单片机控制的电子琴设计毕业设计(20页).doc
-基于单片机控制的电子琴设计毕业设计-第 20 页单片机控制电子琴摘 要 电子琴是现代电子科技与音乐结合的产物,是一种新型的键盘乐器。它在现代音乐扮演着重要的角色,单片机具有强大的控制功能和灵活的编程实现特性,它已经溶入现代人们的生活中,成为不可替代的一部分。本文的主要内容是用AT89S51单片机为核心控制元件,设计一个电子琴。以单片机作为主控核心,与键盘、扬声器等模块组成核心主控制模块,在主控模块上设有16个按键和扬声器。本系统运行稳定,其优点是硬件电路简单,软件功能完善,控制系统可靠,性价比较高等,具有一定的实用和参考价值。关键词:单片机键盘扬声器电子琴Abstract Electronic organ is a modern electronic music technology and the product is a new type of keyboard instruments. It played an important role in modern music. SCM has powerful control functions and flexible programming characteristics. It has converged with modern people's lives, become an irreplaceable part. The main content is AT89S51 control of the core components, design of a electronic organ. SCM as a host to the core, with the keyboard, speaker and other core modules. In the main control module has 16 keys and a speaker. The system is steady, its simple hardware circuits, software functions, reliability of control system and high cost performance is its advantages. It also has certain practical and reference value.Key words : SCM keyboard speaker electronic organ毕业设计(论文)原创性声明和使用授权说明原创性声明本人郑重承诺:所呈交的毕业设计(论文),是我个人在指导教师的指导下进行的研究工作及取得的成果。尽我所知,除文中特别加以标注和致谢的地方外,不包含其他人或组织已经发表或公布过的研究成果,也不包含我为获得 及其它教育机构的学位或学历而使用过的材料。对本研究提供过帮助和做出过贡献的个人或集体,均已在文中作了明确的说明并表示了谢意。作 者 签 名: 日 期: 指导教师签名: 日期: 使用授权说明本人完全了解 大学关于收集、保存、使用毕业设计(论文)的规定,即:按照学校要求提交毕业设计(论文)的印刷本和电子版本;学校有权保存毕业设计(论文)的印刷本和电子版,并提供目录检索与阅览服务;学校可以采用影印、缩印、数字化或其它复制手段保存论文;在不以赢利为目的前提下,学校可以公布论文的部分或全部内容。作者签名: 日 期: 学位论文原创性声明本人郑重声明:所呈交的论文是本人在导师的指导下独立进行研究所取得的研究成果。除了文中特别加以标注引用的内容外,本论文不包含任何其他个人或集体已经发表或撰写的成果作品。对本文的研究做出重要贡献的个人和集体,均已在文中以明确方式标明。本人完全意识到本声明的法律后果由本人承担。作者签名: 日期: 年 月 日学位论文版权使用授权书本学位论文作者完全了解学校有关保留、使用学位论文的规定,同意学校保留并向国家有关部门或机构送交论文的复印件和电子版,允许论文被查阅和借阅。本人授权 大学可以将本学位论文的全部或部分内容编入有关数据库进行检索,可以采用影印、缩印或扫描等复制手段保存和汇编本学位论文。涉密论文按学校规定处理。作者签名:日期: 年 月 日导师签名: 日期: 年 月 日目 录1 引言. 12 原理图. 22.1 系统板硬件连线. 33 主要芯片简介. 43.1 AT89S51简介. 43.1.1 主要功能特性. 53.1.2 引脚功能. 53.2 LM386. 63.2.1 LM386内部电路及特性. 73.2.2 LM386的引脚图. 84 模块原理. 114.1 4X4行列式键盘识别. 114.1.1 系统板上硬件连线设计. 124.1.2 程序设计要求. 134.1.3 键盘识别程序框图. 134.2 触摸式模块的实现原理. 154.3.1 单片机产生音乐原理. 174.3.2 音乐产生原理程序图. 185.PCB电路板图. 206 汇编程序. 227 结束语. 34致 谢. 32参考文献. 331 引言 单片微型计算机是大规模集成电路技术发展的产物,属第四代电子计算机,它具有高性能、高速度、体积小、价格低廉、稳定可靠、应用广泛的特点。它的应用必定导致传统的控制技术从根本上发生变革。因此,单片机的开发应用已成为高科技和工程领域的一项重大课题。 电子琴是现代电子科技与音乐结合的产物,是一种新型的键盘乐器。它在现代音乐扮演着重要的角色,单片机具有强大的控制功能和灵活的编程实现特性,它已经溶入现代人们的生活中,成为不可替代的一部分。本文的主要内容是用AT89S51单片机为核心控制元件,设计一个电子琴。以单片机作为主控核心,与键盘、扬声器等模块组成核心主控制模块,在主控模块上设有16个按键和扬声器。本文主要对使用单片机设计简易电子琴进行了分析,并介绍了基于单片机电子琴统硬件组成。利用单片机产生不同频率来获得我们要求的音阶,最终可随意弹奏想要表达的音乐。并且本文分别从原理图,主要芯片,各模块原理及各模块的程序的调试来详细阐述。 一首音乐是许多不同的音阶组成的,而每个音阶对应着不同的频率,这样我们就可以利用不同的频率的组合,即可构成我们所想要的音乐了,当然对于单片机来产生不同的频率非常方便,我们可以利用单片机的定时/计数器T0来产生这样方波频率信号,因此,我们只要把一首歌曲的音阶对应频率关系弄正确即可。2 原理图图2-1 电子琴电路图 图2-2触摸式电器开关电路 2.1 系统板硬件连线 系统板硬件连线如图2-1所示,发生模块,键盘模块,及触摸模块连接如下 1.把“单片机系统”区域中的P1.0端口用导线连接到“音频放大模块”区域中的SPK IN端口上; 2.把“单片机系统“区域中的P3.0P3.7端口用8芯排线连接到“4X4行列式键盘”区域中的C1C4R1R4端口上; 3.把图2-2继电器的开关两端串联在单片机的工作电源上。3 主要芯片简介3.1 AT89S51简介 AT89S51是一个低功耗,高性能CMOS 8位单片机,片内含4k Bytes ISP(In-system programmable)的可反复擦写1000次的Flash只读程序存储器,器件采用ATMEL公司的高密度、非易失性存储技术制造,兼容标准MCS-51指令系统及80C51引脚结构,芯片内集成了通用8位中央处理器和ISP Flash存储单元,功能强大的微型计算机的AT89S51可为许多嵌入式控制应用系统提供高性价比的解决方案。 AT89S51具有如下特点:40个引脚(引脚图如图3-1所示),4k Bytes Flash片内程序存储器,128 bytes的随机存取数据存储器(RAM),32个外部双向输入/输出(I/O)口,5个中断优先级2层中断嵌套中断,2个16位可编程定时计数器,2个全双工串行通信口,看门狗(WDT)电路,片内时钟振荡器。 此外,AT89S51设计和配置了振荡频率可为0Hz并可通过软件设置省电模式。空闲模式下,CPU暂停工作,而RAM定时计数器,串行口,外中断系统可继续工作,掉电模式冻结振荡器而保存RAM的数据,停止芯片其它功能直至外中断激活或硬件复位。同时该芯片还具有PDIP、TQFP和PLCC等三种封装形式,以适应不同产品的需求。图3-1 管脚图3.1.1 主要功能特性· 兼容MCS-51指令系统 · 32个双向I/O口· 2个16位可编程定时/计数器 · 全双工UART串行中断口线· 2个外部中断源 · 中断唤醒省电模式· 看门狗(WDT)电路 · 灵活的ISP字节和分页编程· 4k可反复擦写ISP Flash ROM · 4.5-5.5V工作电压· 时钟频率0-33MHz · 128x8bit内部RAM· 低功耗空闲和省电模式 · 3级加密位· 软件设置空闲和省电功能 · 双数据寄存器指针3.1.2 引脚功能 VCC(40):5V; GND(20):接地; P0口(3932):P0口为8位漏极开路双向I/O口,每引脚可吸收8个TTL门电流; P1口(18):P1口是从内部提供上拉电阻器的8位双向I/O口,P1口缓冲器能接收和输出4个TTL门电流; P2口(2128):P2口为内部上拉电阻器的8位双向I/O口,P2口缓冲器可接收和输出4个TTL门电流; P3口(1017):P3口是8个带内部上拉电阻器的双向I/O口,可接收和输出4个TTL门电流,P3口也可作为AT89C51的特殊功能口; RST(9):复位输入。当振荡器复位时,要保持RST引脚2个机器周期的高电平时间; ALE/PROG(30):当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的低位字节,在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6,它可用作对外部输出的脉冲或用于定时目的,要注意的是,每当访问外部数据存储器时,将跳过1个ALE脉冲; PSEN(29):外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机器周期2次PSEN有效,但在访问外部数据存储器时,这2次有效的PSEN信号将不出现; EA/VPP(31):当EA保持低电平时,外部程序存储器地址为(0000HFFFFH)不管是否有内部程序存储器。FLASH编程期间,此引脚也用于施加12V编程电源(VPP); XTAL1(19):反向振荡器放大器的输入及内部时钟工作电路的输入; XTAL2(18):来自反向振荡器的输出;3.2 LM386 LM386是一种音频集成功放,具有自身功耗低、电压增益可调整、电源电压范围大、外接元件少和总谐波失真小等优点,广泛应用于录音机和收音机之中。3.2.1 LM386内部电路及特性 图3-2 LM386内部电路原理图 LM386内部电路原理图如图3-2所示。与通用型集成运放相类似,它是一个三级放大电路。 第一级为差分放大电路,T1和T3、T2和T4分别构成复合管,作为差分放大电路的放大管;T5和T6组成镜像电流源作为T1和T2的有源负载;T3和T4信号从管的基极输入,从T2管的集电极输出,为双端输入单端输出差分电路。使用镜像电流源作为差分放大电路有源负载,可使单端输出电路的增益近似等于双端输出电容的增益。 第二级为共射放大电路,T7为放大管,恒流源作有源负载,以增大放大倍数。 第三级中的T8和T9管复合成PNP型管,与NPN型管T10构成准互补输出级。二极管D1和D2为输出级提供合适的偏置电压,可以消除交越失真。 引脚2为反相输入端,引脚3为同相输入端。电路由单电源供电,故为OTL电路。输出端(引脚5)应外接输出电容后再接负载。 电阻R7从输出端连接到T2的发射极,形成反馈通路,并与R5和R6构成反馈网络,从而引入了深度电压串联负反馈,使整个电路具有稳定的电压增益。3.2.2 LM386的引脚图 图3-3 LM386的外形和引脚的排列 LM386的外形和引脚的排列如图3-3所示。引脚2为反相输入端,3为同相输入端;引脚5为输出端;引脚6和4分别为电源和地;引脚1和8为电压增益设定端;使用时在引脚7和地之间接旁路电容,通常取10F。 查LM386的电源电压4-12V或5-18V(LM386N-4);静态消耗电流为4mA;电压增益为20-200dB;在1、8脚开路时,带宽为300KHz;输入阻抗为50K;音频功率0.5W。 尽管LM386的应用非常简单,但稍不注意,特别是器件上电、断电瞬间,甚至工作稳定后,一些操作(如插拔音频插头、旋音量调节钮)都会带来的瞬态冲击,在输出喇叭上会产生非常讨厌的噪声。要注意以下几点: 1、通过接在1脚、8脚间的电容(1脚接电容+极)来改变增益,断开时增益为20dB。因此用不到大的增益,电容就不要接了,不光省了成本,还会带来好处-噪音减少,何乐而不为? 2、PCB设计时,所有外围元件尽可能靠近LM386;地线尽可能粗一些;输入音频信号通路尽可能平行走线,输出亦如此。这是死理,不用多说了吧。 3、选好调节音量的电位器。质量太差的不要,否则受害的是耳朵;阻值不要太大,10K最合适,太大也会影响音质。 4、尽可能采用双音频输入/输出。好处是:“”、“”输出端可以很好地抵消共模信号,故能有效抑制共模噪声。 5、第7脚(BYPASS)的旁路电容不可少!实际应用时,BYPASS端必须外接一个电解电容到地,起滤除噪声的作用。工作稳定后,该管脚电压值约等于电源电压的一半。增大这个电容的容值,减缓直流基准电压的上升、下降速度,有效抑制噪声。在器件上电、掉电时的噪声就是由该偏置电压的瞬间跳变所致,这个电容可千万别省啊! 6、减少输出耦合电容。此电容的作用有二:隔直 + 耦合。隔断直流电压,直流电压过大有可能会损坏喇叭线圈;耦合音频的交流信号。它与扬声器负载构成了一阶高通滤波器。减小该电容值,可使噪声能量冲击的幅度变小、宽度变窄;太低还会使截止频率(fc1/(2*RL*Cout))提高。分别测试,发现10uF/4.7uF最为合适,这是我的经验值。 7、电源的处理,也很关键。如果系统中有多组电源,由于电压不同、负载不同以及并联的去耦电容不同,每组电源的上升、下降时间必有差异。非常可行的方法:将上电、掉电时间短的电源放到+12V处,选择上升相对较慢的电源作为LM386的Vs,但不要低于4V,效果确实不错!4 模块原理4.1 4X4行列式键盘识别 组成键盘的按键有机械式、电容式、导电橡胶式、薄膜式多种,但不管什么形式,其作用都是一个使电路接通与断开的开关。目前微机系统中使用的键盘按其功能不同,通常可分为编码键盘和非编码键盘两种基本类型。 编码键盘:键盘本身带有实现接口主要功能所需的硬件电路。不仅能自动检测被按下的键,并完成去抖动、防串键等功能,而且能提供与被按键功能对应的键码(如ASCII码)送往CPU。所以,编码键盘接口简单、使用方便。但由于硬件电路较复杂,因而价格较贵。 非编码键盘:键盘只简单地提供按键开关的行列矩阵。有关按键的识别、键码的确定与输入、去抖动等功能均由软件完成。目前微机系统中,一般为了降低成本大多数采用非编码键盘。 键盘接口必须具有去抖动、防串键、按键识别和键码产生4个基本功能。 (1)去抖动:每个按键在按下或松开时,都会产生短时间的抖动。抖动的持续时间与键的质量相关,一般为520mm。所谓抖动是指在识别被按键是必须避开抖动状态,只有处在稳定接通或稳定断开状态才能保证识别正确无误。去抖问题可通过软件延时或硬件电路解决。 (2)防串键:防串键是为了解决多个键同时按下或者前一按键没有释放又有新的按键按下时产生的问题。常用的方法有双键锁定和N键轮回两种方法。双键锁定,是当有两个或两个以上的按键按下时,只把最后释放的键当作有效键并产生相应的键码。N键轮回,是当检测到有多个键被按下时,能根据发现它们的顺序依次产生相应键的键码。 (3)被按键识别:如何识别被按键是接口解决的主要问题,一般可通过软硬结合的方法完成。常用的方法有行扫描法和线反转法两种。行扫描法的基本思想是,由程序对键盘逐行扫描,通过检测到的列输出状态来确定闭合键,为此,需要设置入口、输出口一个,该方法在微机系统中被广泛使用。线反转法的基本思想是通过行列颠倒两次扫描来识别闭合键,为此需要提供两个可编程的双向输入/输出端口。 (4)键码产生:为了从键的行列坐标编码得到反映键功能的键码,一般在内存区中建立一个键盘编码表,通过查表获得被按键的键码。 用AT89S51的并行口P1接4×4矩阵键盘,以P1.0P1.3作输入线,以P1.4P1.7作输出线; 图4-1 键盘识别模块4.1.1 系统板上硬件连线设计 键盘模块硬件连线如图4-1所示:(1把“单片机系统“区域中的P3.0P3.7端口用8芯排线连接到“4X4行列式键盘”区域中的C1C4R1R4端口上;4.1.2 程序设计要求 (1 4×4矩阵键盘识别处理。 (2每个按键有它的行值和列值,行值和列值的组合就是识别这个按键的编码。矩阵的行线和列线分别通过两并行接口和CPU通信。每个按键的状态同样需变成数字量“0”和“1”,开关的一端(列线)通过电阻接VCC,而接地是通过程序输出数字“0”实现的。键盘处理程序的任务是:确定有无键按下,判断哪一个键按下,键的功能是什么;还要消除按键在闭合或断开时的抖动。两个并行口中,一个输出扫描码,使按键逐行动态接地,另一个并行口输入按键状态,由行扫描值和回馈信号共同形成键编码而识别按键,通过软件查表,查出该键的功能。4.1.3 键盘识别程序框图 键盘识别程序框图如图4-2所示:图4-2 键盘识别程序框图4.2 触摸式模块的实现原理及分析图4-3触摸式开关电路从图4-3中,开始通电时,由于继电器不吸合,电器电源回路未接通而不工作。当用手指接触金属片A时,人体感应信号加至BG3基极,令其导通R1获得压降,使BG2正偏导通,继而BG1导通,LED点亮,同时继电器J得电流动作其常开触点吸合,接通电器电源回路,电器开始工作。此时,手指离开金属触片A,继电器常开触点Jk仍可靠地吸合。当需要关闭用电器时用户只要触摸金属片B,使BG4导通,此时相当于BG1基极对地短路因此BG1、BG2同时截止,继电器失去电流触点Jk释放,从而切断电器供电电源。所需元件按照电路图中的标注选择,继电器可根据用电器的功率选择触点电流合适的即可。4.3.1单片机产生音乐原理 乐音实际上是有固定周期的信号。我们可以用AT89s51的一个定时器(如T1)控制,在P34脚上输出方波周期信号,产生乐音。根据不同的按键,调节T1的溢出时间,可输出不同频率的乐音,每个乐音的音高(频率)是固定的,表1列出了一个8度以及其上下共16个音的音名、频率及定时器T1初值对照(设晶体频率为6MHz),供参考4-4 图4-4音名,频率,及T1初值对照表4.3.2音乐产生程序原理图图4-5音乐产生原理程序图5 PCB电路板图6 汇编程序KEYBUF EQU 30H ;KEYBUF 定义为,30HSTH0 EQU 31H ;STH0 定义为,31HSTL0 EQU 32H ;STL0 定义为,32HTEMP EQU 33H ;TEMP 定义为,33HORG 00H ;定义当前位置为 00HLJMP START ;长转移到 STARTORG 0BH ;定义当前位置为 0BHLJMP INT_T0 ;长转移到 INT_T0START:MOV TMOD,#01H ;传送 TMOD,立即数01HSETB ET0 ;位-置1 ET0SETB EA ;位-置1 EAWAIT: ; MOV P3,#0FFH ;传送 接口3,立即数0FFHCLR P3.4 ;清0 接口3第4位MOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHXRL A,#0FH ;逻辑-异或 寄存器A,立即数0FHJZ NOKEY1 ;寄存器为0转移 NOKEY1LCALL DELY10MS ;长调用 DELY10MSMOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHXRL A,#0FH ;逻辑-异或 寄存器A,立即数0FHJZ NOKEY1 ;寄存器为0转移 NOKEY1LCALL DELY10MS ;长调用 DELY10MSMOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHCJNE A,#0EH,NK1 ;比较-不等转移 寄存器A,立即数0EH,MOV KEYBUF,#0 ;传送 KEYBUF,立即数LJMP DK1 ;长转移到 DK1NK1:CJNE A,#0DH,NK2 ;比较-不等转移 寄存器A,立即数0DH,MOV KEYBUF,#1 ;传送 KEYBUF,立即数1LJMP DK1 ;长转移到 DK1NK2:CJNE A,#0BH,NK3 ;比较-不等转移 寄存器A,立即数0BH,MOV KEYBUF ,#2 ;传送 KEYBUF ,立即数2LJMP DK1 ;长转移到 DK1NK3:CJNE A,#07H,NK4 ;比较-不等转移 寄存器A,立即数07H,MOV KEYBUF ,#3 ;传送 KEYBUF ,立即数3LJMP DK1 ;长转移到 DK1NK4:NOP ;空操作 DK1: ; MOV A ,KEYBUF ;传送 A ,KEYBUFMOV DPTR,#TABLE ;传送 DPTR,立即数TABLEMOVC A,A+DPTR ;程序存储器-读 寄存器A,A+DPTR指向的单元的内容MOV P0,A ;传送 接口0,寄存器AMOV A,KEYBUF ;传送 寄存器A,KEYBUFMOV B,#2 ;传送 B,立即数2MUL AB ;两数相乘 ABMOV TEMP,A ;传送 TEMP,寄存器AMOV DPTR,#TABLE1 ;传送 DPTR,立即数TABLE1MOVC A,A+DPTR ;程序存储器-读 寄存器A,A+DPTR指向的单元的内容MOV STH0,A ;传送 STH0,寄存器AMOV TH0,A ;传送 TH0,寄存器AINC TEMP ;加1 TEMPMOV A,TEMP ;传送 寄存器A,TEMPMOVC A,A+DPTR ;程序存储器-读 寄存器A,A+DPTR指向的单元的内容MOV STL0,A ;传送 STL0,寄存器AMOV TL0,A ;传送 TL0,寄存器ASETB TR0 ;位-置1 TR0DK1A:MOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHXRL A,#0FH ;逻辑-异或 寄存器A,立即数0FHJNZ DK1A ;寄存器不为0转移 DK1ACLR TR0 ;清0 TR0NOKEY1: ; MOV P3,#0FFH ;传送 接口3,立即数0FFHCLR P3.5 ;清0 接口3第5位MOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHXRL A,#0FH ;逻辑-异或 寄存器A,立即数0FHJZ NOKEY2 ;寄存器为0转移 NOKEY2LCALL DELY10MS ;长调用 DELY10MSMOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHJZ NOKEY2 ;寄存器为0转移 NOKEY2MOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHCJNE A,#0EH,Nk5 ;比较-不等转移 寄存器A,立即数0EH,MOV KEYBUF,#4 ;传送 KEYBUF,立即数4LJMP DK2 ;长转移到 DK2NK5:CJNE A,#0DH,NK6 ;比较-不等转移 寄存器A,立即数0DH,MOV KEYBUF,#5 ;传送 KEYBUF,立即数5LJMP DK2 ;长转移到 DK2NK6:CJNE A,#0BH,NK7 ;比较-不等转移 寄存器A,立即数0BH,MOV KEYBUF,#6 ;传送 KEYBUF,立即数6LJMP DK2 ;长转移到 DK2NK7:CJNE A,#07H,NK8 ;比较-不等转移 寄存器A,立即数07H,MOV KEYBUF,#7 ;传送 KEYBUF,立即数7LJMP DK2 ;长转移到 DK2NK8:NOP ;空操作 DK2: ; MOV A,KEYBUF ;传送 寄存器A,KEYBUFMOV DPTR,#TABLE ;传送 DPTR,立即数TABLEMOVC A,A+DPTR ;程序存储器-读 寄存器A,A+DPTR指向的单元的内容MOV P0,A ;传送 接口0,寄存器AMOV A,KEYBUF ;传送 寄存器A,KEYBUFMOV B,#2 ;传送 B,立即数2MUL AB ;两数相乘 ABMOV TEMP,A ;传送 TEMP,寄存器AMOV DPTR,#TABLE1 ;传送 DPTR,立即数TABLE1MOVC A,A+DPTR ;程序存储器-读 寄存器A,A+DPTR指向的单元的内容MOV STH0,A ;传送 STH0,寄存器AMOV TL0,A ;传送 TL0,寄存器ASETB TR0 ;位-置1 TR0DK2A:MOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHXRL A,#0FH ;逻辑-异或 寄存器A,立即数0FHJNZ DK2A ;寄存器不为0转移 DK2ACLR TR0 ;清0 TR0NOKEY2: ; MOV P3,#0FFH ;传送 接口3,立即数0FFHCLR P3.6 ;清0 接口3第6位MOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHXRL A,#0FH ;逻辑-异或 寄存器A,立即数0FHJZ NOKEY3 ;寄存器为0转移 NOKEY3LCALL DELY10MS ;长调用 DELY10MSMOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHXRL A,#0FH ;逻辑-异或 寄存器A,立即数0FHJZ NOKEY3 ;寄存器为0转移 NOKEY3MOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHCJNE A,#0EH,NK9 ;比较-不等转移 寄存器A,立即数0EH,MOV KEYBUF,#8 ;传送 KEYBUF,立即数8LJMP DK3 ;长转移到 DK3NK9:CJNE A,#0DH,NK10 ;比较-不等转移 寄存器A,立即数0DH,MOV KEYBUF,#9 ;传送 KEYBUF,立即数9LJMP DK3 ;长转移到 DK3NK10:CJNE A,#0BH,NK11 ;比较-不等转移 寄存器A,立即数0BH,MOV KEYBUF,#10 ;传送 KEYBUF,立即数10LJMP DK3 ;长转移到 DK3NK11:NOP ;空操作 DK3: ; MOV A,KEYBUF ;传送 寄存器A,KEYBUFMOV DPTR,#TABLE ;传送 DPTR,立即数TABLEMOVC A,A+DPTR ;程序存储器-读 寄存器A,A+DPTR指向的单元的内容MOV P0,A ;传送 接口0,寄存器AMUL AB ;两数相乘 ABMOV TEMP,A ;传送 TEMP,寄存器AMOV DPTR,#TABLE1 ;传送 DPTR,立即数TABLE1MOVC A,A+DPTR ;程序存储器-读 寄存器A,A+DPTR指向的单元的内容MOV STH0,A ;传送 STH0,寄存器AMOV TH0,A ;传送 TH0,寄存器ASETB TR0 ;位-置1 TR0DK3A:MOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHXRL A,#0FH ;逻辑-异或 寄存器A,立即数0FHJNZ DK3A ;寄存器不为0转移 DK3ACLR TR0 ;清0 TR0NOKEY3: ; MOV P3,#0FFH ;传送 接口3,立即数0FFHCLR P3.7 ;清0 接口3第7位MOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHXRL A,#0FH ;逻辑-异或 寄存器A,立即数0FHJZ NOKEY4 ;寄存器为0转移 NOKEY4LCALL DELY10MS ;长调用 DELY10MSMOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHXRL A,#0FH ;逻辑-异或 寄存器A,立即数0FHJZ NOKEY4 ;寄存器为0转移 NOKEY4MOV A,P3 ;传送 寄存器A,接口3ANL A,#0FH ;逻辑-与 寄存器A,立即数0FHCJNE A,#0EH,NK13 ;比较-不等转移 寄存器A,立即数0EH,MOV KEYBUF,#12 ;传送 KEYBUF,立即数12LJMP DK4 ;长转移到 DK4NK13:CJNE A,#0DH,NK14 ;比较-不等转移 寄存器A,立即数0DH,MOV KEYBUF,#13 ;传送 KEYBUF,立即数13LJMP DK4 ;长转移到 DK4,NK14:CJNE A,#0BH,NK15 ;比较-不等转移 寄存器A,立即数0BH,MOV KE