找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 11803|回复: 6
收起左侧

单片机红外无线通信Proteus仿真+发送与接收程序

  [复制链接]
ID:237897 发表于 2018-12-4 09:13 | 显示全部楼层 |阅读模式
红外无线通信仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
51hei.png
0.png
红外无线发射/接收器

灯光模拟:有光电阻小,无光电阻大

单片机源程序如下(发送程序):
  1. #include <REG51.h>
  2. #include <intrins.h>
  3. #include "hongwaifashe.h"

  4. void hongwaifashe(void)
  5. {

  6.   TMOD = 0x01;         //T0 16位工作方式
  7.   IR=1;                                   //发射端口常态为高电平

  8. ZZ(setdata[0]);
  9. ZZ(setdata[1]);
  10. }


  11.   void ZZ(uchar x)
  12. {
  13.   TT0(1,m9);                   //高电平9mS
  14.   TT0(0,m4_5);               //低电平4.5mS

  15.   /*┈ 发送4帧数据 ┈*/
  16.   Z0(SBM);                                                                                                                                       
  17.   Z0(~SBM);
  18.   Z0(x);
  19.   Z0(~x);

  20.   /*┈┈ 结束码 ┈┈*/
  21.   TT0(1,m_56);
  22.   TT0(0,m40);
  23. }/*┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈
  24. 函数功能:单帧发送程序
  25. 入口参数:1帧数据
  26. ┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈*/
  27. void Z0(uchar temp)
  28. {
  29.   uchar v;
  30.   for (v=0;v<8;v++)                     //循环8次移位
  31.        {     
  32.                  TT0(1,m_56);                        //高电平0.65mS         
  33.                          if(temp&0x01) TT0(0,m1_68); //发送最低位
  34.                          else          TT0(0,m_56);     
  35.                          temp >>= 1;                //右移一位
  36.         }   
  37. }

  38. /*┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈
  39. 函数功能:38KHz脉冲发射 + 延时程序
  40. 入口参数:(是否发射脉冲,延时约 x (uS))
  41. ┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈*/
  42. void TT0(bit BT,uint x)
  43. {
  44.   TH0 = x>>8;                    //输入T0初始值
  45.   TL0 = x;
  46.   TF0=0;                                //清0
  47.   TR0=1;                                //启动定时器0
  48.   if(BT == 0) while(!TF0);        //BT=0时不发射38KHz脉冲只延时;BT=1发射38KHz脉冲且延时;
  49.   else while(1)                            //38KHz脉冲,占空比5:26
  50.          {
  51.                   IR = 0;
  52.                   if(TF0)break;
  53.                if(TF0)break;
  54.                   IR = 1;
  55.                 if(TF0)break;
  56.                  if(TF0)break;
  57.                  if(TF0)break;
  58.                   if(TF0)break;
  59.                  if(TF0)break;
  60.                  if(TF0)break;
  61.                  if(TF0)break;
  62.                  if(TF0)break;
  63.                  if(TF0)break;
  64.                   if(TF0)break;
  65.                  }
  66.   TR0=0;                                //关闭定时器0
  67.   TF0=0;                                //标志位溢出则清0

  68.   IR =1;                                //脉冲停止后,发射端口常态为高电平
  69. }
复制代码


接受程序:
  1. #include<reg52.h>
  2. #include"12864.h"
  3. #include<intrins.h>  //包含_nop_()函数定义的头文件
  4. sbit IR=P3^2;           //将IR位定义为P3.2引脚
  5. unsigned char a[4];    //储存用户码、用户反码与键数据码、键数据反码
  6. unsigned char zai=0,om,pm,qm;

  7. unsigned int LowTime,HighTime; //储存高、低电平的宽度
  8. void fenjie()
  9. {        
  10.   if(a[2]==0x80)
  11.      zai=0;
  12.           else if(a[2]==0xc0)
  13.           zai=1;
  14.            else
  15.                    {
  16.                      om=a[2]/100;
  17.                          pm=a[2]/10%10;
  18.                          qm=a[2]%100%10;
  19.                    }
  20.    
  21. }
  22. bit DeCode(void)        
  23. {
  24.    
  25.    unsigned char  i,j;
  26.         unsigned char temp;    //储存解码出的数据
  27.         for(i=0;i<4;i++)      //连续读取4个用户码和键数据码
  28.           {
  29.                  for(j=0;j<8;j++)  //每个码有8位数字
  30.                          {
  31.                  temp=temp>>1;  //temp中的各数据位右移一位,因为先读出的是高位数据                                                                        
  32.                            TH0=0;         //定时器清0
  33.                            TL0=0;         //定时器清0
  34.                            TR0=1;         //开启定时器T0
  35.                       while(IR==0)   //如果是低电平就等待
  36.                        ;              //低电平计时
  37.                              TR0=0;         //关闭定时器T0
  38.                            LowTime=TH0*256+TL0;    //保存低电平宽度
  39.                            TH0=0;         //定时器清0
  40.                            TL0=0;         //定时器清0
  41.                            TR0=1;         //开启定时器T0
  42.                           while(IR==1)   //如果是高电平就等待
  43.                                ;                           
  44.                            TR0=0;        //关闭定时器T0
  45.                            HighTime=TH0*256+TL0;   //保存高电平宽度
  46.                            if((LowTime<360)||(LowTime>680))   
  47.                                               return 0;        //如果低电平长度不在合理范围,则认为出错,停止解码                        
  48.                            if((HighTime>400)&&(HighTime<680))   //如果高电平时间在560微秒左右,即计数560/1.085=516次
  49.                                    temp=temp&0x7f;       //(520-100=420, 520+100=620),则该位是0
  50.                            if((HighTime>1400)&&(HighTime<1850)) //如果高电平时间在1680微秒左右,即计数1680/1.085=1548次
  51.                                    temp=temp|0x80;       //(1550-250=1300,1550+250=1800),则该位是1
  52.                      }                                      
  53.            a[i]=temp;        //将解码出的字节值储存在a[i]                                                                                                                                                                        
  54.     }                                                   
  55.   if(a[2]=~a[3])  //验证键数据码和其反码是否相等,一般情况下不必验证用户码
  56.          return 1;     //解码正确,返回1
  57. }
  58. void init(void)
  59. {
  60.     E=1;
  61.         CS1=0;CS2=0;         
  62.     lcd_clear();
  63.     lcd_init();
  64.         EA=1;        //开启总中断
  65.   
  66.    ET0=1;       //定时器T0中断允许
  67.    IT0=1;       //外中断的下降沿触发  
  68.     TMOD=0x01;   //使用定时器T0的模式1        
  69.         TR0=0;       //定时器T0关闭
  70.   EX0=1;       //开外中断0
  71.   
  72. }
  73. void display()
  74. {
  75.    CS1=0;
  76.          CS2=1;
  77.    lcd_mwc(0xb8);        // 无线环境监测
  78.    lcd_mwc(0x50);
  79.    dispm_zi_up(&WUYOU[0][0]);
  80.    dispm_zi_up(&XIAN);
  81.    dispm_zi_up(&HUAN);
  82.    
  83.   

  84.    lcd_mwc(0xb9);
  85.    lcd_mwc(0x50);
  86.    dispm_zi_down(&WUYOU[0][0]);
  87.    dispm_zi_down(&XIAN);
  88.    dispm_zi_down(&HUAN);
  89.   

  90.    lcd_mwc(0xba);        // 温度
  91.    lcd_mwc(0x40);
  92.    dispm_zi_up(&WEN);
  93.    dispm_zi_up(&DU);
  94.    dispm_zi_up(&MAOHAO);
  95.    dispm_zi_up(&SHUZI[om][0]);
  96.   



  97.    lcd_mwc(0xbb);
  98.    lcd_mwc(0x40);
  99.    dispm_zi_down(&WEN);
  100.    dispm_zi_down(&DU);
  101.    dispm_zi_down(&MAOHAO);
  102.    dispm_zi_down(&SHUZI[om][0]);
  103.   

  104.    lcd_mwc(0xbc);                 //亮度
  105.    lcd_mwc(0x40);
  106.    dispm_zi_up(&LIANG);
  107.    dispm_zi_up(&DU);
  108.    dispm_zi_up(&MAOHAO);

  109.   

  110.    lcd_mwc(0xbd);
  111.    lcd_mwc(0x40);
  112.    dispm_zi_down(&LIANG);
  113.    dispm_zi_down(&DU);
  114.    dispm_zi_down(&MAOHAO);
  115.   
  116.                   CS1=1;
  117.                 CS2=0;
  118.    lcd_mwc(0xb8);        // 无线环境监测
  119.    lcd_mwc(0x40);
  120.    dispm_zi_up(&JING);
  121.    dispm_zi_up(&JIAN);
  122.    dispm_zi_up(&CE);

  123.         lcd_mwc(0xb9);
  124.     lcd_mwc(0x40);
  125.     dispm_zi_down(&JING);
  126.     dispm_zi_down(&JIAN);
  127.     dispm_zi_down(&CE);

  128.         lcd_mwc(0xba);        // 温度
  129.     lcd_mwc(0x40);
  130.         dispm_zi_up(&SHUZI[pm][0]);
  131.     dispm_zi_up(&SHUZI[qm][0]);
  132.     dispm_zi_up(&DUHAO);

  133.         lcd_mwc(0xbb);
  134.     lcd_mwc(0x40);
  135.     dispm_zi_down(&SHUZI[pm][0]);
  136.     dispm_zi_down(&SHUZI[qm][0]);
  137.     dispm_zi_down(&DUHAO);

  138.         lcd_mwc(0xbc);                 //亮度
  139.     lcd_mwc(0x40);
  140.         dispm_zi_up(&WUYOU[zai][0]);

  141.         lcd_mwc(0xbd);
  142.     lcd_mwc(0x40);
  143.     dispm_zi_down(&WUYOU[zai][0]);         

  144. }
  145. void main(void)
  146. {               
  147.     init();
  148.         while(1)
  149.         {
  150.            // fenjie();
  151.           display();


  152.     }

  153. }


  154. /************************************************************
  155. 函数功能:红外线触发的外中断处理函数
  156. *************************************************************/
  157. void Int0(void) interrupt 0
  158.   {         
  159.      EX0=0;      //关闭外中断0,不再接收二次红外信号的中断,只解码当前红外信号
  160.           TH0=0;      //定时器T0的高8位清0
  161.          TL0=0;      //定时器T0的低8位清0
  162.           TR0=1;            //开启定时器T0         
  163.           while(IR==0);          //如果是低电平就等待,给引导码低电平计时
  164.           TR0=0;                //关闭定时器T0     
  165.           LowTime=TH0*256+TL0;  //保存低电平时间
  166.           if(((LowTime>8500)&&(LowTime<9500))!=1) {EX0=1;return;}
  167.           TH0=0;      //定时器T0的高8位清0
  168.           TL0=0;      //定时器T0的低8位清0
  169.         fenjie();   TR0=1;            //开启定时器T0
  170. while(IR==1);  //如果是高电平就等待,给引导码高电平计时
  171.          
  172.          
  173.           TR0=0;        //关闭定时器T0
  174.           HighTime=TH0*256+TL0;        //保存引导码的高电平长度
  175.   if((HighTime>4000)&&(HighTime<5000))
  176.                 {         
  177.                         DeCode();
  178.                    fenjie();     
  179.                  
  180.           }
  181.                   
  182.         EX0=1;

  183.   }
复制代码

所有资料51hei提供下载:
红外无线通信.zip (146.29 KB, 下载次数: 245)

评分

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

查看全部评分

回复

使用道具 举报

ID:313328 发表于 2018-12-4 17:08 | 显示全部楼层
吸纳收藏了
回复

使用道具 举报

ID:513023 发表于 2019-11-1 12:19 | 显示全部楼层
资料不错,可供参考
回复

使用道具 举报

ID:693722 发表于 2020-3-1 21:59 | 显示全部楼层
有没有其他的无线通信方式可以仿真?或者有什么小技巧
回复

使用道具 举报

ID:731614 发表于 2020-4-19 13:20 | 显示全部楼层
本帖最后由 deardlrb 于 2020-4-20 11:40 编辑

有原理图吗...在线等
请问dsn格式如何用protues打开啊?

回复

使用道具 举报

ID:247623 发表于 2021-6-13 00:04 | 显示全部楼层
我用这个仿真设计,发现实物焊接显示屏显示不了数字,求教大家,如何排查问题
回复

使用道具 举报

ID:1069596 发表于 2023-4-3 01:40 | 显示全部楼层
"hongwaifashe.h"在哪里?
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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