分享

315兆2262无线模块51单片机解码程序(成功版)

 快乐读书法 2015-12-20
先声明一下,这只是个演示的程序和设备,你真的想拿这个程序去偷别的的什么数据,那还是不可能的事情。
因为我专门在程序结构上做了些文章,处理的速度慢了很多,想得逞,难!


就是这么个东西,下面把程序共享!
  1. #include<reg52.h>
  2. #include <intrins.h>
  3. #define uchar unsigned char

  4. uchar code dis1[] = {" 2262 CODE IS "};
  5. void delay_1s(uchar);
  6. typedef unsigned char BYTE;
  7. typedef unsigned int WORD;
  8. typedef bit BOOL ;
  9. sbit rs = P2^6 ;
  10. sbit rw = P3^6 ;
  11. sbit ep = P2^7 ;

  12. delay(BYTE ms)
  13. {        // 延时子程序
  14. BYTE i;
  15. while(ms--)
  16. {
  17.    for(i = 0; i< 250; i++)
  18.    {
  19.     _nop_();
  20.     _nop_();
  21.     _nop_();
  22.     _nop_();
  23.    }
  24. }
  25. }

  26. BOOL lcd_bz()
  27. {        // 测试LCD忙碌状态
  28. BOOL result;
  29. rs = 0;
  30. rw = 1;
  31. ep = 1;
  32. _nop_();
  33. _nop_();
  34. _nop_();
  35. _nop_();
  36. result = (BOOL)(P0 & 0x80);
  37. ep = 0;
  38. return result;
  39. }

  40. lcd_wcmd(BYTE cmd)
  41. {        // 写入指令数据到LCD
  42. while(lcd_bz());
  43. rs = 0;
  44. rw = 0;
  45. ep = 0;
  46. _nop_();
  47. _nop_();
  48. P0 = cmd;
  49. _nop_();
  50. _nop_();
  51. _nop_();
  52. _nop_();
  53. ep = 1;
  54. _nop_();
  55. _nop_();
  56. _nop_();
  57. _nop_();
  58. ep = 0;  
  59. }

  60. lcd_pos(BYTE pos)
  61. {        //设定显示位置
  62. lcd_wcmd(pos | 0x80);
  63. }

  64. lcd_wdat(BYTE dat)
  65. {        //写入字符显示数据到LCD
  66. while(lcd_bz());
  67. rs = 1;
  68. rw = 0;
  69. ep = 0;
  70. P0 = dat;
  71. _nop_();
  72. _nop_();
  73. _nop_();
  74. _nop_();
  75. ep = 1;
  76. _nop_();
  77. _nop_();
  78. _nop_();
  79. _nop_();
  80. ep = 0;
  81. }

  82. lcd_init()
  83. {        //LCD初始化设定
  84. lcd_wcmd(0x38);    //
  85. delay(1);
  86. lcd_wcmd(0x0c);    //
  87. delay(1);
  88. lcd_wcmd(0x06);    //
  89. delay(1);
  90. lcd_wcmd(0x01);    //清除LCD的显示内容
  91. delay(1);
  92. }
  93. bit T0Action;
  94. bit Action;
  95. bit RECEIVE; //接收标志

  96. sbit P1_7=P1^1;   //接收脚
  97. sbit P3_5=P1^3; //发光二极管

  98. void main()
  99. {
  100. uchar temp,data0,data1,counttime,i=0;
  101. int time,time1,time2;
  102. lcd_init(); // 初始化LCD
  103.    
  104. T0Action=0;
  105. RECEIVE=0;    //接收标志位
  106. Action=0;
  107. TMOD = 0x01;        // 定时器0 工作方式1
  108. TH0=0x00;
  109. TL0=0x00;
  110. P3_5=1;
  111. lcd_pos(0x00);
  112.    while(dis1[i] != '\0')
  113. {       // 显示字符ttnu.com
  114.    lcd_wdat(dis1[i]);
  115.    i++;
  116. }
  117. while(1)              
  118. {
  119.    do{P3_5=1;}while(P1_7==1);
  120.    if((P1_7==0) && (T0Action==0))      //等待低电平,低电平开始记时
  121.      {
  122.        TR0=0; TH0=0x00;   TL0=0x00;   TF0=0;   TR0=1;   T0Action=1;
  123.       while(1)
  124.        {
  125.           if((P1_7==1) && (T0Action==1))
  126.          {
  127.            TR0=0;
  128.            time=TH0*256+TL0;     //记下低电平宽度时间
  129.            T0Action=0;
  130.             break;
  131.           }
  132.         }
  133.        }
  134. if((time>9500) && (time<11500))            //检测同步码约11ms
  135.      {
  136.       counttime=0;
  137.       data0=0;
  138.       data1=0;
  139.       time=0;
  140.       RECEIVE=1;    //检测到同步码时 置标志位 RECEIVE=1
  141.       P3_5=0;                 //绿发光二极管灯亮(调试用)
  142.       }
  143. if(RECEIVE==1)                    //检测到同步码后开始解码
  144.     {
  145.        RECEIVE=0;
  146.     lcd_pos(0x42);
  147.        while(1)
  148.        {
  149.           do{}while(P1_7==1);
  150.           if((P1_7==0) && (T0Action==0))     //等待第一个低电平,一有低电平马上记时
  151.             {
  152.              TR0=0; T0Action=1; TH0=0x00; TL0=0x00; TF0=0; TR0=1;
  153.              while(1)
  154.               {
  155.                 if((P1_7==1) && (T0Action==1))
  156.                  {
  157.                     TR0=0;
  158.                     time=TH0*256+TL0;    //记下第一个低电平宽度时间
  159.                     T0Action=0;
  160.                     TH0=0x00;TL0=0x00; TF0=0;TR0=1;       //开始记高电平时间
  161.                     break;
  162.                   }
  163.                }
  164.              }
  165.            do{}while(P1_7==1);
  166.            if((P1_7==0) && (T0Action==0))       //等待第二个低电平,一有低电平马上记时
  167.             {
  168.               TR0=0;
  169.               time2=TH0*256+TL0;           //记下一个高电平宽度时间
  170.               T0Action=1;
  171.               TH0=0x00; TL0=0x00; TF0=0; TR0=1;
  172.               while(1)
  173.                 {
  174.                   if((P1_7==1) && (T0Action==1))
  175.                     {
  176.                        TR0=0;
  177.                        time1=TH0*256+TL0;       //记下第二个低电平宽度时间
  178.                        T0Action=0; break;
  179.                      }
  180.                 }
  181.             }
  182.            if((time<1500))    //判断两个低电平宽度时间是否相等,限时1500us
  183.                {
  184.                  if(((time-time1)>=-600&&(time-time1)<=600) && (time>780) && (time<1150))    //低电平宽度时间
  185.                   {
  186.                      if((time2>210) && (time2<450))   //高电平宽度时间
  187.                      lcd_wdat('0');temp=0x00;       //0
  188.           }
  189.                  if(((time-time1)>=-600&&(time-time1)<=600) && (time>210) && (time<450))   //低电平宽度时间
  190.                     {         
  191.                         if((time2>780) && (time2<1150))   //高电平宽度时间
  192.                         lcd_wdat('1');temp=0x01;       //1
  193.      
  194.                     }
  195.      if((time>780) && (time<1150)&&(time1>210) && (time1<450))
  196.           lcd_wdat('f');      // f
  197.                counttime++;
  198.       
  199.                  if(counttime<=8)                         //开始接收前8位   地址码
  200.           data0=(data0<<1)|temp;

  201.        else if((counttime>8) && (counttime<=12)) //开始接收后4位 数据码
  202.                     data1=(data1<<1)|temp;
  203.                  if(counttime==12)                     // 第12位
  204.                      {
  205.                       Action=1;
  206.                       break;        //接收完毕,退出解码程序
  207.                      }
  208.         }
  209.     }
  210.     }
  211.    }
  212. }
复制代码


大家在搞之前还是最好把2262发码的时序和结构弄一下。
你真正明白了,做个全段扫描的出来,最好用汇编,那要的解码速度是非常快的。
这些东西,我现在已经实现了。
主要是用来在厂矿搞车辆定位的。
这样就节省了很多买gps的资金。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多