键盘接口实验实验报告及程序.doc

键盘接口实验实验报告及程序.doc

ID:54763009

大小:72.17 KB

页数:5页

时间:2020-04-21

键盘接口实验实验报告及程序.doc_第1页
键盘接口实验实验报告及程序.doc_第2页
键盘接口实验实验报告及程序.doc_第3页
键盘接口实验实验报告及程序.doc_第4页
键盘接口实验实验报告及程序.doc_第5页
资源描述:

《键盘接口实验实验报告及程序.doc》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、实验六键盘接口实验姓名专业通信工程学号成绩一、实验目的1.掌握KeilC51软件与Protues软件联合仿真调试的方法;2.掌握单片机的键盘接口电路;3.掌握单片机键盘扫描原理;4.掌握键盘的去抖原理及处理方法。二、实验仪器与设备1.微机1台2.KeilC51集成开发环境3。Proteus仿真软件三、实验内容1.用Proteus设计一矩阵键盘接口电路。要求利用P1口接一4*4矩阵键盘。串行口通过一74LS164接一共阴极数码管。参考电路见后面。2.用线反转法编写矩阵键盘识别程序,要求采用中断方式(列线通过4输入与门74LS20接/INT0),无

2、按键按下时,数码管循环画“8”;有按键按下时产生中断并将按键的键值0~F通过串行口输出,在数码管上显示3秒钟后返回;返回后,数码管继续循环画“8”。3.将P1口矩阵键盘改为8个独立按键(用中断方式设计),键盘通过74LS30(8输入与非门)和74LS04(六反相器)与/INT0相连,重新编写识别和显示程序。四、实验原理矩阵键盘识别一般应包括以下内容:1)判别有无键按下。2)键盘扫描取得闭合键的行、列号。3)用计算法火或查表法得到键值。4)判断闭合键是否释放,如果没释放则继续等待。5)将闭合键的键值保存,同时转去执行该闭合键的功能。五、实验步骤1

3、.用Proteus设计键盘接口电路;2.在KeilC51中编写键盘识别程序,编译通过后,与Proteus联合调试;3.按动任意键,观察键值是否能正确显示。六、电路设计及调试、程序1)程序设计:矩阵键盘#include#defineucharunsignedchar#defineuintunsignedintucharcodetable1[]={0x00,0x01,0x21,0x61,0x65,0x6d,0x7d,0x7f};ucharcodekey_table[]={0xee,0xde,0xbe,0x7e,0xed,0xdd,

4、0xbd,0x7d,0xeb,0xdb,0xbb,0x7b,0xe7,0xd7,0xb7,0x77};//键盘表ucharcodetable2[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x77,0x7c,0x39,0x5e,0x79,0x71};voiddelay(uintc){uinta,b;for(;c>0;c--)for(b=142;b>0;b--)for(a=2;a>0;a--);}voiddisplay(void){uchari;TI=0;while(1){for(i=

5、0;i<8;i++){SBUF=table1[i];delay(200);while(TI==0);TI=0;}}}voidINT_0()interrupt0{ucharj,temp,num,key;EX0=0;delay(20);P1=0xf0;if(P1!=0xf0){delay(20);if(P1!=0xf0){temp=P1;P1=0x0f;key=temp

6、P1;for(j=0;j<16;j++)if(key==key_table[j]){num=j;break;}SBUF=table2[num];while(TI==0);TI=0;

7、delay(1000);return;}}EX0=1;P1=0xf0;}voidmain(){EA=1;EX0=1;IT0=0;SCON=0x00;P1=0xf0;display();}独立键盘#include#defineucharunsignedchar#defineuintunsignedintucharcodetable1[]={0x00,0x01,0x21,0x61,0x65,0x6d,0x7d,0x7f};//单管依次点亮画"8"ucharcodetable2[]={0x3F,0x06,0x5B,0x4F,0x66

8、,0x6D,0x7D,0x07};//共阴极"0"~"F"编码表uchari;voiddelay(uintc){uinta,b;for(;c>0;c--)for(b=142;b>0;b--)for(a=2;a>0;a--);}voidmain(){EA=1;EX0=1;IT1=1;SCON=0X00;TI=0;while(1){for(i=0;i<8;i++){SBUF=table1[i];delay(200);}}while(1);}voidINT_0()interrupt0{EX0=0;delay(20);EX0=1;if(P1!=0xff

9、){switch(P1){case0xfe:SBUF=table2[0];while(!TI);TI=0;delay(1000);break;case

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。