找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机红外通信程序

[复制链接]
跳转到指定楼层
楼主
红外通信接线图:


单片机源程序如下:
  1. /**************************************************************************************
  2. *                              红外通信实验                                                                                                  *
  3. 实现现象:        具体接线操作请参考视频
  4.                         下载程序后,数码管显示红外遥控键值数据
  5. 注意事项:        红外遥控模块的短接片J1短接,
  6.                         红外遥控器内的电池绝缘片一定要抽掉                                                                                                                                                          
  7. ***************************************************************************************/

  8. #include "reg52.h"                         //此文件中定义了单片机的一些特殊功能寄存器
  9.        

  10. typedef unsigned int u16;          //对数据类型进行声明定义
  11. typedef unsigned char u8;

  12. sbit LSA=P2^2;
  13. sbit LSB=P2^3;
  14. sbit LSC=P2^4;

  15. sbit IRIN=P3^2;

  16. u8 IrValue[6];
  17. u8 Time;

  18. u8 DisplayData[8];
  19. u8 code smgduan[17]={
  20. 0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
  21. 0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0X76};
  22. //0、1、2、3、4、5、6、7、8、9、A、b、C、d、E、F、H的显示码

  23. /*******************************************************************************
  24. * 函 数 名         : delay
  25. * 函数功能                   : 延时函数,i=1时,大约延时10us
  26. *******************************************************************************/
  27. void delay(u16 i)
  28. {
  29.         while(i--);       
  30. }


  31. /*******************************************************************************
  32. * 函数名         :DigDisplay()
  33. * 函数功能                 :数码管显示函数
  34. * 输入           : 无
  35. * 输出                  : 无
  36. *******************************************************************************/
  37. void DigDisplay()
  38. {
  39.         u8 i;
  40.         for(i=0;i<3;i++)
  41.         {
  42.                 switch(i)         //位选,选择点亮的数码管,
  43.                 {
  44.                         case(0):
  45.                                 LSA=0;LSB=0;LSC=0; break;//显示第0位
  46.                         case(1):
  47.                                 LSA=1;LSB=0;LSC=0; break;//显示第1位
  48.                         case(2):
  49.                                 LSA=0;LSB=1;LSC=0; break;//显示第2位       
  50.                 }
  51.                 P0=DisplayData[i];//发送数据
  52.                 delay(100); //间隔一段时间扫描       
  53.                 P0=0x00;//消隐
  54.         }               
  55. }


  56. /*******************************************************************************
  57. * 函数名         : IrInit()
  58. * 函数功能                   : 初始化红外线接收
  59. * 输入           : 无
  60. * 输出                  : 无
  61. *******************************************************************************/

  62. void IrInit()
  63. {
  64.         IT0=1;//下降沿触发
  65.         EX0=1;//打开中断0允许
  66.         EA=1;        //打开总中断

  67.         IRIN=1;//初始化端口
  68. }


  69. /*******************************************************************************
  70. * 函 数 名       : main
  71. * 函数功能                 : 主函数
  72. * 输    入       : 无
  73. * 输    出             : 无
  74. *******************************************************************************/
  75. void main()
  76. {       
  77.         IrInit();
  78.         while(1)
  79.         {       
  80.                 DisplayData[0] = smgduan[IrValue[2]/16];
  81.                 DisplayData[1] = smgduan[IrValue[2]%16];
  82.                 DisplayData[2] = smgduan[16];
  83.             DigDisplay();               
  84.         }               
  85. }

  86. /*******************************************************************************
  87. * 函数名         : ReadIr()
  88. * 函数功能                   : 读取红外数值的中断函数
  89. * 输入           : 无
  90. * 输出                  : 无
  91. *******************************************************************************/

  92. void ReadIr() interrupt 0
  93. {
  94.         u8 j,k;
  95.         u16 err;
  96.         Time=0;                                         
  97.         delay(700);        //7ms
  98.         if(IRIN==0)                //确认是否真的接收到正确的信号
  99.         {         
  100.                
  101.                 err=1000;                                //1000*10us=10ms,超过说明接收到错误的信号
  102.                 /*当两个条件都为真是循环,如果有一个条件为假的时候跳出循环,免得程序出错的时
  103.                 侯,程序死在这里*/       
  104.                 while((IRIN==0)&&(err>0))        //等待前面9ms的低电平过去                 
  105.                 {                       
  106.                         delay(1);
  107.                         err--;
  108.                 }
  109.                 if(IRIN==1)                        //如果正确等到9ms低电平
  110.                 {
  111.                         err=500;
  112.                         while((IRIN==1)&&(err>0))                 //等待4.5ms的起始高电平过去
  113.                         {
  114.                                 delay(1);
  115.                                 err--;
  116.                         }
  117.                         for(k=0;k<4;k++)                //共有4组数据
  118.                         {                               
  119.                                 for(j=0;j<8;j++)        //接收一组数据
  120.                                 {

  121.                                         err=60;               
  122.                                         while((IRIN==0)&&(err>0))//等待信号前面的560us低电平过去
  123.                                         {
  124.                                                 delay(1);
  125.                                                 err--;
  126.                                         }
  127.                                         err=500;
  128.                                         while((IRIN==1)&&(err>0))         //计算高电平的时间长度。
  129.                                         {
  130.                                                 delay(10);         //0.1ms
  131.                                                 Time++;
  132.                                                 err--;
  133.                                                 if(Time>30)
  134.                                                 {
  135.                                                         return;
  136.                                                 }
  137.                                         }
  138.                                         IrValue[k]>>=1;         //k表示第几组数据
  139.                                         if(Time>=8)                        //如果高电平出现大于565us,那么是1
  140.                                         {
  141.                                                 IrValue[k]|=0x80;
  142.                                         }
  143.                                         Time=0;                //用完时间要重新赋值                                                       
  144.                                 }
  145.                         }
  146.                 }
  147.                 if(IrValue[2]!=~IrValue[3])
  148.                 {
  149.                         return;
  150.                 }
  151.         }                       
  152. }

复制代码

所有资料51hei提供下载:
程序.rar (21.71 KB, 下载次数: 12)


评分

参与人数 1黑币 +8 收起 理由
xiou + 8 很给力!

查看全部评分

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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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