欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

標題: 單片機怎么實現長按功能?長按著K1會連續加1往上增,長按k2會連續往下... [打印本頁]

作者: 汪巖    時間: 2018-12-28 11:33
標題: 單片機怎么實現長按功能?長按著K1會連續加1往上增,長按k2會連續往下...
這個代碼是0~99 基本都是按一下+1或者-1我覺得好像只有用定時器0和1才可以弄這樣子,但是,代碼是怎么寫?謝謝大家了。我因為我腦子問題太多,總在想,按1下有點慢。換長按,這樣連續快速,才可以連續加1或者減1了。

單片機源程序如下:
  1. #include "reg52.h"               
  2. typedef unsigned int u16;
  3. typedef unsigned char u8;
  4. sbit LSA=P2^2;
  5. sbit LSB=P2^3;
  6. sbit LSC=P2^4;
  7. sbit k1=P3^1;
  8. sbit k2=P3^0;
  9. sbit k3=P3^2;
  10. sbit k4=P3^3;
  11. u8 code smgduan[17]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
  12.                                         0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};//顯示0~F的值
  13. #define KEY1 1
  14. #define KEY2 2
  15. #define KEY3 3
  16. #define KEY4 4
  17. char keynum;
  18. u8 DisplayData[8];void delay(u16 i)
  19. {
  20.         while(i--);        
  21. }
  22. u8 KeyScan(u8 mode)
  23. {
  24.         static u8 keyen=1;
  25.         if(mode==1)
  26.         {
  27.                 keyen=1;
  28.         }
  29.         if(keyen==1&&(k1==0||k2==0||k3==0||k4==0))
  30.         {
  31.                 delay(1000);  //消抖處理
  32.                 keyen=0;
  33.                 if(k1==0)return KEY1;
  34.                 else if(k2==0)return KEY2;
  35.                 else if(k3==0)return KEY3;
  36.                 else if(k4==0)return KEY4;                                
  37.         }
  38.         else if(k1==1&&k2==1&&k3==1&&k4==1)
  39.         {
  40.                 keyen=1;
  41.         }
  42.         return 0;        
  43. }void DigDisplay()
  44. {
  45.         u8 i;
  46.         for(i=0;i<8;i++)
  47.         {
  48.                 switch(i)
  49.                 {
  50.                         case(0):
  51.                                 LSA=0;LSB=0;LSC=0; break
  52.                         case(1):
  53.                                 LSA=1;LSB=0;LSC=0; break
  54.                         case(2):
  55.                                 LSA=0;LSB=1;LSC=0; break
  56.                         case(3):
  57.                                 LSA=1;LSB=1;LSC=0; break
  58.                         case(4):
  59.                                 LSA=0;LSB=0;LSC=1; break
  60.                         case(5):
  61.                                 LSA=1;LSB=0;LSC=1; break
  62.                         case(6):
  63.                                 LSA=0;LSB=1;LSC=1; break
  64.                         case(7):
  65.                                 LSA=1;LSB=1;LSC=1; break        
  66.                 }
  67.                 P0=DisplayData[i];
  68.                 delay(100);
  69.                 P0=0x00;
  70.         }
  71. }
  72. void datapros()
  73. {
  74.         u8 key=KeyScan(0);
  75.         switch(key)
  76.         {
  77.                 case 1:  keynum++;if(keynum==100)keynum=0; break;
  78.                 case 2:  keynum--;if(keynum<=0)keynum=99; break;
  79.                 case 3:  keynum=0; break;
  80.                 case 4:   break;
  81.         }
  82.         DisplayData[0]=smgduan[keynum%10];
  83.         DisplayData[1]=smgduan[keynum/10];void main()
  84. {        
  85.         while(1)
  86.         {
  87.                 datapros();
  88.                 DigDisplay();        
  89.         }               
  90. }
復制代碼


作者: 汪巖    時間: 2018-12-28 15:36
我參考很多次網上的,置入了
像這些
void t0isr() interrupt 1
{
        TH0 = (65536 - 10000) / 256;
        TL0 = (65536 - 10000) % 256;
        cnt++;
        if (cnt >= 200)
        {
                flagl = 1;
                flags = 0;
                if ((cnt % 5) == 0)dat++;
        }
}
void t1isr() interrupt 3
{
   static u16 disscan;
        TH1 = (65536 - 5000) / 256;
        TL1 = (65536 - 5000) % 256;
        P2 = 1 << disscan;
        P0 = smgduan[dis[disscan]];
        disscan++;
        disscan %= 4;
}
好多都是這樣子,但始終不是要的結果。。。這是為什么
作者: 幻兮末晨    時間: 2018-12-28 16:44
我建議你可以加入延時操作

作者: 汪巖    時間: 2018-12-29 01:45
真沒人嗎我真的就差這一個課設唯一的題目了。
作者: 周超然    時間: 2018-12-29 08:21
你自己調試下嘛,加個延時。
作者: 笨笨兔    時間: 2018-12-29 08:33
                delay(1000);  //消抖處理

直接延時等待,浪費啊;

用中斷+標志,應該容易實現
作者: mrhan1992    時間: 2018-12-29 08:45
可以在按鍵按下的時候開啟定時器,或者延遲(例如延遲10ms,長按判斷為2s),然后設置一個記錄變量,每延時一次或者定時器中斷中變量自增一次,直到200(2s=2000ms,2000ms/10ms=200),判斷為長按,響應長按的事件
作者: 汪巖    時間: 2018-12-31 02:25
做出來了。成功




歡迎光臨 (http://m.raoushi.com/bbs/) Powered by Discuz! X3.1