当前位置:首页 > 单片机 > 单片机
[导读]正点原子的ALIENTEK遥控器用户码00ff16进制键值码表45 46 4744 40 4307 15 0916 19 0d0c 18 5e08 1c 5a42? 4a红外接收管 通用型即可---------------------------------------------------------------------------下

正点原子的ALIENTEK遥控器

用户码00ff

16进制键值码表
45 46 47
44 40 43
07 15 09
16 19 0d
0c 18 5e
08 1c 5a
42? 4a

红外接收管 通用型即可


---------------------------------------------------------------------------

下面是类似的波形图,这个是网上找的,图片较大,缩小后看上去有些模糊,不过没关系,数据手册上一般都有



遥控器在发射红外信号之前,我们的mcu已经开启了定时器
在定时器中断函数中的全局变量irTimeCounts++ 一直在自加
irTimeCounts多长时间加一次? 或者说多长时间进入一次定时器中断函数呢?
在方式2时,t=256*12/11059200 约为277.78us
============================================================
1.对于1.125ms的时间,timer0会中断1.125/t=4.05次 也就是要5次,算上各种误差,(顶多5次,至少4次)
2.对于2.25ms 的时间,timer0会中断 2.25/t=8.1次, 也就是要9次,算上各种误差,(顶多9次,至少8次)
对于这里的次数,比N次小一点,就是N次,比N次大一点,就是N+1次,因为不会有半次,
误差给它正负0.4次足够了,给了误差后再算次数,直接舍入就行

那么我们就检测irTimeCounts的值,
如果小于6或7,那么接收到的数据为0
如果大于6或7,那么接收到的数据为1

从计算结果来看,我觉得0.56,1.125,2.25这些值的出现是比较合理的,
能有效避免由于器件误差和环境造成的数据误判,而且计算也方便

C代码

#include"my51.h"

#include"ir.h"

#include"smg.h"

voidmain()

{

timer0Init();//定时器0初始化

int0Init();//外部中断0初始化

while(1)

{

if(irTimeCountsArrProcess())//如果成功接收并解析完成一帧数据

{//就让蜂鸣器响一下

beep=0;//蜂鸣器开启

led4=~led4;//4号灯反转一下

}

displaySMG(irCodeByteDataProcessForSmg());//显示

beep=1;//蜂鸣器关闭

//由于displaySMG()函数执行时间较短,故蜂鸣器响声时间也较短,听到滴了一下

}

}

C代码

#ifndef_51IR_H_

#define_51IR_H_

#include"my51.h"

externu8datasmgWela[7];//数码管显示的数据

externvoidint0Init();//外部中断0初始化

externvoidtimer0Init();//定时器0初始化

externboolirTimeCountsArrProcess();//成功解析一帧中断数据返回TRUE

externu8*irCodeByteDataProcessForSmg();//将遥控器码值处理成数码管可显示数据

#endif

C代码

#include"ir.h"

u8irTimeCounts=0;//定时器0在方式2下8位自动重装时的中断计数值

u8irTimeCountsArr[32]={0};//存放红外接收数据时的中断次数记录值,

u8bitNum=0;//标志当前接收的是第几个比特位

u8irReceFlag=0;//红外接收一帧数据未完成标志,为1时完成

u8irCodeByteData[4]={0};//保存接收到的4个字节的有效数据

u8irTimeCountsArrProcessOk=0;//对接收到的33位数据处理未完成标志,1完成

voidint0Init();//外部中断0初始化

voidtimer0Init();//定时器0初始化

boolirTimeCountsArrProcess();//解析中断次数,即解码

u8*irCodeByteDataProcessForSmg();//将遥控器码值处理成数码管可显示数据

u8*irCodeByteDataProcessForSmg()//将解码的4字节数据处理成数码管可显示的数据

{

if(irTimeCountsArrProcessOk)//检测一帧数据是否解析完成

{

//这里的用户码只显示低八位,因为高八位反正都是00(手上2个遥控器都是00)

//然后还显示遥控键值及其反码,我们的数码管只有6位,只显示3字节数据

if(irCodeByteData[2]+irCodeByteData[3]!=0xff)//校验数据的完整性

{//最后一个字节是键码的反码

led6=0;//调试代码

}

else

{

smgWela[0]=irCodeByteData[1]>>4;//取高4位

smgWela[1]=irCodeByteData[1]&0x0f;//取低4位

smgWela[2]=irCodeByteData[2]>>4;

smgWela[3]=irCodeByteData[2]&0x0f;

smgWela[4]=irCodeByteData[3]>>4;

smgWela[5]=irCodeByteData[3]&0x0f;

smgWela[6]=0xff;//小数点全不显

}

irTimeCountsArrProcessOk=0;//标志清零,下一次有未解析的数据时才会再解析

}

returnsmgWela;

}

boolirTimeCountsArrProcess()//对接收到的32位的中断次数数据进行解析

{

u8i,j,k,value=0;

if(irReceFlag)//检测是否已经接收到新的4字节的红外通信数据

{

for(j=0;j<4;j++)//有4个字节

{

for(i=0;i<8;i++) //对每个字节的8位数据处理

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

STM32与51单片机之间有什么差异呢?两者可以说是一场科技与性能的较量了。在科技飞速发展的今天,微控制器(MCU)已广泛应用于各类电子设备和系统中,发挥着举足轻重的作用。其中,STM32和51单片机作为两种常见的微控制...

关键字: STM32 51单片机 MCU

51单片机将是下述内容的主要介绍对象,通过这篇文章,小编希望大家可以对51单片机的相关情况以及信息有所认识和了解,详细内容如下。

关键字: 单片机 51单片机

在嵌入式系统开发中,单片机是不可或缺的重要组成部分。其中,STM32单片机和51单片机是两种常见的单片机芯片。本文将对比分析这两种单片机的区别,并探讨STM32单片机的优势。

关键字: stm32单片 51单片机

51单片机是指由美国INTEL公司生产的一系列单片机的总称,这一系列单片机包括了许多品种,如8031,8051,8751,8032,8052,8752等,其中8051是最早最典型的产品,该系列其它单片机都是在8051的基...

关键字: 51单片机 串行通信

51单片机是一种常见的微控制器,它具有串行通信接口(Serial Communication Interface,SCI)。通过串口通信接口,51单片机可以与其他设备或系统进行串行通信,实现数据传输和控制。

关键字: 51单片机 串口通信

Pic单片机和51单片机是两种应用广泛的微控制器,它们各自具有不同的特点和优势,选择哪种单片机取决于具体应用需求。下面将对Pic单片机和51单片机进行详细的介绍和对比。

关键字: PIC单片机 51单片机 单片机

随着电子信息技术的快速发展,串行通信在各种应用中得到了广泛的应用。其中,51单片机作为一种常见的嵌入式系统,具有低功耗、高性能、易于编程等特点,常用于各种自动化控制、数据采集等系统中。而PC机具有强大的数据处理能力和丰富...

关键字: 51单片机 PC机 串行通信

51 单片机内部有一个全双工串行接口。什么叫全双工串口呢?一般来说,只能接受或只能发送的称为单工串行;既可接收又可发送,但不能同时进行的称为半双工;能同时接收和发送的串行口称为全双工串行口。

关键字: 51单片机 串口通信 半双工

步进电机是一种无刷电机,可将电脉冲转换为机械旋转。顾名思义,它根据输入脉冲逐步旋转,是现代数字程序控制系统中的主要执行元件。

关键字: 51单片机 步进电机 无刷电机

1.ROM:只读存储器,单片机的只读存储区大多用于存储程序固又称程序存储器。

关键字: 51单片机 工作原理 电路
关闭
关闭