微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > MCU和单片机设计讨论 > 按键扫描程序

按键扫描程序

时间:10-02 整理:3721RD 点击:
#include <reg52.h>
#define uint unsigned int
#define uchar unsigned char
sbit wela=P2^7;
sbit dula=P2^6;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71,0};
uchar num,temp,shu;
void delay(uint);
uchar keyscon();
void display(uchar);
void main()
{
num=17;
wela=1;
P0=0x7f;
wela=0;
while(1)
{
  display(keyscon());
}
}
void delay(uint z)
{
uint x,y;
for(x=z;x>0;x--)
  for(y=113;y>0;y--);
}
uchar keyscon()
{
P3=0xfe;
temp=P3;
temp=temp&0xf0;
while(temp!=0xf0)
{
  delay(5);
  temp=P3;
  temp=temp&0xf0;
  while(temp!=0xf0)
  {
   temp=P3;
   switch(temp)
   {
    case 0xee:num=1;
     break;
    case 0xde:num=2;
     break;
    case 0xbe:num=3;
     break;
    case 0x7e:num=4;
     break;
   }
   while(temp!=0xf0)
   {
    temp=P3;
    temp=temp&0xf0;
   }
  }
}
P3=0xfd;
temp=P3;
temp=temp&0xf0;
while(temp!=0xf0)
{
  delay(5);
  temp=P3;
  temp=temp&0xf0;
  while(temp!=0xf0)
  {
   temp=P3;
   switch(temp)
   {
    case 0xed:num=5;
     break;
    case 0xdd:num=6;
     break;
    case 0xbd:num=7;
     break;
    case 0x7d:num=8;
     break;
   }
   while(temp!=0xf0)
   {
    temp=P3;
    temp=temp&0xf0;
   }
  }
}
P3=0xfb;
temp=P3;
temp=temp&0xf0;
while(temp!=0xf0)
{
  delay(5);
  temp=P3;
  temp=temp&0xf0;
  while(temp!=0xf0)
  {
   temp=P3;
   switch(temp)
   {
    case 0xeb:num=9;
     break;
    case 0xdb:num=10;
     break;
    case 0xbb:num=11;
     break;
    case 0x7b:num=12;
     break;
   }
   while(temp!=0xf0)
   {
    temp=P3;
    temp=temp&0xf0;
   }
  }
}
P3=0xf7;
temp=P3;
temp=temp&0xf0;
while(temp!=0xf0)
{
  delay(5);
  temp=P3;
  temp=temp&0xf0;
  while(temp!=0xf0)
  {
   temp=P3;
   switch(temp)
   {
    case 0xe7:num=13;
     break;
    case 0xd7:num=14;
     break;
    case 0xb7:num=15;
     break;
    case 0x77:num=16;
     break;
   }
   while(temp!=0xf0)
   {
    temp=P3;
    temp=temp&0xf0;
   }
  }
}
return num;
}
void display(uchar shu)
{
dula=1;
P0=table[shu-1];
dula=0;
}

学习下 谢谢

weafrthkjwhjkert

对初学者的我是在看天书。希望有一天能读懂。

奥帆基地蓝看,

有问题

非常感谢,新手学习

初学者,有些看不懂。

小编很慷慨                             

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top