找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 33670|回复: 71
收起左侧

单片机做的433遥控解码源程序,带学习功能可存8组遥控码

  [复制链接]
ID:252456 发表于 2017-11-22 21:59 | 显示全部楼层 |阅读模式
分享一个最近用STC89C52单片机做的433遥控解码程序,带学习功能的,可以存8组遥控码,如果不够可以自行增加。电路图如下:
欢迎各位大神提出宝贵意见!

TIM截图20171122215054.jpg

单片机源程序如下:
  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黑下载附件…………
复制代码

0.png

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

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:1 发表于 2017-11-23 03:17 | 显示全部楼层
好资料,51黑有你更精彩!!!
回复

使用道具 举报

ID:134317 发表于 2017-11-23 07:13 | 显示全部楼层
感谢分享!
回复

使用道具 举报

ID:167337 发表于 2017-11-23 10:04 | 显示全部楼层
好资料!正需要学习,谢谢楼主分享资源!
回复

使用道具 举报

ID:218360 发表于 2017-11-26 19:56 | 显示全部楼层
我们公司的做无线433M产品,现在也在学习51单片机,先收藏。谢谢
回复

使用道具 举报

ID:34298 发表于 2017-11-28 22:19 | 显示全部楼层
谢谢楼主分享资源!
回复

使用道具 举报

ID:265302 发表于 2017-12-22 15:35 | 显示全部楼层
没有接收的程序吗?
回复

使用道具 举报

ID:152715 发表于 2017-12-24 23:45 来自手机 | 显示全部楼层
不错,很好的资料
回复

使用道具 举报

ID:269870 发表于 2018-1-3 05:59 来自手机 | 显示全部楼层
有没有那位高手在?我知道这样问一定是白问!因为高手在民间!
回复

使用道具 举报

ID:65957 发表于 2018-1-11 09:51 | 显示全部楼层
一直想学习无线遥控,下下来看看
回复

使用道具 举报

ID:272932 发表于 2018-1-11 11:04 | 显示全部楼层
谢谢,真的好贴
回复

使用道具 举报

ID:274730 发表于 2018-1-11 11:47 | 显示全部楼层
谢谢分享谢谢分享
回复

使用道具 举报

ID:211333 发表于 2018-1-13 16:14 | 显示全部楼层
试了一下,不行
回复

使用道具 举报

ID:229306 发表于 2018-1-15 13:34 | 显示全部楼层
我试了一下,好象没反应啊,不知哪里出问题了?
回复

使用道具 举报

ID:276631 发表于 2018-1-16 17:45 | 显示全部楼层
正在学习当中
回复

使用道具 举报

ID:280555 发表于 2018-1-29 08:55 | 显示全部楼层
刚好需要,谢谢了。
回复

使用道具 举报

ID:300216 发表于 2018-4-1 11:37 | 显示全部楼层
我现在做的是用TTL口经过433模块无线收发,配对学习这部分一直没搞定
回复

使用道具 举报

ID:60122 发表于 2018-5-21 17:41 | 显示全部楼层

刚好需要,谢谢了。
回复

使用道具 举报

ID:161227 发表于 2018-6-19 22:53 | 显示全部楼层
你这个是不病毒啊
回复

使用道具 举报

ID:277370 发表于 2018-8-11 15:35 | 显示全部楼层
433的资料很少,难得一份好资料~~学习学习~
回复

使用道具 举报

ID:6985 发表于 2018-8-21 12:17 | 显示全部楼层
正需要用到,参考一下,谢谢
回复

使用道具 举报

ID:343102 发表于 2018-8-21 17:04 | 显示全部楼层
下来学习一下,谢谢分享
回复

使用道具 举报

ID:42114 发表于 2018-10-23 16:03 | 显示全部楼层
谢谢楼主分享资源!
回复

使用道具 举报

ID:106063 发表于 2018-10-24 17:37 | 显示全部楼层
谢谢分享
回复

使用道具 举报

ID:373 发表于 2018-11-1 10:12 | 显示全部楼层
认真学习,没有黑币,努力工作
回复

使用道具 举报

ID:403857 发表于 2018-11-1 23:57 | 显示全部楼层
谢谢楼主分享,正在找315,433方方面的资料
回复

使用道具 举报

ID:434079 发表于 2018-11-27 11:57 | 显示全部楼层

好资料,51黑有你更精彩!!!
回复

使用道具 举报

ID:96180 发表于 2018-12-2 16:54 | 显示全部楼层
谢谢分享!!!
回复

使用道具 举报

ID:443649 发表于 2018-12-10 21:17 | 显示全部楼层
谢谢分享!!!
回复

使用道具 举报

ID:465279 发表于 2019-1-18 21:21 | 显示全部楼层


好资料,51黑有你更精彩!!
回复

使用道具 举报

ID:477620 发表于 2019-2-18 11:02 | 显示全部楼层
好资料,51黑有你更精彩!!!
回复

使用道具 举报

ID:114907 发表于 2019-3-30 08:25 | 显示全部楼层
多谢分享
回复

使用道具 举报

ID:439239 发表于 2019-5-14 10:26 | 显示全部楼层
谢谢分享谢谢分享
回复

使用道具 举报

ID:403503 发表于 2019-6-6 23:50 | 显示全部楼层
自己用STM单片机做过,解码不灵敏,有时能解不时不行,参考一下楼主的程序,希望能找出问题点
回复

使用道具 举报

ID:550077 发表于 2019-7-7 14:20 | 显示全部楼层
试了很久,没有解码成功,希望有好方法及建议!
回复

使用道具 举报

ID:581591 发表于 2019-7-10 14:08 | 显示全部楼层
好资料,谢谢分享
回复

使用道具 举报

ID:85743 发表于 2019-8-28 10:23 | 显示全部楼层

好资料!正需要学习,谢谢楼主分享!
回复

使用道具 举报

ID:604759 发表于 2019-8-28 15:19 | 显示全部楼层
感谢分享!
回复

使用道具 举报

ID:593904 发表于 2019-8-29 23:34 来自手机 | 显示全部楼层
很好的学习资料
回复

使用道具 举报

ID:630250 发表于 2019-10-25 21:13 | 显示全部楼层
资料不错
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表