您现在的位置是:首页 > 行业发展
红外遥控怎么做?看完这篇你该试试手
智慧创新站
2025-03-02【行业发展】204人已围观
简介红外接收头的型号有很多HS0038VS838等功能大致相同,只是引脚封装不同。红外接收有几种统一的编码方式,采样哪种编码方式取决于遥控器使用的芯片,接收头收到的都是一样的。电视遥控器使用的是专用集成发射芯片来实现遥控码的发射,如东芝TC9012,飞利浦AA3010T等,通常彩电遥控信号的发射,就是将...
红外接收头的型号有很多HS0038VS838等功能大致相同,只是引脚封装不同。
红外接收有几种统一的编码方式,采样哪种编码方式取决于遥控器使用的芯片,接收头收到的都是一样的。
电视遥控器使用的是专用集成发射芯片来实现遥控码的发射,如东芝TC9012,飞利浦AA3010T等,通常彩电遥控信号的发射,就是将某个按键所对应的控制指令和系统码(由0和1组成的序列),调制在38KHz的载波上,然后经放大、驱动红外发射管将信号发射出去。不同公司的遥控芯片,采样的遥控码格式也不一样,较普遍的有两种,一种NEC标准,一种是PHILIPS标准。
NEC标准:遥控载波的频率为38KHz(占空比1:3)当某个键按下时,系统首先发射一个完整的全码,如果按键超过108ms仍未松开,接下来发射的代码(连发代码)将由起始码(9ms)和结束码(2.5ms)组成。
一个完整的全码=引导码+用户码+用户码+数据码+数据码+数据反码。

其中,引导码高电平9ms,低电平4.5ms;系统码8位,数据码8位,共32位;其中前16位为用户识别码,能区别不同的红外遥控设备,以防止不同的机种遥控码互相干扰。后16位为8位的操作码和8位的操作反码,用于核对数据是否接收准确。收端根据数据码做出应该执行上面动作的判断。
连发代码是在持续按键时发送的码。它告知接收端。某键是在被连续的按着。
NEC标准下的发射码表示
发射数据0时用”0.56ms高电平+0.565ms低电平=1.125ms”表示;
数据1用”高电平0.56ms+1.69ms=2.25ms”表示。
遥控器发射信号:
需要注意的是:当一体化接收头收到38kHz红外信号时,输出端输出低电平,否则为高电平。所以一体化接收头输出的波形和发射波形是反向的
PHILIPS标准:载波频率38KHz:没有筒,点按键时,控制码1和0之间切换,若持续按键,则控制码不变。
一个全码=起始码’11’+控制码+用户码+用户码
数据0用“低电平1.778ms+高电平1.778ms”表示;
数据1用“高电平1.778ms+低电平1.778ms”表示。
连续码重复延时114ms。
所谓的解码就是一个区分脉冲宽度的过程。红矮信号的0和1是通过脉冲持续时间的长短来区分的,
我的遥控器使用的是NEC标准的WD6122芯片,遥控器编码如下:
以下是我用1602显示红外接收头接收到编码的程序:①这个是对1602操作的函数
------------------------------------------------*/
include""
defineRS_CLRRS=0
defineRW_CLRRW=0
defineEN_CLREN=0
defineDataPortP0
/*------------------------------------------------
判忙函数
------------------------------------------------*/
bitLCD_Check_Busy(void)
{
else
return0;
//包含头文件,一般情况不需要改动,头文件包含特殊功能寄存器的定义
include""
sbitIR=P3^2;//红外接口标志
charcodeTab[16]="0123456789ABCDEF";
/*------------------------------------------------
全局变量声明
------------------------------------------------*/
unsignedcharirtime;//红外用全局变量
bitirpro_ok,irok;
unsignedcharIRcord[4];
unsignedcharirdata[33];
unsignedcharTempData[16];
/*------------------------------------------------
函数声明
------------------------------------------------*/
voidIr_work(void);
voidIrcordpro(void);
/*------------------------------------------------
定时器0中断处理
------------------------------------------------*/
voidtim0_isr(void)interrupt1using1
{
irtime++;//用于计数2个下降沿之间的时间
外部中断0中断处理
------------------------------------------------*/
voidEX0_ISR(void)interrupt0//外部中断0服务函数
{
staticunsignedchari;//接收红外信号处理
staticbitstartflag;//是否开始处理标志位
if(startflag)
{
if(irtime63irtime=33)//引导码TC9012的头码,9ms+4.5ms
i=0;
irdata[i]=irtime;//存储每个电平的持续时间,用于以后判断是0还是1
irtime=0;
i++;
if(i==33)
{
irok=1;
else
startflag=1;
定时器0初始化
------------------------------------------------*/
voidTIM0init(void)//定时器0初始化
{
TMOD=0x02;//定时器0工作方式2,TH0是重装值,TL0是初值
TH0=0x00;//重载值
TL0=0x00;//初始化值
ET0=1;//开中断
TR0=1;
外部中断0初始化
------------------------------------------------*/
voidEX0init(void)
{
IT0=1;//指定外部中断0下降沿触发,INT0()
EX0=1;//使能外部中断
EA=1;//开总中断
键值处理
------------------------------------------------*/
voidIr_work(void)
{
TempData[0]=Tab[IRcord[0]/16];//处理客户码
TempData[1]=Tab[IRcord[0]%16];
TempData[2]='-';
TempData[3]=Tab[IRcord[1]/16];//处理客户码
TempData[4]=Tab[IRcord[1]%16];
TempData[5]='-';
TempData[6]=Tab[IRcord[2]/16];//处理数据码
TempData[7]=Tab[IRcord[2]%16];
TempData[8]='-';
TempData[9]=Tab[IRcord[3]/16];//处理数据反码
TempData[10]=Tab[IRcord[3]%16];
LCD_Write_String(5,1,TempData);
irpro_ok=0;//处理完成标志
红外码值处理
------------------------------------------------*/
voidIrcordpro(void)//红外码值处理函数
{
unsignedchari,j,k;
unsignedcharcord,value;
k=1;
for(i=0;i4;i++)//处理4个字节
{
for(j=1;j=8;j++)//处理1个字节8位
{
cord=irdata[k];
if(cord7)//大于某值为1,这个和晶振有绝对关系,这里使用12M计算,此值可以有一定误差
value|=0x80;
if(j8)
{
value=1;
}
k++;
}
IRcord[i]=value;
value=0;
}
irpro_ok=1;//处理完毕标志位置1
主函数
------------------------------------------------*/
voidmain(void)
{
EX0init;//初始化外部中断
TIM0init;//初始化定时器
LCD_Init;//初始化液晶
DelayMs(20);//延时有助于稳定
LCD_Clear;//清屏
LCD_Write_String(0,0,"");
LCD_Write_String(0,1,"Code:");
while(1)//主循环
{
if(irok)//如果接收好了进行红外处理
{
Ircordpro;
irok=0;
}
if(irpro_ok)//如果处理好后进行工作处理,如按对应的按键后显示对应的数字等
{
Ir_work;
很赞哦!(51)