标题: 单片机做的433遥控解码源程序,带学习功能可存8组遥控码 [打印本页]

作者: linlihui0601    时间: 2017-11-22 21:59
标题: 单片机做的433遥控解码源程序,带学习功能可存8组遥控码
分享一个最近用STC89C52单片机做的433遥控解码程序,带学习功能的,可以存8组遥控码,如果不够可以自行增加。电路图如下:
欢迎各位大神提出宝贵意见!



单片机源程序如下:
  1. 1、EV1527/PT2262 按键解码输出,并有解码有效输出端。

  2. 2、程序采用中断嵌套结构,定时时间准确,可轻松集成到您现有程序中,解码精度不受其他程序块影响。

  3. 3、通过学习键可学习40个遥控器编码,使用芯片自带EEPROM,无需外挂存储。

  4. 4、提供keil5 c代码,有详细注释,提供网络技术支持。

  5. 该源码适合初学者研究,或想在原有产品中增加功能又缺乏此类经验的朋友。


  6. !!!按一下学习键指示灯亮一下灭,松开,再按一下遥控器,学习指示灯闪一下,表示学习成功
  7. 学习成功后,才能接收此遥控器的数据,否则没反应!!!

  8. !!!按下学习按键6秒之内松开,超过6秒后无效并清除以前存储的遥控器数据
  9. */



  10. #include "main.h"



  11. uint TMR0;


  12. void system_init(void)   //上电初始化
  13. {       

  14.   
  15. #if defined(SYS_CY_12T)  
  16. // /*//12T
  17.         AUXR &= 0x7F;                //定时器时钟12T模式
  18.         TMOD &= 0xF0;                //设置定时器模式
  19.         TMOD |= 0x01;                //设置定时器模式
  20.         TL0 = 0x9C;                //设置定时初值
  21.         TH0 = 0xFF;                //设置定时初值
  22.         TF0 = 0;                //清除TF0标志
  23.         TR0 = 1;                //定时器0开始计时
  24.         ET0 = 1; //定时器0中断允许
  25.   
  26.         AUXR &= 0xBF;                //定时器时钟12T模式
  27.         TMOD &= 0x0F;                //设置定时器模式
  28.         TMOD |= 0x10;                //设置定时器模式
  29.         TL1 = 0;                //设置定时初值
  30.         TH1 = 0;                //设置定时初值
  31.         TF1 = 0;                //清除TF1标志
  32.         //TR1 = 1;                //定时器1开始计时
  33. //        ET1 = 1;   
  34.   //*/
  35. #endif  
  36.   

  37.    LM_SEL=1;
  38.    RF=1;
  39. SET=1;
  40.   
  41.   EA = 1; //允许CPU中断     
  42.   

  43. }





  44. void tm0_isr() interrupt 1 using 1
  45. {
  46.   rx_data();
  47. }




  48. void main()
  49. {
  50. system_init();
  51.          
  52.   while(1)
  53.         {
  54.     set_scan();
  55.         }  
  56. }


  57. ……………………

  58. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

rx.c源程序如下:
  1. #include "main.h"


  2. bit old_bit;           //保存上一次查询到的电平状态
  3. bit tb_ok;             //接收到同步的马时置1   
  4. bit rf_ok;            //接收到一个完整的遥控命令后置1,通知解码程序可以解码了
  5. bit study;                                 //进入学习状态标志
  6. bit bt_auto=0;     //自动设置遥控接收波特率标志
  7. bit rf_ok1,rf_ok2;        //接收成功临时标志



  8. uchar  hh_w,ll_w;           //高,低电平宽度
  9. uchar  ma_n;                //接收到第几位编码了
  10. uchar  bma1,bma2,bma3,bma4; //用于接收过程存放遥控编码
  11. uchar  mma1,mma2,mma3,mma4; //第一次接收到的编码,用于解码过程
  12. uchar  mmb1,mmb2,mmb3,mmb4; //第二次接收到的编码


  13. uchar temp_T0;                        //t初值


  14. uint s_tim;                //定时






  15. #if 1

  16. void rx_data()
  17.    {          
  18.      uchar x;   

  19.      
  20.                      if(!bt_auto)//自动设置遥控接收波特率标志
  21.                     {
  22.           TMR0=100;
  23.                                     TMR00;
  24.                     }
  25.                         else
  26.                                 {
  27.           TMR0=temp_T0;
  28.                                         TMR00;               
  29.                                 }

  30.                 




  31.    
  32.      if (!RF) { ll_w++;old_bit=0; }  // 检测到低电平 低电平时间加1,记录本次电平状态  old_rc5=保存上一次查询到的电平状态
  33.      
  34.      
  35.      

  36.      else        // 检测到高电平
  37.        {
  38.          

  39.          
  40.                hh_w++;//记录高电平时间
  41.          
  42.          if (!old_bit)// 检测到从低到高的跳变,已检测到一个完整(高-低)电平周期
  43.           {
  44.       
  45.             
  46.            
  47.             
  48.            if (((hh_w>=2)&&(hh_w<=7))&&((ll_w>=50)&&(ll_w<=180)))          //判同步码          
  49.                {                                                       //下面是同步码低电平判断
  50.                                            if((ll_w>=100)&&(ll_w<=180))//4.7m电阻
  51.                     {ma_n=0;tb_ok=1;bma1=0; bma2=0; bma3=0; bma4=0;bt_auto=0;//temp_T0=100;
  52.                     }

  53.                     
  54.                 }

  55.                
  56.                
  57.            else if ((tb_ok)&&((ll_w>=10)&&(ll_w<=16)))         //数据低电平   
  58.                                          {        
  59.                                                  ma_n++;                                //已经接收到同步码,判为0
  60.                                                  if(ma_n>23)
  61.                                                          {
  62.                                                            if(!rf_ok1)
  63.                                                                    {
  64.                                                                       mma1=bma1;mma2=bma2;mma3=bma3;mma4=bma4;//将接收到的编码复制到解码寄存器中                             
  65.                             rf_ok1=1;
  66.                             ma_n=0;                           
  67.                             tb_ok=0;
  68.                                                                       bt_auto=0;
  69.                                                                       s_tim=2500;                                                   
  70.                                                                    }
  71.                                                                 else
  72.                                                                         {
  73.                                                                          mmb1=bma1;mmb2=bma2;mmb3=bma3;mmb4=bma4;//将接收到的编码复制到解码寄存器中                             
  74.                                   rf_ok2=1;
  75.                                   ma_n=0;                              
  76.                                   tb_ok=0;
  77.                                                                          bt_auto=0;                                                                                                                                                       
  78.                                                                         }
  79.                                                                
  80.                                                          }
  81.                                           }  
  82.                  
  83.                   
  84.                   
  85.                   
  86.             else if ((tb_ok)&&((ll_w>=3)&&(ll_w<=6)))                   //数据高电平   
  87.                  { switch (ma_n)
  88.                      {
  89.                                           case 0 : { bma1=bma1 | 0x80; break; }//遥控地址编码第1位
  90.                        case 1 : { bma1=bma1 | 0x40; break; }
  91.                        case 2 : { bma1=bma1 | 0x20; break; }
  92.                        case 3 : { bma1=bma1 | 0x10; break; }
  93.                        case 4 : { bma1=bma1 | 0x08; break; }
  94.                        case 5 : { bma1=bma1 | 0x04; break; }
  95.                        case 6 : { bma1=bma1 | 0x02; break; }
  96.                        case 7 : { bma1=bma1 | 0x01; break; }

  97.                        case 8 : { bma2=bma2 | 0x80; break; }
  98.                        case 9 : { bma2=bma2 | 0x40; break; }
  99.                        case 10: { bma2=bma2 | 0x20; break; }
  100.                        case 11: { bma2=bma2 | 0x10; break; }
  101.                        case 12: { bma2=bma2 | 0x08; break; }
  102.                        case 13: { bma2=bma2 | 0x04; break; }
  103.                        case 14: { bma2=bma2 | 0x02; break; }
  104.                        case 15: { bma2=bma2 | 0x01; break; }

  105.                        case 16: { bma3=bma3 | 0x80; break; }//2262按键码第1位
  106.                        case 17: { bma3=bma3 | 0x40; break; }
  107.                        case 18: { bma3=bma3 | 0x20; break; }
  108.                        case 19: { bma3=bma3 | 0x10; break; }
  109.                        case 20: { bma4=bma4 | 0x80; break; }//1527按键码第1位
  110.                        case 21: { bma4=bma4 | 0x40; break; }
  111.                        case 22: { bma4=bma4 | 0x20; break; }
  112.                        case 23:
  113.                            { bma4=bma4 | 0x10;                                          
  114.                                           if(!rf_ok1)
  115.                                                    {
  116.                                                   mma1=bma1;mma2=bma2;mma3=bma3;mma4=bma4;//将接收到的编码复制到解码寄存器中                             
  117.                                       rf_ok1=1;                                
  118.                                       tb_ok=0;
  119.                                                   bt_auto=0;
  120.                                                   ma_n=0;
  121.                                                   s_tim=2500;
  122.                                                   break;                                                                       
  123.                                                   }
  124.                                                  else
  125.                                                       {
  126.                                                        mmb1=bma1;mmb2=bma2;mmb3=bma3;mmb4=bma4;//将再次接收到的编码复制到解码寄存器中,                             
  127.                                        rf_ok2=1;                                
  128.                                        tb_ok=0;
  129.                                                        bt_auto=0;
  130.                                                        ma_n=0;
  131.                                                        break;                                                                                                                                                       
  132.                                                        }
  133.                                    
  134.                             }
  135.                      }
  136.                     ma_n++;
  137.                                        
  138.                   }
  139.                  
  140.                   
  141.             else {ma_n=0; tb_ok=0; bt_auto=0;bma1=0; bma2=0; bma3=0; bma4=0;hh_w=1;ll_w=0;}      //接收到不符合的高-低电平序列
  142.               
  143.                    ll_w=0;hh_w=1;
  144.                            }
  145.          
  146.          
  147.         old_bit=1;      // 记录本次电平状态
  148.      }
  149.   
  150.      
  151.      
  152.      
  153.      

  154.          if(rf_ok1)                //规定时间内接受到2帧相同的编码数据才有效
  155.                 {       
  156.       
  157.    
  158.       
  159.                         s_tim--;
  160.                         if(!s_tim) rf_ok1=0;
  161.                         if(rf_ok2)
  162.                                 {
  163.         

  164.          
  165.                                   if((mma1==mmb1)&&(mma2==mmb2)&&(mma3==mmb3)&&(mma4==mmb4))//比较两次接收到的编码是否一致 OK
  166.                                            {
  167.                                           
  168.                                           rf_ok=1;
  169.                                           rf_ok1=0;
  170.                                           rf_ok2=0;                                         
  171.                                          }
  172.                                         else//接收数据无效  
  173.                                          {
  174.                                                   rf_ok=0;
  175.                                                   rf_ok1=0;
  176.                                                   rf_ok2=0;                                          
  177.                      }
  178.                                                                  
  179.                                 }                                       
  180.                   }
  181.                
  182.                        
  183.                        
  184.                        
  185.         #if defined(STUDY_NOSET)
  186.    if(rf_ok)                 //判断
  187.                         {         
  188.                                 GIE=0;
  189.                                 rf_ok=0;
  190.                                 if(((mma3==0xc0)&&(!mma4))|((mma3==0x30)&&(!mma4))|((!mma3)&&(mma4==0xc0))|((!mma3)&&(mma4==0x30)))   //判断是2262编码
  191.                                         {  

  192.                   D0=(mma3 - 0xc0);    //取按键码          
  193.                                                                         D1=(mma3 - 0x30);
  194.                                                                         D2=(mma4 - 0xc0);
  195.                                                                         D3=(mma4 - 0x30);
  196.             
  197.                                                                         decode_ok=0;
  198.                                                                         s=1500;

  199.                                                                                 
  200.                                         }
  201.                                         else                                         //判断是1527编码
  202.                                                 {         
  203.                
  204.                       D0=(mma4 - 0x80);    //取按键码          
  205.                                                                                         D1=(mma4 - 0x40);
  206.                                                                                         D2=(mma4 - 0x20);
  207.                                                                                         D3=(mma4 - 0x10);       
  208.               
  209.                                                                                         decode_ok=0;                                       
  210.                                                                                         s=1500;        //解码有效输出时间                                                       
  211.                                                                                                
  212.                                                 }
  213.                                          GIE=1;
  214.                         }                       
  215.                         #endif
  216.                        
  217.       
  218.       
  219.       #if defined(STUDY_SET)
  220. ////////////////////////////////////////////////////////////////////                       
  221. if((rf_ok)&&(!study))                 //判断是否是学习状态
  222.                         {         
  223.                
  224.                                 rf_ok=0;
  225.                                 if(((mma3==0xc0)&&(!mma4))|((mma3==0x30)&&(!mma4))|((!mma3)&&(mma4==0xc0))|((!mma3)&&(mma4==0x30)))   //判断是2262编码
  226.                                         {  
  227.                                            for(x=0;x<40;x++)
  228.                                                    {
  229.                                                         if((mma1==EEPROM_read(x*3+1))&&(mma2==EEPROM_read(x*3+2)))
  230.                                                                 {
  231.                                                                         D0=(mma3 - 0xc0);    //取按键码          
  232.                                                                         D1=(mma3 - 0x30);
  233.                                                                         D2=(mma4 - 0xc0);
  234.                                                                         D3=(mma4 - 0x30);       
  235.        
  236.                                                                         decode_ok=0;
  237.                                                                         s_tim=1500;
  238.                                                                         break;
  239.                                                                 }
  240.                                                                                                
  241.                                                 }
  242.                                                                                 
  243.                                         }
  244.                                         else                                         //判断是1527编码
  245.                                                 {         
  246.                                                      for(x=0;x<40;x++)
  247.                                                                    {   
  248.                                                                         if((mma1==EEPROM_read(x*3+1))&&(mma2==EEPROM_read(x*3+2))&&(mma3==EEPROM_read(x*3+3)))
  249.                                                                                 {                                                                                       
  250.                                                                                         D0=(mma4 - 0x80);    //取按键码          
  251.                                                                                         D1=(mma4 - 0x40);
  252.                                                                                         D2=(mma4 - 0x20);
  253.                                                                                         D3=(mma4 - 0x10);       
  254.                                                                                                                                                  
  255.                                                                                         decode_ok=0;                                       
  256.                                                                                         s_tim=1500;        //解码有效输出时间
  257.                                                                                         break;
  258.                                                                                 }
  259.                                                                                                                
  260.                                                                 }
  261.                                                                                                
  262.                                                 }
  263.                                        
  264.                         }                       

  265. /////////////////////////////////////////////////////////////////////////
  266.    #endif
  267.       
  268.       
  269.       
  270.      if(!decode_ok)//解码有效输出
  271.                   {
  272.                           s_tim--;
  273.                           if(!s_tim)
  274.                                  {
  275.                                         decode_ok=1;//关信号灯
  276.                                         if(!LM_SEL)    //  锁存/暂态 选择
  277.                                                 {
  278.                                                         D0=1;
  279.                                                         D1=1;
  280.                                                         D2=1;
  281.                                                         D3=1;
  282.                                                 }
  283.                                  }
  284.                                   
  285.                    }


  286.    }


  287. #endif

  288.    
  289.    
  290. void KEY_study()        //遥控器学习
  291. {       
  292.         uchar num_rf;
  293.         uchar d_num=0;                       

  294.         while(!rf_ok)//等待按键
  295.                 {
  296.                         delay_ms(100);
  297.                         d_num++;
  298.                         if(d_num>200) break;          
  299.                 }
  300.    
  301.    
  302.         d_num=0;
  303.    
  304.         if(rf_ok)
  305.                 {
  306.                         GIE=0;
  307.                         num_rf=EEPROM_read(0x00);       //取已学习的遥控器数量
  308.                         if(num_rf>40){num_rf=0;}        //如果遥控器数量超过40个,覆盖最先学习的
  309.                        
  310.      
  311.       
  312.                         EEPROM_write(0,num_rf+1);
  313.       
  314.       EEPROM_write(num_rf*3+1,mma1);
  315.                         EEPROM_write(num_rf*3+2,mma2);
  316.                         EEPROM_write(num_rf*3+3,mma3);
  317.       
  318.                        
  319.       
  320.       
  321.       
  322.                         LED=0;
  323.                         delay_ms(200);
  324.                         LED=1;
  325.                         rf_ok=0;

  326.                         GIE=1;
  327.                        
  328.                  }       
  329.                 else
  330.                         {
  331.                                 rf_ok=0;                //操作超时                       
  332.                         }
  333.         d_num=0;
  334.          
  335.                
  336. }



  337. void system_res()  //系统清零,清除学习过的遥控器编码          
  338. {

  339.         GIE=0;

  340.    
  341. ……………………

  342. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码



所有资料51hei提供下载:
51单片机433遥控解码(带学习功能).rar (205.31 KB, 下载次数: 1234)



作者: admin    时间: 2017-11-23 03:17
好资料,51黑有你更精彩!!!
作者: liugang    时间: 2017-11-23 07:13
感谢分享!
作者: YQS    时间: 2017-11-23 10:04
好资料!正需要学习,谢谢楼主分享资源!
作者: 打杂的    时间: 2017-11-26 19:56
我们公司的做无线433M产品,现在也在学习51单片机,先收藏。谢谢
作者: fancunwu    时间: 2017-11-28 22:19
谢谢楼主分享资源!
作者: GYB0412    时间: 2017-12-22 15:35
没有接收的程序吗?
作者: xingyusky111    时间: 2017-12-24 23:45
不错,很好的资料
作者: bzf51    时间: 2018-1-3 05:59
有没有那位高手在?我知道这样问一定是白问!因为高手在民间!
作者: tzyjf    时间: 2018-1-11 09:51
一直想学习无线遥控,下下来看看
作者: zxcvbnm123789    时间: 2018-1-11 11:04
谢谢,真的好贴
作者: wyh5360    时间: 2018-1-11 11:47
谢谢分享谢谢分享
作者: shanxiaoke    时间: 2018-1-13 16:14
试了一下,不行
作者: tqmtonychen    时间: 2018-1-15 13:34
我试了一下,好象没反应啊,不知哪里出问题了?
作者: randy0504    时间: 2018-1-16 17:45
正在学习当中
作者: Ming5566    时间: 2018-1-29 08:55
刚好需要,谢谢了。
作者: ticf    时间: 2018-4-1 11:37
我现在做的是用TTL口经过433模块无线收发,配对学习这部分一直没搞定
作者: liaoxliang    时间: 2018-5-21 17:41

刚好需要,谢谢了。
作者: sztangr    时间: 2018-6-19 22:53
你这个是不病毒啊
作者: lovemj42    时间: 2018-8-11 15:35
433的资料很少,难得一份好资料~~学习学习~
作者: wb8899    时间: 2018-8-21 12:17
正需要用到,参考一下,谢谢
作者: 风158    时间: 2018-8-21 17:04
下来学习一下,谢谢分享
作者: LCY30520    时间: 2018-10-23 16:03
谢谢楼主分享资源!
作者: szdgsz    时间: 2018-10-24 17:37
谢谢分享

作者: chengfgc    时间: 2018-11-1 10:12
认真学习,没有黑币,努力工作
作者: 无焰之火    时间: 2018-11-1 23:57
谢谢楼主分享,正在找315,433方方面的资料
作者: qaz_aiit    时间: 2018-11-27 11:57

好资料,51黑有你更精彩!!!
作者: qiao3755    时间: 2018-12-2 16:54
谢谢分享!!!
作者: Rain2003    时间: 2018-12-10 21:17
谢谢分享!!!
作者: hxszrb    时间: 2019-1-18 21:21


好资料,51黑有你更精彩!!
作者: gogogoing    时间: 2019-2-18 11:02
好资料,51黑有你更精彩!!!
作者: retome    时间: 2019-3-30 08:25
多谢分享
作者: qwea_cn1    时间: 2019-5-14 10:26
谢谢分享谢谢分享
作者: 蜗牛贤    时间: 2019-6-6 23:50
自己用STM单片机做过,解码不灵敏,有时能解不时不行,参考一下楼主的程序,希望能找出问题点
作者: daniellew    时间: 2019-7-7 14:20
试了很久,没有解码成功,希望有好方法及建议!
作者: cheeseyang    时间: 2019-7-10 14:08
好资料,谢谢分享
作者: vectorxu    时间: 2019-8-28 10:23

好资料!正需要学习,谢谢楼主分享!
作者: HXN1    时间: 2019-8-28 15:19
感谢分享!
作者: dspmomo    时间: 2019-8-29 23:34
很好的学习资料
作者: lipopo    时间: 2019-10-25 21:13
资料不错
作者: 568204532    时间: 2019-10-30 14:59
我现在做433模块无线收发,这款内部做多可以存储多少个码值?
作者: kmdyc    时间: 2019-11-13 10:54
正好需要这个,收藏先~~~~~
作者: KEIILER    时间: 2019-11-13 20:36

好资料!正需要学习,谢谢楼主分享资源!
作者: wdliming    时间: 2019-11-14 12:49
谢谢分享~~
作者: 一命    时间: 2019-12-18 12:15
学习一下
作者: wudihuanx    时间: 2020-1-9 18:46
感谢分享!学习一下。
作者: xqg0809    时间: 2020-2-20 17:35
好资料,正需要,谢谢分享
作者: wxxl    时间: 2020-2-24 16:13
这个网站真好,有很多外面难找的资料!
作者: yangalex    时间: 2020-3-26 11:53
认真学习,没有黑币,我也要努力发共享贴。
作者: 杰哥仔    时间: 2020-3-27 18:19
谢谢分享,最近在搞个无线遥控,正适合
作者: xiaolingfu    时间: 2020-4-5 17:08
好好学习
作者: xiaolingfu    时间: 2020-4-6 08:22
功能强大
作者: 6174    时间: 2020-4-6 11:49
谢谢分享
作者: cyzyr001    时间: 2020-4-16 22:19
多谢楼主分享
作者: xiaoci958    时间: 2020-6-21 23:38
路过 收下了 谢谢 。。。。。。。。。。。。。。。。。。
作者: huihuangzeng    时间: 2020-7-26 21:22
SYN531
路过 收下了 谢谢 。。。。。。。。。。。。。。。。。。
作者: huihuangzeng    时间: 2020-7-28 21:02

好资料,51黑有你更精彩!!!
作者: zzq5008    时间: 2020-11-4 14:07
我们做无线433M产品,现在也在学习51单片机,先收藏。谢谢
作者: 川蜀浪子    时间: 2021-6-30 12:02
正需要用到,参考一下,谢谢
作者: 13968727975    时间: 2021-7-8 14:05
你的这资料是RF 433
作者: qxdqx    时间: 2021-7-27 21:12
好资料,51黑有你更精彩!!!
作者: 华而不斯    时间: 2021-9-10 12:02
if(!bt_auto)//自动设置遥控接收波特率标志
                    {
          TMR0=100;
                                    TMR00;
                    }
                        else
                                {
          TMR0=temp_T0;
                                        TMR00;               
                                }
这个 TMR00;    好蒙啊
作者: radio0326    时间: 2021-11-19 08:47
真的是一个好贴,好好看程序学习一下
作者: wgrren    时间: 2022-2-13 19:11
学习一下,十分感谢
作者: wgrren    时间: 2022-2-13 19:12
下载学习一下,十分感谢提供。
作者: nuomistudio    时间: 2022-2-14 09:41
这个不错,自己设计?
作者: 1m49s    时间: 2022-7-11 17:38
好资料,51黑有你更精彩!!  先看看~
作者: haxiny    时间: 2023-2-10 13:11
谢谢楼主分享资料!!好东西
作者: wellhope    时间: 2023-2-13 14:03
发射器按键长按,接收不知道怎么处理,楼主能指点一下吗?谢谢!
作者: joe069    时间: 2023-2-14 22:47
真是很有价值的资料,赞一个,先收藏
作者: joe069    时间: 2023-2-14 22:50
非常有价值的资料,感谢楼主分享
作者: torp    时间: 2023-4-18 17:28
收藏起来,最近有用
作者: loalt    时间: 2024-8-15 10:12
刚好需要,学习中,感谢!!!
作者: lyd2004888    时间: 2024-11-19 07:57
感谢分享!正想要的
作者: Mrjork    时间: 2025-2-22 10:28
大佬非常感谢您的分享,但是我想请教一下取前20位地址码部分是怎么实现的呢,麻烦您指教一下,非常感谢




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1