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

標題: 51單片機紅外遙控控制燈的亮暗程序(用PWM控制) [打印本頁]

作者: 323    時間: 2019-4-26 11:14
標題: 51單片機紅外遙控控制燈的亮暗程序(用PWM控制)
紅外遙控控制燈的亮暗(用PWM控制),可控制燈的打開和關閉,以及用PWM控制燈的亮暗。
非常好用,方便移植到任何地方,下在板子上即可用了。51單片機紅外遙控例程。!
附帶紅外遙控鍵盤碼。


單片機源程序如下:
  1. /*
  2. 紅外無線遙控LED燈 +  變亮  按- 變暗 按CH- 關燈 按CH- 開燈CH
  3. */
  4. #include <reg52.h>


  5. /*====================================
  6. 自定義類型名
  7. ====================================*/
  8. typedef unsigned char INT8U;
  9. typedef unsigned char uchar;

  10. typedef unsigned int INT16U;
  11. typedef unsigned int uint;
  12. /*====================================
  13. 硬件接口位聲明
  14. ====================================*/
  15. sbit IR  = P3^2;     //定義紅外脈沖數據接口        外部中斷O輸入口
  16. sbit beep = P2^3;

  17. uchar IRtime;                 //檢測紅外高電平持續時間(脈寬)
  18. uchar IRcord[4];    //此數組用于儲存分離出來的4個字節的數據(用戶碼2個字節+鍵值碼2個字節)
  19. uchar IRdata[33];   //此數組用于儲存紅外的33位數據(第一位為引導碼用戶碼16+鍵值碼16)
  20. bit IRpro_ok, IRok;  //第一個用于紅外接收4個字節完畢。IRok用為檢測脈寬完畢


  21. unsigned char pwm_left_val = 250;//左電機占空比值 取值范圍0-170,0最快
  22. unsigned char pwm_t;//周期


  23. //毫秒級延時
  24. void delay(unsigned int z)
  25. {
  26.         unsigned int x,y;
  27.         for(x = z; x > 0; x--)
  28.                 for(y = 114; y > 0 ; y--);
  29. }

  30. void time0() interrupt 1   //定義定時器0
  31. {
  32.         IRtime++;                            //檢測脈寬,1次為278us
  33. }
  34. //定時器1中斷
  35. void timer1() interrupt 3
  36. {
  37.         pwm_t++;
  38.         if(pwm_t == 250)
  39.                 pwm_t = P1 = 0;
  40.         if(pwm_left_val == pwm_t)
  41.                         P1 = 0xff;                                         
  42. }
  43. void int0() interrupt 0                          //定義外部中斷0
  44. {
  45.         static uchar i;                                 //        聲明靜態變量(在跳出函數后在回來執行的時候不會丟失數值)i用于把33次高電平的持續時間存入IRdata
  46.         static bit startflag;                //開始儲存脈寬標志位
  47.         if(startflag)                                 //開始接收脈寬檢測
  48.         {
  49.                 if( (IRtime < 53) && (IRtime >= 32) ) /*判斷是否是引導碼,底電平9000us+高4500us       
  50.                 這個自己可以算我以11.0592來算了NEC協議的引導碼低8000-10000+高4000-5000
  51.                 如果已經接收了引導碼那么i不會被置0就會開始依次存入脈寬*/
  52.                         i = 0;                                 //如果是引導碼那么執行i=0把他存到IRdata的第一個位
  53.                 IRdata[i] = IRtime;                   //以T0的溢出次數來計算脈寬,把這個時間存到數組里面到后面判斷
  54.                 IRtime = 0;                                 //計數清零,下一個下降沿的時候在存入脈寬
  55.                 i++;                                          //計數脈寬存入的次數
  56.                 if(i == 33)                                  //如果存入34次 數組的下標是從0開始i等于33表示執行了34次
  57.                 {
  58.                          IRok = 1;                                 //那么表示脈寬檢測完畢
  59.                         i = 0;                                  //把脈寬計數清零準備下次存入
  60.                 }
  61.         }
  62.         else                  
  63.         {
  64.                 IRtime = 0;                                  //引導碼開始進入把脈寬計數清零開始計數
  65.                 startflag = 1;                         //開始處理標志位置1
  66.         }
  67. }

  68. void IRcordpro()                                    //提取它的33次脈寬進行數據解碼
  69. {
  70.         uchar i, j, k, cord, value;        /*i用于處理4個字節,j用于處理一個字節中每一位,k用于33次脈寬中的哪一位
  71.         cord用于取出脈寬的時間判斷是否符合1的脈寬時間*/
  72.         k = 1;                                                 //從第一位脈寬開始取,丟棄引導碼脈寬
  73.         for(i = 0; i < 4; i++)
  74.         {
  75.                 for(j = 0; j < 8; j++)
  76.                 {
  77.                         cord = IRdata[k];            //把脈寬存入cord
  78.                         if(cord > 5)                         //如果脈寬大于我11.0592的t0溢出率為約278us*5=1390那么判斷為1
  79.                         value = value | 0x80;        /*接收的時候是先接收最低位,
  80.                         把最低位先放到value的最高位在和0x08按位或一下
  81.                         這樣不會改變valua的其他位的數值只會讓他最高位為1*/
  82.                         if(j < 7)
  83.                         {
  84.                                 value = value >> 1;        //value位左移依次接收8位數據。
  85.                         }
  86.                         k++;                                //每執行一次脈寬位加1
  87.                 }
  88.                 IRcord[i] = value;           //每處理完一個字節把它放入IRcord數組中。
  89.                 value = 0;                            //清零value方便下次在存入數據
  90.         }
  91.         IRpro_ok = 1;                                   //接收完4個字節后IRpro ok置1表示紅外解碼完成       
  92. }

  93. void main()
  94. {
  95.         unsigned char i = 9;
  96.         TMOD |= 0x20;//T1 8位自動重裝模塊
  97.         TH1 = 245;
  98.         TL1 = 245;//11.0592M晶振下占空比最大比值是256,輸出100HZ
  99.         TR1 = 1;//啟動定時器0
  100.         ET1 = 1;//允許定時器0中斷
  101.         EA        = 1;//總中斷允許

  102.         TMOD |= 0x02; //定時器0工作方式2,8位自動重裝
  103.         TH0 = 0x00;  //高8位裝入0那么定時器溢出一次的時間是256個機器周期
  104.         TL0 = 0x00;
  105.         ET0 = 1;           //定時器0中斷
  106.         TR0 = 1;     //啟動定時器0

  107.         IT0 = 1;           //設置外部中斷0為跳沿觸發方式,來一個下降沿觸發一次
  108.         EX0 = 1;           //啟動外部中斷0
  109.         //delay(2000);
  110.         while(1)
  111.         {
  112.                
  113.                 if(IRok)    //判斷脈寬是否檢測完畢                    
  114.                 {   
  115.                         IRcordpro();//根據脈寬解碼出4個字節的數據
  116.                         IRok = 0;        //重新等待脈寬檢測
  117.                         if(IRpro_ok) //判斷是否解碼完畢  
  118.                         {
  119.                         switch(IRcord[2])
  120.                                    {
  121.                                      case 0x07:   //-
  122.                                          if(i > 0)
  123.                                         {
  124.                                                 pwm_left_val = pwm_left_val - 25;
  125.                                                 i--;
  126.                                         }
  127.                                         beep = 0; delay(5); beep = 1;
  128.                                              break;
  129.                                      case 0x15:   //+
  130.                                         if(i < 9)
  131.                                         {
  132.                                                 pwm_left_val = pwm_left_val + 25;
  133.                                                 i++;
  134.                                         }
  135.                                         beep = 0; delay(5); beep = 1;
  136.                                                      break;
  137.                                          case 0x46: ET1 = 1; P1 = 0;beep = 0; delay(5); beep = 1;                 
  138.                                              break;
  139.                                          case 0x45: ET1 = 0; P1 = 0XFF;beep = 0; delay(5); beep = 1;               
  140.                                              break;
  141.                                    }
  142.                                 IRpro_ok = 0;
  143.                         }
  144.                 }       
  145.                 /*if(S2 == 0)
  146.                 {
  147.                         delay(5);
  148.                         if(S2 == 0)
  149.                         {
  150.                                 if(i < 9)
  151.                                 {
  152.                                         pwm_left_val = pwm_left_val + 8;
  153.                                         i++;
  154.                                         P0 = discode[i];
  155.                                 }
  156.                                 while(!S2);                
  157.                         }
  158.                 }
  159.                 if(S3 == 0)
  160.                 {
  161.                         delay(5);
  162.                         if(S3 == 0)
  163.                         {
  164.                                 if(i > 0)
  165.                                 {
  166.                                         pwm_left_val = pwm_left_val - 8;
  167.                                         i--;
  168.                                         P0 = discode[i];
  169.                                 }
  170.                                 while(!S3);                
  171.                         }
  172.                 }*/       
  173.         }
  174. }

復制代碼

所有資料51hei提供下載:
紅外調光.docx (14.83 KB, 下載次數: 188)



作者: 323    時間: 2019-4-29 09:59
大家有問題可以問哈,我時不時就會登陸,看到了就會回的哈!

作者: roachwz    時間: 2019-5-5 21:46
沒看懂pwm的那段程序,注釋寫的少。紅外遙控接收的倒是懂了
作者: yfpc2006    時間: 2019-5-6 02:47
挺好的資料,希望多學習~!
作者: ptlantu    時間: 2019-5-6 13:03
感謝分享
作者: 323    時間: 2019-5-6 15:33
ptlantu 發表于 2019-5-6 13:03
感謝分享

不用謝啦~

作者: 323    時間: 2019-5-6 15:33
yfpc2006 發表于 2019-5-6 02:47
挺好的資料,希望多學習~!

謝謝啦~
作者: 323    時間: 2019-5-6 15:43
roachwz 發表于 2019-5-5 21:46
沒看懂pwm的那段程序,注釋寫的少。紅外遙控接收的倒是懂了

嘻嘻,沒看懂的話我給你講一遍吧,在這個程序中PWM主要出現在void timer1() interrupt 3里,那我們就討論這里就行了,pwm_t是定時器溢出一次,他加1,現在假設pwm_left_val現在為25,F在定時器在不斷的溢出,
pwm_t也在不斷的加1,當pwm_t等于25時,執行P1 = 0xff;   燈全滅了,現在pwm_t還是在不斷的加1。然后燈是一直滅的,直到pwm_t == 250,執行pwm_t = P1 = 0;現在燈全亮了。pwm_t現在又從1開始加了。那么可以看出,0-25燈是亮的,25-250是滅的,然后他們亮滅的非?,你眼睛里看到的燈是一直亮的,但亮度是由
pwm_left_val決定的,這就是占空比,F在應該明白了吧,嘻嘻。
作者: grx-gql    時間: 2019-6-5 15:03
謝謝你的分享
作者: fankechang    時間: 2019-8-31 22:20
對初學者太實用了
作者: liudi1990    時間: 2019-9-1 11:27
樓主 有沒有紅外信號發送的程序啊
作者: fdc2011    時間: 2019-9-19 15:01
用戶碼與引導碼看不明白,請指教一下
作者: yuanni5544    時間: 2019-11-29 15:24
value = value | 0x80;為什么要或,不加也不會有問題吧,例如接收10100011,value的值怎么接收
作者: szzxl10    時間: 2019-11-30 17:58
謝謝樓主分享
作者: 323    時間: 2020-1-2 19:55
liudi1990 發表于 2019-9-1 11:27
樓主 有沒有紅外信號發送的程序啊

我的紅外信號發送是用那個紅外遙控器的。如果你想自己做一個的話可以在百度上搜“紅外信號發送的程序”可以看下。我沒試過哦。
作者: 17356536968    時間: 2020-4-16 14:50
323 發表于 2019-4-29 09:59
大家有問題可以問哈,我時不時就會登陸,看到了就會回的哈!!

您好  關于“51單片機紅外遙控控制燈的亮暗程序(用PWM控制)”的資料可以分享一下嗎  謝謝
作者: 楊天想    時間: 2020-7-25 17:49
請樓主有433紅外解碼對碼的程序和講解嗎

作者: 2728331964    時間: 2020-12-30 14:11
可以發一份原理圖嗎
作者: 2728331964    時間: 2020-12-30 15:10
請問有原理圖嗎
作者: 木示    時間: 2022-12-2 11:24
這段代碼是做什么用的呢?
   /*if(S2 == 0)
                {
                        delay(5);
                        if(S2 == 0)
                        {
                                if(i < 9)
                                {
                                        pwm_left_val = pwm_left_val + 8;
                                        i++;
                                        P0 = discode[i];
                                }
                                while(!S2);               
                        }
                }
                if(S3 == 0)
                {
                        delay(5);
                        if(S3 == 0)
                        {
                                if(i > 0)
                                {
                                        pwm_left_val = pwm_left_val - 8;
                                        i--;
                                        P0 = discode[i];
                                }
                                while(!S3);               
                        }
                }*/      
作者: wkman    時間: 2022-12-3 08:59
某1個寶上1快多的遙控器???
作者: likejian    時間: 2023-8-25 11:59
看起來很復雜,難度很大




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