PIC16F877矩阵键盘的识别

本文介绍使用PIC单片机进行矩阵键盘扫描的方法,包括扫描法和线反转法的具体实现,展示了如何通过TRIS寄存器配置输入输出,以及如何读取按键状态并进行按键值映射。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文地址:http://blog.sina.com.cn/s/blog_4a3946360100mwqh.html

关于矩阵键盘的识别方法在51矩阵键盘识别中已经说过,现在要说的是PIC单片机与51单片机的区别,主要是PIC单片机的口子的输入输出需要TRISn寄存器设置,具体如下:

PIC16F877矩阵键盘的识别

 

扫描法:

#include<pic.h>
#define uchar unsigned char
#define uint unsigned int
uchar num;
const ucharSSEG[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};

void delay1ms(uint z)
{
 uint x;
 uchar y;
 for(x=z;x>0;x--)
  for(y=110;y>0;y--);
}

void keyscan()
{
 uchar temp;
 TRISB=0x0f;
 PORTB=0x7f;
 temp=PORTB&0x0f;
 if(temp!=0x0f)
 {
  delay1ms(10);
  temp=PORTB&0x0f;
  if(temp!=0x0f)
  {
   num=temp|0x70; 
  }
  temp=PORTB&0x0f;
  while(temp!=0x0f)
  {
   temp=PORTB&0x0f;  
  }
  switch(num)
  {
   case 0x7e:num =12;break;
    case0x7d: num =13;break;
   case 0x7b:num =14;break;
   case 0x77:num =15;break;
  }
 }
 PORTB=0xbf;
 temp=PORTB&0x0f;
 if(temp!=0x0f)
 {
  delay1ms(10);
  temp=PORTB&0x0f;
  if(temp!=0x0f)
  {
   num=temp|0xb0; 
  }
  temp=PORTB&0x0f;
  while(temp!=0x0f)
  {
   temp=PORTB&0x0f;  
  }
  switch(num)
  {
   case 0xbe:num =8;break;
    case0xbd: num =9;break;
   case 0xbb:num =10;break;
   case 0xb7:num =11;break;
  }
 }
 PORTB=0xdf;
 temp=PORTB&0x0f;
 if(temp!=0x0f)
 {
  delay1ms(10);
  temp=PORTB&0x0f;
  if(temp!=0x0f)
  {
   num=temp|0xd0; 
  }
  temp=PORTB&0x0f;
  while(temp!=0x0f)
  {
   temp=PORTB&0x0f;  
  }
  switch(num)
  {
   case 0xde:num =4;break;
    case0xdd: num =5;break;
   case 0xdb:num =6;break;
   case 0xd7:num =7;break;
  }
 }
 PORTB=0xef;
 temp=PORTB&0x0f;
 if(temp!=0x0f)
 {
  delay1ms(10);
  temp=PORTB&0x0f;
  if(temp!=0x0f)
  {
   num=temp|0xe0; 
  }
  temp=PORTB&0x0f;
  while(temp!=0x0f)
  {
   temp=PORTB&0x0f;  
  }
  switch(num)
  {
   case 0xee:num =0;break;
    case0xed: num =1;break;
   case 0xeb:num =2;break;
   case 0xe7:num =3;break;
  }
 }      
}

void main()
{
 num=0xff;
 TRISD=0;
 PORTD=0;
 while(1)
 {
  keyscan();
  PORTD=~SSEG[num];
 }
}

 

线反转法:

#include<pic.h>
#define uchar unsigned char
#define uint unsigned int
uchar num;
const ucharSSEG[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};

void delay1ms(uint z)
{
 uint x;
 uchar y;
 for(x=z;x>0;x--)
  for(y=110;y>0;y--);
}

void keyscan()
{
 uchar temp,z,x;
 TRISB=0x0f;
 PORTB=0x0f;
 x=PORTB&0x0f;
 if(x!=0x0f)
 {
  delay1ms(10);
  x=PORTB&0x0f;
  if(x!=0x0f)
  {
   temp=PORTB&0x0f;
   TRISB=0xf0;
   PORTB=0xf0;  
   z=temp|PORTB;
   x=PORTB&0xf0;
   while(x!=0xf0)//松手检测
   {
    x=PORTB&0xf0;  
   }
   switch(z)
   {
    case0xee: num =0; break;
         case 0xde: num =4; break;
         case 0xbe: num =8; break;
         case 0x7e: num =12; break;
         case 0xed: num =1; break;
         case 0xdd: num =5; break;
         case 0xbd: num =9; break;
         case 0x7d: num =13; break;
         case 0xeb: num =2; break;
         case 0xdb: num =6;break;    
         case 0xbb: num =10;break;
         case 0x7b: num =14;break;
         case 0xe7: num =3;break;
         case 0xd7: num =7;break;
         case 0xb7: num =11;break;
         case 0x77: num =15;break;
   }
  }
 }
}

void main()
{

 

num=0xff;
 TRISD=0;
 PORTD=0;
 while(1)
 {
  keyscan();
  PORTD=~SSEG[num];
 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值