找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 420|回复: 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, 下载次数: 38)

评分

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

查看全部评分

回复

使用道具 举报

ID:672792 发表于 2024-3-10 16:59 | 显示全部楼层
好资料必须支持,
回复

使用道具 举报

ID:491875 发表于 2024-3-11 08:42 | 显示全部楼层
如果能够增加掉电唤醒功能就可以方便控制接受芯片进入节电模式方便单火线取电功能的实现那就完美了,现在市面上有这个芯片
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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