找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1897|回复: 0
收起左侧

51单片机红外接收模块数码管显示

[复制链接]
ID:849491 发表于 2021-3-5 10:33 | 显示全部楼层 |阅读模式

实物图

实物图

实物

实物

可接收红外遥控器的键值,用数码管显示。
代码
  1. #include "reg52.h"                         //此文件中定义了单片机的一些特殊功能寄存器
  2.         

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

  5. sbit LSA=P2^0;        //2
  6. sbit LSB=P2^1;        //3
  7. sbit LSC=P2^2;        //4
  8. sbit LSD=P2^3;
  9. sbit LSE=P2^4;
  10. sbit LSF=P2^5;


  11. sbit IRIN=P3^2;

  12. u8 IrValue[6];
  13. u8 Time;

  14. u8 DisplayData[8];
  15. u8 code smgduan[18]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0X6f,0X80};
  16. //0、1、2、3、4、5、6、7、8、9、A、b、C、d、E、F、g,"."的显示码

  17. /*******************************************************************************
  18. * 函 数 名         : delay
  19. * 函数功能                   : 延时函数,i=1时,大约延时10us
  20. *******************************************************************************/
  21. void delay(u16 i)
  22. {
  23.         while(i--);        
  24. }


  25. /*******************************************************************************
  26. * 函数名         :DigDisplay()
  27. * 函数功能                 :数码管显示函数
  28. * 输入           : 无
  29. * 输出                  : 无
  30. *******************************************************************************/
  31. void DigDisplay()
  32. {
  33.         u8 i;
  34.         for(i=0;i<6;i++)  //
  35.         {
  36.                 switch(i)         //位选,选择点亮的数码管,
  37.                 {
  38.                         case(0):
  39.                                 LSA=0;LSB=1;LSC=1;LSD=1;LSE=1;LSF=1; break;//显示第0位        
  40.                         case(1):
  41.                                 LSA=1;LSB=0;LSC=1;LSD=1;LSE=1;LSF=1; break;//显示第1位
  42.                         case(2):
  43.                                 LSA=1;LSB=1;LSC=0;LSD=1;LSE=1;LSF=1; break;//显示第2位
  44.                         case(3):
  45.                                 LSA=1;LSB=1;LSC=1;LSD=0;LSE=1;LSF=1; break;//显示第3位
  46.                         case(4):
  47.                                 LSA=1;LSB=1;LSC=1;LSD=1;LSE=0;LSF=1; break;//显示第4位
  48.                         case(5):
  49.                                 LSA=1;LSB=1;LSC=1;LSD=1;LSE=1;LSF=0; break;//显示第4位


  50.                                  

  51.                 }
  52.                 P0=DisplayData[i];//发送数据
  53.                 P1=DisplayData[i];        //---
  54.                 delay(100); //间隔一段时间扫描        
  55.                 P0=0x00;//消隐
  56.                 P1=0x00;
  57.         }               
  58. }


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

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

  70.         IRIN=1;//初始化端口
  71. }


  72. /*******************************************************************************
  73. * 函 数 名       : main
  74. * 函数功能                 : 主函数
  75. * 输    入       : 无
  76. * 输    出             : 无
  77. *******************************************************************************/
  78. void main()
  79. {        
  80.         IrInit();
  81.         while(1)
  82.         {        
  83.                 DisplayData[0] = smgduan[IrValue[2]/16];                         //smgduan[IrValue[2]/16];
  84.                 DisplayData[1] = smgduan[IrValue[2]%16];                                //smgduan[IrValue[2]%16];
  85.                 DisplayData[2] = smgduan[IrValue[0]/16];
  86.                 DisplayData[3] = smgduan[IrValue[0]/16];
  87.                 DisplayData[4] = smgduan[17];
  88.                 DisplayData[5] = smgduan[16];

  89.             DigDisplay();               
  90.         }               
  91. }

  92. /*******************************************************************************
  93. * 函数名         : ReadIr()
  94. * 函数功能                   : 读取红外数值的中断函数
  95. * 输入           : 无
  96. * 输出                  : 无
  97. *******************************************************************************/

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

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

复制代码

评分

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

查看全部评分

回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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