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

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验六键盘接口实验

姓名专业通信工程学号成绩

一、实验目的

1.掌握Keil C51软件与Protues软件联合仿真调试的方法;

2.掌握单片机的键盘接口电路;

3.掌握单片机键盘扫描原理;

4.掌握键盘的去抖原理及处理方法。

二、实验仪器与设备

1.微机1台

2.Keil C51集成开发环境 3。Proteus仿真软件

三、实验内容

1.用Proteus设计一矩阵键盘接口电路。要求利用P1口接一4*4矩阵键盘。

串行口通过一74LS164接一共阴极数码管。参考电路见后面。

2.用线反转法编写矩阵键盘识别程序,要求采用中断方式(列线通过4输

入与门74LS20接/INT0),无按键按下时,数码管循环画“8”;有按键

按下时产生中断并将按键的键值0~F通过串行口输出,在数码管上显示

3秒钟后返回;返回后,数码管继续循环画“8”。

3.将P1口矩阵键盘改为8个独立按键(用中断方式设计),键盘通过74LS30

(8输入与非门)和74LS04(六反相器)与/INT0相连,重新编写识别

和显示程序。

四、实验原理

矩阵键盘识别一般应包括以下内容:

1)判别有无键按下。

2)键盘扫描取得闭合键的行、列号。

3)用计算法火或查表法得到键值。

4)判断闭合键是否释放,如果没释放则继续等待。

5)将闭合键的键值保存,同时转去执行该闭合键的功能。

五、实验步骤

1.用Proteus设计键盘接口电路;

2.在Keil C51中编写键盘识别程序,编译通过后,与Proteus联合调试;

3.按动任意键,观察键值是否能正确显示。

六、电路设计及调试、程序

1)程序设计:矩阵键盘

#include

#define uchar unsigned char

#define uint unsigned int

uchar code

table1[]={0x00,0x01,0x21,0x61,0x65,0x6d,0x7d,0x7f};

uchar code

key_table[]={0xee,0xde,0xbe,0x7e,0xed,0xdd,0xbd,0x7d,0xeb,0xd

b,0xbb,0x7b,0xe7,0xd7,0xb7,0x77};//键盘表

uchar code

table2[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0

x77,0x7c,0x39,0x5e,0x79,0x71};

void delay(uint c) {

uint a,b;

for(;c>0;c--)

for(b=142;b>0;b--)

for(a=2;a>0;a--);

}

void display(void)

{

uchar i;

TI=0;

while(1)

{

for(i=0;i<8;i++)

{

SBUF=table1[i];

delay(200);while(TI==0);T I=0;

}

}

}

void INT_0() interrupt 0

{

uchar

j,temp,num,key;

EX0=0;

delay(20);

P1=0xf0;

if(P1!=0xf0)

{

delay(20);

if(P1!=0xf0)

{

temp=P1;

P1=0x0f;

key=temp|P1;

for(j=0;j<16;j++) if(key==key_table[j]) {

num=j;break;

}

SBUF=table2[num];while(TI ==0);TI=0;

delay(1000); return;

}

}

EX0=1;

P1=0xf0;

}

void main( )

{

EA=1;

EX0=1;

IT0=0;

SCON=0x00;

P1=0xf0;

display();

}

独立键盘

#include

#define uchar unsigned char

#define uint unsigned int

uchar code

table1[]={0x00,0x01,0x21, 0x61,0x65,0x6d,0x7d,0x7f} ;//单管依次点亮画"8"

uchar code

table2[]={0x3F,0x06,0x5B, 0x4F,0x66,0x6D,0x7D,0x07} ;//共阴极"0"~"F"编码表

uchar i;

void delay(uint c)

{

uint a,b;

for(;c>0;c--)

for(b=142;b>0;b--)

for(a=2;a>0;a--);

}

void main()

{

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);

}

void INT_0() interrupt 0

{

EX0=0;

delay(20);

EX0=1;

if(P1!=0xff)

{

switch(P1)

{

case

0xfe:SBUF=table2[0];

while(!TI);

TI=0;delay(1000);break;

case

0xfd:SBUF=table2[1];

while(!TI);

TI=0;delay(1000);break;

case

0xfb:SBUF=table2[2];

while(!TI);

TI=0;delay(1000);break;

case

0xf7:SBUF=table2[3];

while(!TI);

TI=0;delay(1000);break;

case

0xef:SBUF=table2[4];

while(!TI);

TI=0;delay(1000);break;

case

0xdf:SBUF=table2[5];

while(!TI);

TI=0;delay(1000);break;

case

0xbf:SBUF=table2[6];

while(!TI);

TI=0;delay(1000);break;

相关文档
最新文档