找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5205|回复: 1
打印 上一主题 下一主题
收起左侧

单片机红外线发射接收电路+源程序与Proteus仿真图

  [复制链接]
跳转到指定楼层
楼主
仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


单片机源程序如下:
  1. /***************************************************************
  2.         作品:红外线发射
  3.   单片机:STC89C52RC
  4.     晶振:12M
  5. 编译环境:Keil uVision4 V9.00
  6. ***************************************************************/
  7. //
  8. //        发射引脚(接PNP三极管b极)
  9. //        PNP三极管e极接2Ω电阻,c极接红外发射管
  10.      
  11. #include <REG51.h>
  12. #include <intrins.h>
  13. #define uchar unsigned char
  14. #define uint  unsigned int

  15. #define SBM   0x80                //识别码

  16. #define m9    (65536-9000)               //约9mS
  17. #define m4_5  (65536-4500)               //约4.5mS
  18. #define m1_6  (65536-1630)               //约1.65mS
  19. #define m_65  (65536-580)               //约0.65mS
  20. #define m_56  (65536-560)               //约0.56mS
  21. #define m40   (65536-40000)       //约40mS
  22. #define m56   (65536-56000)       //56mS
  23. #define m2_25 (65536-2250)        //约2.25mS

  24. sbit IR  = P3^6;                                  //定义发射引脚(接PNP三极管基极)
  25. sbit LED = P3^7;                                  //发射指示灯

  26. uchar KEY(void);
  27. void  SanZhuan(void);
  28. void  ZZ(uchar x);
  29. void  Z0(uchar temp);
  30. void  TT0(bit BT,uint x);
  31. void  YS(uchar time);

  32. /*┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈
  33. 函数功能:主函数
  34. ┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈*/
  35. void main(void)
  36. {

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

  39.   while(1)
  40.   {
  41.    SanZhuan();
  42.   }
  43. }
  44. /***************************************************************
  45. 函数功能:             4×4矩阵键盘
  46.                            键值                    
  47. P1.0 P1.1 P1.2 P1.3 P1.4 P1.5 P1.6 P1.7
  48. │     │    │    │    │    │    │    │    ┃
  49. │     │    │    └────13   14   15   16   ┃   
  50. │     │    └─────────9    10   11   12   ┃   
  51. │     └──────────────5    6    7    8    ┃   
  52. └────────────────────1    2    3    4    ┃  
  53. ***************************************************************/
  54. uchar KEY(void)
  55. {
  56. uchar H,L;            //行值,列值
  57. H=0;
  58. L=0;
  59. P1 = 0xf0;            //将键盘端口行值设为1,列值设为0
  60. if(P1!= 0xf0)         //检测是否有按键按下,如果有则hangval必不为0x0f
  61.    {
  62.     YS(10);            //按键去抖动,延时10毫秒
  63.     if(P1!=0xf0)       //确实有按键按下
  64.       {
  65.        H  = P1&0xf0;   //按键后得到按键的行标志位,将行标志位赋值给hangval
  66.        P1 = 0x0f;      //翻转键盘接口输出
  67.        L  = P1&0x0f;   //得到列标志位
  68.       }
  69.         return (H+L);
  70.    }
  71.   return 0;
  72. }
  73. /***************************************************************
  74. 函数功能:散转程序
  75. 入口参数:v
  76. //
  77. //  13 14 15 16
  78. //  9  10 11 12
  79. //  5  6  7  8
  80. //  1  2  3  4
  81. ***************************************************************/
  82. void SanZhuan(void)
  83. {
  84. uchar v;
  85. v = KEY();

  86. switch(v)
  87. {
  88.   case 0x77:ZZ(0x01);v=0;break;                //"  "
  89.   case 0xb7:ZZ(0x02);v=0;break;                //"  "
  90.   case 0xd7:ZZ(0x03);v=0;break;                //"  "
  91.   case 0xe7:ZZ(0x04);v=0;break;                //"  "
  92.   case 0x7b:ZZ(0x05);v=0;break;                //"  "
  93.   case 0xbb:ZZ(0x06);v=0;break;                //"  "
  94.   case 0xdb:ZZ(0x07);v=0;break;                //"  "
  95.   case 0xeb:ZZ(0x08);v=0;break;                //"  "
  96.   case 0x7d:ZZ(0x09);v=0;break;                //"  "
  97.   case 0xbd:ZZ(0x10);v=0;break;                //"  "
  98.   case 0xdd:ZZ(0x11);v=0;break;                //"  "
  99.   case 0xed:ZZ(0x12);v=0;break;                //"  "
  100.   case 0x7e:ZZ(0x13);v=0;break;                //"  "
  101.   case 0xbe:ZZ(0x14);v=0;break;                //"  "
  102.   case 0xde:ZZ(0x15);v=0;break;                //"  "
  103.   case 0xee:ZZ(0x16);v=0;break;                //"  "
  104.   default:v=0;
  105. }
  106. }
  107. /*┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈
  108. 函数功能:发送主程序
  109. ┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈*/
  110. void ZZ(uchar x)
  111. {
  112.   TT0(1,m9);                   //高电平9mS
  113.   TT0(0,m4_5);               //低电平4.5mS

  114.   /*┈ 发送4帧数据 ┈*/
  115.   Z0(SBM);                                                                                                                                       
  116.   Z0(~SBM);
  117.   Z0(x);
  118.   Z0(~x);

  119.   /*┈┈ 结束码 ┈┈*/
  120.   TT0(1,m_65);
  121.   TT0(0,m40);

  122.   /*┈┈ 重复码 ┈┈*/
  123.   while(KEY())
  124.    {
  125.         TT0(1,m9);
  126.         TT0(0,m2_25);

  127.         TT0(1,m_56);
  128.         TT0(0,m40);
  129.                 TT0(0,m56);
  130.                
  131.                 LED = !LED;                  //指示灯                                          
  132.     }

  133.    LED = 1;                    

  134. }
  135. /*┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈
  136. 函数功能:单帧发送程序
  137. 入口参数:1帧数据
  138. ┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈*/
  139. void Z0(uchar temp)
  140. {
  141.   uchar v;
  142.   for (v=0;v<8;v++)                     //循环8次移位
  143.        {     
  144.                  TT0(1,m_65);                        //高电平0.65mS         
  145.                          if(temp&0x01) TT0(0,m1_6); //发送最低位
  146.                          else          TT0(0,m_56);     
  147.                          temp >>= 1;                //右移一位
  148.         }   
  149. }

  150. /*┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈
  151. 函数功能:38KHz脉冲发射 + 延时程序
  152. 入口参数:(是否发射脉冲,延时约 x (uS))
  153. ┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈┈*/
  154. void TT0(bit BT,uint x)
  155. {
  156.   TH0 = x>>8;                    //输入T0初始值
  157.   TL0 = x;
  158.   TF0=0;                                //清0
  159.   TR0=1;                                //启动定时器0
  160.   if(BT == 0) while(!TF0);        //BT=0时不发射38KHz脉冲只延时;BT=1发射38KHz脉冲且延时;
  161.   else while(1)                            //38KHz脉冲,占空比5:26
  162.          {
  163.                   IR = 0;
  164.                   if(TF0)break;
  165.                if(TF0)break;
  166.                   IR = 1;
  167.                 if(TF0)break;
  168.                  if(TF0)break;
  169. ……………………

  170. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
红外线遥控Proteus仿真电路+发射+接收程序.7z (1.19 MB, 下载次数: 116)

评分

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

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏9 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:724172 发表于 2020-8-20 15:26 | 只看该作者
这对于我这初学者还蛮难理解的。不过也要赞一下
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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