单片机教程网

电脑版
提示:原网页已由神马搜索转码, 内容由www.51hei.com提供.
查看:571|回复:2
打印上一主题下一主题

STC8单片机之EV1527无线433M解码程序

[复制链接]
跳转到指定楼层
#
ID:105206发表于 2024-3-9 22:28|只看该作者回帖奖励
MCU:STC8单片机
解码协议:EV1527
显示:LCD1602

单片机源程序如下:
  1. #include "time.h"
  2. #include "uart.h"
  3. #include "delay.h"
  4. #include "task.h"

  5. ////////////////////////////////
  6. unsigned char decode_ok;        
  7. unsigned int  hh_w,ll_w;      
  8. unsigned char  ma_x;          
  9. unsigned char  bma1,bma2,bma3,bma4;
  10. unsigned char  mma1,mma2,mma3,mma4;
  11. unsigned char mmb1,mmb2,mmb3,mmb4;
  12. //extern uint8_t mmb1,mmb2,mmb3,mmb4;
  13. unsigned char rf_ok1,rf_ok2,rf_ok;      
  14. unsigned char old_rc5;        
  15. unsigned char tb_ok;          
  16. unsigned char D0,D1,D2,D3 ;
  17. unsigned int s ,s1;
  18. unsigned char bt_auto;    
  19. unsigned char rf_data[4];
  20. void rexode_433M(void);
  21. //bit open_led_flag=0;
  22. unsigned char count_5ms=0;
  23.   

  24. extern unsigned char code out[];//LED数组
  25. extern u8 add1,spacing,mode;//地址,间隔时间,模式


  26. //////////////////////////////////////////
  27. void Timer0Init(void)          
  28. {
  29.        TMOD|=0x00;
  30.        TL0=65536-10;                                 //定时10ms
  31.        TH0=(65536-10)>>8;
  32. /////////////////////以下STC12/////////////////////
  33. //           TL0=65536-46;                                 //定时10ms,系统时钟12分频后,定时1的时钟为2.25M,
  34. //           TH0=(65536-46)>>8;
  35.        TR0=1;ET0=1;       //定时器0 ,定时16位模式          
  36.        EA=1;
  37. }
  38. //////////////////////////////////////////
  39. void timer0_interrupt(void) interrupt 1
  40. {

  41.        TL0=(65535-50)%256;                                 //定时50us,
  42.        TH0=(65535-50)/256;
  43.        count_5ms++;
  44.        TX_433M_pin=~TX_433M_pin;
  45.        rexode_433M();
  46. }
  47. //////////////////////////////////////////////
  48. void rexode_433M(void)
  49. {
  50.        if (!RF)
  51.        {
  52.            ll_w++;                
  53.            old_rc5=0;
  54.        }          
  55.        else      
  56.        {
  57.        hh_w++;
  58.        if (!old_rc5)            
  59.        {   // 2/5 100/130
  60.            if (((hh_w>=2)&&(hh_w<=15))&&((ll_w>=160)&&(ll_w<=320)))
  61.            {
  62.                  tb_ok = 1 ;
  63.                  ma_x = 0;
  64.                  bma1=0; bma2=0; bma3=0; bma4=0;  
  65.            }
  66.            else if ((tb_ok)&&((ll_w>=19)&&(ll_w<=33))) //8/13
  67.            {  
  68.                  ma_x++;
  69.                  if(ma_x>23)
  70.                  {
  71.                        if(!rf_ok1)
  72.                        {  
  73.                            mma1=bma1;
  74.                            mma2=bma2;
  75.                            mma3=bma3;
  76.                            mma4=bma4;
  77.                                                                                         
  78.                            rf_ok1=1;              
  79.                            tb_ok=0;
  80.                            s=10000;                    
  81.                            }
  82.                            else
  83.                            {
  84.                                  mmb1=bma1;
  85.                                  mmb2=bma2;
  86.                                  mmb3=bma3;
  87.                                  mmb4=bma4;  
  88.                                                                                       
  89.                                  rf_ok2=1;              
  90.                                  tb_ok=0;                                                
  91.                            }
  92.                        }
  93.                  }  
  94.                  else if ((tb_ok)&&((ll_w>=2)&&(ll_w<=14)))   // 2/7
  95.                  {
  96.                        switch (ma_x)
  97.                        {
  98.                        case 0 : { bma1=bma1 | 0x01; break; }  
  99.                        case 1 : { bma1=bma1 | 0x02; break; }
  100.                        case 2 : { bma1=bma1 | 0x04; break; }
  101.                        case 3 : { bma1=bma1 | 0x08; break; }
  102.                        case 4 : { bma1=bma1 | 0x10; break; }
  103.                        case 5 : { bma1=bma1 | 0x20; break; }
  104.                        case 6 : { bma1=bma1 | 0x40; break; }
  105.                        case 7 : { bma1=bma1 | 0x80; break; }                                
  106.                        case 8 : { bma2=bma2 | 0x01; break; }
  107.                        case 9 : { bma2=bma2 | 0x02; break; }
  108.                        case 10: { bma2=bma2 | 0x04; break; }
  109.                        case 11: { bma2=bma2 | 0x08; break; }
  110.                        case 12: { bma2=bma2 | 0x10; break; }
  111.                        case 13: { bma2=bma2 | 0x20; break; }
  112.                        case 14: { bma2=bma2 | 0x40; break; }
  113.                        case 15: { bma2=bma2 | 0x80; break; }                            
  114.                        case 16: { bma3=bma3 | 0x01; break; }
  115.                        case 17: { bma3=bma3 | 0x02; break; }
  116.                        case 18: { bma3=bma3 | 0x04; break; }
  117.                        case 19: { bma3=bma3 | 0x08; break; }
  118.                        case 20: { bma3=bma3 | 0x10; break; }// ?????1?
  119.                        case 21: { bma3=bma3 | 0x20; break; }
  120.                        case 22: { bma3=bma3 | 0x40; break; }
  121.                        case 23: { bma3=bma3 | 0x80;          
  122.                                        if(!rf_ok1)
  123.                                        {
  124.                                              mma1=bma1;
  125.                                              mma2=bma2;
  126.                                              mma3=bma3;
  127.                                          // mma4=bma4;                                          
  128.                                              rf_ok1=1;      
  129.                                              tb_ok=0;
  130. //                         bt_auto=0;
  131.                                              s=10000;
  132.                                              break;                      
  133.                                        }
  134.                                        else
  135.                                        {
  136.                                              mmb1=bma1;
  137.                                              mmb2=bma2;
  138.                                              mmb3=bma3;
  139.                                            //mmb4=bma4;                        
  140.                                            rf_ok2=1;                        
  141.                                            tb_ok=0;
  142.                                            break;                                                  
  143.                                        }                        
  144.                                  }
  145.                }
  146.                ma_x++;
  147.              }
  148.              else
  149.              {ma_x=0; tb_ok=0;bt_auto=0;bma1=0;bma2=0; bma3=0; hh_w=1;ll_w=0;}                        
  150.              ll_w=0;hh_w=1;
  151.          }      
  152.          old_rc5=1;    
  153.      }
  154.      if(rf_ok1)  
  155.        {
  156.          s--;
  157.          if(!s) rf_ok1=0;
  158.          if(rf_ok2)
  159.          {
  160.          if((mma1==mmb1)&&(mma2==mmb2)&&(mma3==mmb3))
  161.          {
  162.            rf_ok=1;
  163.            rf_ok1=0;
  164.            rf_ok2=0;              
  165.          }
  166.          else
  167.          {
  168.            rf_ok=0;
  169.            rf_ok1=0;
  170.            rf_ok2=0;

  171.          }      
  172.        }            
  173.    }
  174.    if((rf_ok))    
  175.    {  
  176.        TR0=0;
  177.        rf_ok=0;
  178.        rf_data[0]=mma1;
  179.        rf_data[1]=mma2;
  180.        rf_data[2]=mma3;
  181.            SendOneByte(rf_data[0]);
  182.            SendOneByte(rf_data[1]);
  183.            SendOneByte(rf_data[2]);
  184.        decode_ok=1;
  185.        TR0=1;
  186.    }
  187. }

  188. ////////////////////////////////////////////
  189. void EV1527_decoding()
  190. {
  191.        char i=0;
  192.        /////////////////解码值////////////////////////////////
  193.            if(decode_ok)
  194.            {
  195.                  decode_ok=0;
  196.                  switch(rf_data[2])
  197.                  {          
  198.                        case  0x19: OUT1=~OUT1;rf_data[2]=0;break;//1号键
  199.                        case  0x29: OUT2=~OUT2;rf_data[2]=0;break;
  200.                        case  0x49: OUT3=~OUT3;rf_data[2]=0;break;
  201.                        case  0x89: OUT4=~OUT4;rf_data[2]=0;break;
  202.                        case  0x39: OUT5=~OUT5;rf_data[2]=0;break;
  203.                        case  0x59: OUT6=~OUT6;rf_data[2]=0;break;
  204.                        case  0xa9: OUT7=~OUT7;rf_data[2]=0;break;
  205.                        case  0x69: OUT8=~OUT8;rf_data[2]=0;break;
  206.                        case  0x79: OUT9=~OUT9;rf_data[2]=0;break;
  207.                        case  0xe9: OUT10=~OUT10;rf_data[2]=0;break;//10号键
  208. /////////////11键亮(流水)/////////12键灭(流水)////////////////////////////////////////////
  209.                        case 0X99:   //解码           遥控器11键
  210.                        {
  211.                            delay_ms(1);
  212.                            led=out[i];//led灯开始往后面亮delay_ms(2);//led灯开始往后面亮      
  213.                            i++;          
  214.                            delay_ms(spacing*100);          
  215.                            if(i>8)//如果led灯亮完了
  216.                            {
  217.                                 
  218.                                  i=8;
  219.                                  led=0xff;rf_data[2]=0;                            
  220.                            }
  221.                        }break;                          
  222.                        case 0Xd9:   //解码           遥控器12键
  223.                        {      
  224.                            delay_ms(1);
  225.                            led=out[i];//灭-》灭                                          
  226.                            i--;                
  227.                            delay_ms(spacing*100);                                                                
  228.                            if(i<0)
  229.                            {
  230.                                 
  231.                                  i=0;led=0x00; //p35=1;
  232.                                  rf_data[2]=0;
  233.                            }                      
  234.                        }break;

  235.                  }
  236.                 
  237.            }
  238.                 


  239.       
  240. }

复制代码



#include "time.h"
#include "uart.h"
#include "LCD1602.h"
#include "delay.h"
#include "key.h"
#include "task.h"
///////////////////////////////////////////////////////
extern u8       xdata U1RxBuf[];
extern u8 add;
extern bit flag;
extern unsigned char Uartflag ;                   //UART判断标志位
extern char Recive_state ;   //接收完成标志
/********************************************************************
                   主函数
*********************************************************************/
void main()
{      
       InitUART();
       Timer0Init();
///////////////配置端口为双向口////////////////////////
       P1M0=0X00;
       P1M1=0X00;
       P2M0=0X00;
       P2M1=0X00;
       P3M0=0X00;
       P3M1=0X00;
       Init_LCD1602();;//lcd初始化      
       delay_ms(10);
       LCD_Clear();       //清屏
//////////////////////LOGO///////////////////////////
       LCD1602_write_com(0x80);           //指针指向第1行第0个位置
       LCD1602_write_word("     BLD     ");//宝蕾德电子产品
       LCD1602_write_com(0x80+0x40);       //指针指向第2行第0个位置
       LCD1602_write_word("0~10s APPLE:S118");
       delay_ms(100);      
       LCD_Clear();//清屏
       LCD1602_write_com(0x80);           //指针指向第1行第0个位置
       LCD1602_write_word("             ");      
       LCD1602_write_com(0x80+0x40);       //指针指向第2行第0个位置
       LCD1602_write_word("spacing:   s~   ");       //      
//       spacing=IapRead(0x0000);       //EEPROM  读0x0000到hc[0]
//       add1=IapRead(0x0002);       //EEPROM  读0x0002到hc[1]
//       mode=IapRead(0x0004);       //EEPROM  读0x0002到hc[2]
       delay_ms(2);
       spacing_data();      
       P2=0x00;
       while(1)   //无限循环
       {
           EV1527_decoding();//解码
           display_zhu();
       }
}      

原理图: 无
仿真: 无
代码: STC8-解码433M EV1527 串口发送OK版.rar(84.37 KB, 下载次数: 46)

评分

黑币 +70
收起理由
+ 70
共享资料的黑币奖励!

查看全部评分

沙发
ID:491875发表于 2024-3-11 08:42|只看该作者
如果能够增加掉电唤醒功能就可以方便控制接受芯片进入节电模式方便单火线取电功能的实现那就完美了,现在市面上有这个芯片
楼主
ID:672792发表于 2024-3-10 16:59|只看该作者
好资料必须支持,

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

Powered by 单片机教程网