久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1431|回復: 3
打印 上一主題 下一主題
收起左側

關于單片機陣列按鈕的檢測問題

[復制鏈接]
跳轉到指定樓層
樓主
ID:598105 發表于 2019-8-9 01:28 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
看到郭天祥新概念51單片機C語言教程的按鈕陣列時,我完全被弄暈了,先上代碼

我寫的是用鍵盤陣列去改變P3管腳的電平,通過電平的改變去改變P2管腳從而驅動LED小燈,功能都實現了,但是我現在唯一搞不懂的地方就是檢測矩陣鍵盤的地方
  1. 比如說我現在已經按下了矩陣鍵盤第2行的第2列,那么這個時候P3管腳的電平應該是11011101也就是0xDD
復制代碼

哪位大神幫小弟解決一下這個問題啊,這個問題已經困擾我兩天了


  1. #include <reg52.h>

  2. #define uchar unsigned char
  3. #define uint  unsigned int
  4.         
  5. uchar key;


  6. void delayms(uint xms) {
  7.         uint i, j;
  8.         for(i = xms; i > 0; i--)
  9.                 for(j = 110; j > 0; j--);
  10. }

  11. void matrixKeyScan() {
  12.         
  13.         uchar _temp;
  14.         
  15.         //檢測第一行
  16.         P3    = 0xFE;
  17.         _temp = P3;
  18.         _temp = _temp & 0xF0;
  19.         if(_temp != 0xF0){
  20.                 delayms(10);
  21.                 _temp = P3;
  22.                 _temp = _temp & 0xF0;
  23.                 if(_temp != 0xF0){
  24.                         _temp = P3;
  25.                         switch(_temp) {
  26.                                 case 0xEE:
  27.                                         key = 0;
  28.                                         break;
  29.                                 case 0xDE:
  30.                                         key = 1;
  31.                                         break;
  32.                                 case 0xBE:
  33.                                         key = 2;
  34.                                         break;
  35.                                 case 0x7E:
  36.                                         key = 3;
  37.                                         break;
  38.                         }
  39.                         while(_temp != 0xF0){
  40.                                 _temp = P3;
  41.                                 _temp = _temp & 0xF0;
  42.                         }
  43.                 }
  44.         }
  45.         
  46.         //檢測第二行
  47.         P3 = 0xFD;
  48.         _temp = P3;
  49.         _temp = _temp & 0xF0;
  50.         if(_temp != 0xF0){
  51.                 delayms(10);
  52.                 _temp = P3;
  53.                 _temp = _temp & 0xF0;
  54.                 if(_temp != 0xF0){
  55.                         _temp = P3;
  56.                         switch(_temp) {
  57.                                 case 0xED:
  58.                                         key = 4;
  59.                                         break;
  60.                                 case 0xDD:
  61.                                         key = 5;
  62.                                         break;
  63.                                 case 0xBD:
  64.                                         key = 6;
  65.                                         break;
  66.                                 case 0x7D:
  67.                                         key = 7;
  68.                                         break;
  69.                         }
  70.                         while(_temp != 0xF0){
  71.                                 _temp = P3;
  72.                                 _temp = _temp & 0xF0;
  73.                         }
  74.                 }
  75.         }
  76.         
  77.         //檢測第三行
  78.         P3 = 0xFB;
  79.         _temp = P3;
  80.         _temp = _temp & 0xF0;
  81.         if(_temp != 0xF0){
  82.                 delayms(10);
  83.                 _temp = P3;
  84.                 _temp = _temp & 0xF0;
  85.                 if(_temp != 0xF0){
  86.                         _temp = P3;
  87.                         switch(_temp) {
  88.                                 case 0xEB:
  89.                                         key = 8;
  90.                                         break;
  91.                                 case 0xDB:
  92.                                         key = 9;
  93.                                         break;
  94.                                 case 0xBB:
  95.                                         key = 10;
  96.                                         break;
  97.                                 case 0x7B:
  98.                                         key = 11;
  99.                                         break;
  100.                         }
  101.                         while(_temp != 0xF0){
  102.                                 _temp = P3;
  103.                                 _temp = _temp & 0xF0;
  104.                         }
  105.                 }
  106.         }
  107.         
  108.         //檢測第四行
  109.         P3 = 0xF7;
  110.         _temp = P3;
  111.         _temp = _temp & 0xF0;
  112.         if(_temp != 0xF0){
  113.                 delayms(10);
  114.                 _temp = P3;
  115.                 _temp = _temp & 0xF0;
  116.                 if(_temp != 0xF0){
  117.                         _temp = P3;
  118.                         switch(_temp) {
  119.                                 case 0xE7:
  120.                                         key = 12;
  121.                                         break;
  122.                                 case 0xD7:
  123.                                         key = 13;
  124.                                         break;
  125.                                 case 0xB7:
  126.                                         key = 14;
  127.                                         break;
  128.                                 case 0x77:
  129.                                         key = 15;
  130.                                         break;
  131.                         }
  132.                         while(_temp != 0xF0){
  133.                                 _temp = P3;
  134.                                 _temp = _temp & 0xF0;
  135.                         }
  136.                 }
  137.         }
  138.         
  139. }


  140. void main() {
  141.         
  142.         key = 99;
  143.         
  144.         while(1) {
  145.                 matrixKeyScan();
  146.                
  147.                 switch(key) {
  148.                         case 0:
  149.                                 P2 = 0xFE;
  150.                                 break;
  151.                         case 1:
  152.                                 P2 = 0xFD;
  153.                                 break;
  154.                         case 2:
  155.                                 P2 = 0xFB;
  156.                                 break;
  157.                         case 3:
  158.                                 P2 = 0xF7;
  159.                                 break;
  160.                         case 4:
  161.                                 P2 = 0xEF;
  162.                                 break;
  163.                         case 5:
  164.                                 P2 = 0xDF;
  165.                                 break;
  166.                         case 6:
  167.                                 P2 = 0xBF;
  168.                                 break;
  169.                         case 7:
  170.                                 P2 = 0x7F;
  171.                 }
  172.         }

  173. }
復制代碼


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:164602 發表于 2019-8-9 08:29 | 只看該作者
給你一個例子程序吧,比你的程序好、實用。
/*
本實例為矩陣鍵盤的實驗
1、按不同的鍵,顯示所按的鍵的數字。其實主要是實驗出按的哪個鍵,程序判斷對不對
   完全可以通過按鍵執行其它任務
2、矩陣鍵盤得到所按哪個鍵的過程相對復雜一點,注意理解。
*/

#include<reg51.h>

#define GPIO_DIG P0//數碼管
#define GPIO_KEY P1//矩陣鍵盤

sbit LSA=P2^2;//數碼管位碼CBA分別為000第一位,001第二位,010第三位
sbit LSB=P2^3;//                   011第四位,100第五位,101第六位
sbit LSC=P2^4;//                                   110第七位,111第八位

unsigned char code DIG_CODE[17]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,
0x77,0x7c,0x39,0x5e,0x79,0x71};//0、1、2、3、4、5、6、7、8、9、A、b、C、d、E、F的顯示碼

unsigned char KeyValue;//用來存放讀取到的鍵值

bit KeyState;        //記錄按鍵的狀態,0沒有,1有

unsigned char DisplayData[8];//用來存放要顯示的8位數的值,一個管分配一個數組

void Delay10ms();   //延時10ms
void KeyDown();                 //檢測按鍵函數
void DigDisplay(); //動態顯示函數

void main(void)
{
        KeyState=0;//初始化按鍵
        while(1)
        {
                KeyDown();//檢測按鍵
                 if(KeyState==1)//有鍵按下才執行
                {
                        DisplayData[7]=DisplayData[6];//顯示的內容左移一位
                        DisplayData[6]=DisplayData[5];
                        DisplayData[5]=DisplayData[4];
                        DisplayData[4]=DisplayData[3];
                        DisplayData[3]=DisplayData[2];
                        DisplayData[2]=DisplayData[1];
                        DisplayData[1]=DisplayData[0];
                        DisplayData[0]=DIG_CODE[KeyValue];
                       
                        KeyState=0;//顯示完畢要初始化
                }
                DigDisplay();//顯示
        }                               
}
/*******************************************************************************
* 函 數 名         : DigDisplay
* 函數功能                   : 使用數碼管顯示
* 輸    入         : 無
* 輸    出         : 無
*******************************************************************************/
void DigDisplay()
{
        unsigned char i;
        unsigned int j;
        for(i=0;i<8;i++)//只有8個數碼管
        {
                switch(i)         //位選,選擇點亮的數碼管,
                {
                        case(0):
                                LSA=0;LSB=0;LSC=0; break;//顯示第0位
                        case(1):
                                LSA=1;LSB=0;LSC=0; break;//顯示第1位
                        case(2):
                                LSA=0;LSB=1;LSC=0; break;//顯示第2位
                        case(3):
                                LSA=1;LSB=1;LSC=0; break;//顯示第3位
                        case(4):
                                LSA=0;LSB=0;LSC=1; break;//顯示第4位
                        case(5):
                                LSA=1;LSB=0;LSC=1; break;//顯示第5位
                        case(6):
                                LSA=0;LSB=1;LSC=1; break;//顯示第6位
                        case(7):
                                LSA=1;LSB=1;LSC=1; break;//顯示第7位       
                }
                GPIO_DIG=DisplayData[i];//發送段碼
                j=10;                                                 //掃描間隔時間設定
                while(j--);       
                GPIO_DIG=0x00;//消隱
        }
}
/*******************************************************************************
* 函 數 名         : KeyDown
* 函數功能                   : 檢測有按鍵按下并讀取鍵值
* 輸    入         : 無
* 輸    出         : 無
*******************************************************************************/
void KeyDown(void)//其實最簡單的就是逐行掃描,就不難懂了。這里的行列掃描法有點
                                  //難理解,程序也復雜。
{
        unsigned char a=0;
        GPIO_KEY=0x0f;//測試列
        if(GPIO_KEY!=0x0f)
        {
                Delay10ms();//此處按鍵消抖,不可在測試列之后,那樣顯示時間不對,亮度很小
                if(GPIO_KEY!=0x0f)
                {
                        KeyState=1;//有按鍵按下
                        switch(GPIO_KEY)
                        {
                                case(0X07):        KeyValue=0;break;
                                case(0X0b):        KeyValue=1;break;
                                case(0X0d): KeyValue=2;break;
                                case(0X0e):        KeyValue=3;break;
                        }
                        //測試行
                        GPIO_KEY=0Xf0;
                        Delay10ms();//此處延時為了消抖
                        switch(GPIO_KEY)
                        {
                                case(0X70):        KeyValue=KeyValue;break;
                                case(0Xb0):        KeyValue=KeyValue+4;break;
                                case(0Xd0): KeyValue=KeyValue+8;break;
                                case(0Xe0):        KeyValue=KeyValue+12;break;
                        }
                        while((a<200)&&(GPIO_KEY!=0xf0))//按鍵松手檢測,a的值太小,就會在按下不松
                                                                                        //手時,產生多次按鍵的結果,現在有2s時間
                        {
                                Delay10ms();
                                a++;
                        }
                        a=0;
                }
        }
}


/*******************************************************************************
* 函 數 名         : Delay10ms
* 函數功能                   : 延時函數,延時10ms
* 輸    入         : 無
* 輸    出         : 無
*******************************************************************************/
void Delay10ms(void)   //誤差 0us
{
    unsigned char a,b,c;
    for(c=1;c>0;c--)
        for(b=38;b>0;b--)
            for(a=130;a>0;a--);
}
回復

使用道具 舉報

板凳
ID:282095 發表于 2019-8-9 08:52 | 只看該作者
通過按鍵進行掃描矩陣的處理
回復

使用道具 舉報

地板
ID:302534 發表于 2019-8-9 18:48 | 只看該作者
列掃描和豎掃描
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日韩中文字幕一区 | 国产精品久久久久久久久久久免费看 | 青青伊人久久 | 国产精品视频在线播放 | 国产jizz女人多喷水99 | 求个av网址 | 中文字幕国产日韩 | 国产精品日韩欧美一区二区三区 | 伊人操| 国产成人a亚洲精品 | 日韩欧美国产一区二区 | 日本在线精品视频 | 国产精品久久 | 男人的天堂视频网站 | 国产三级精品视频 | 在线观看www视频 | 免费 视频 1级| 日韩精品一区二区三区中文字幕 | 日韩欧美三级电影在线观看 | 一级一片在线观看 | 欧美一级在线 | av性色| 欧美激情一区二区三级高清视频 | 久久久日韩精品一区二区三区 | 国产精品亚洲一区二区三区在线 | 精品免费国产视频 | 高清久久 | 91在线精品秘密一区二区 | 国产视频精品区 | 在线91| 国产精品二区三区 | 日韩精品一区二区三区中文字幕 | 久久精品亚洲精品国产欧美 | 中文字幕日韩欧美一区二区三区 | 精品一二区| 亚洲一区二区精品 | 亚洲一本 | 国产精品嫩草影院精东 | 91精品一区二区三区久久久久久 | 国产一区二区在线免费 | 日韩一区二区三区在线看 |