您的位置 首页 国产IC

51单片机制造红外遥控器

你的生活中是否也有这样的场景,要打开电视,满屋子找遥控器,翻了一大堆遥控器却愣是没找到哪个是电视机的?我们走访了不少家庭,得到了一…

你的日子中是否也有这样的场景,要翻开电视,满屋子找遥控器,翻了一大堆遥控器却愣是没找到哪个是电视机的?咱们造访了不少家庭,得到了一个惊人的数据,至少一个三口之家的家庭会有6个遥控板,更多的乃至达到了10多个。越来越多的电器为了让操作更简洁,更便利人们运用而选用了遥控的技能,以一般的家庭为例,一台电视就有一个遥控器、机顶盒一个遥控器,空调也是一个房间一个,也有三个遥控器、DVD也有一个遥控器。假如再加上客厅的电灯、电扇、音响等等那就更多了。常用的就由5,6个。许多的市民都面临着遥控器太多的烦恼。迫切需求有一个能替代家里遥控器的设备。用单片机模仿遥控器发射红外线。

一、红外发射管电路

二、红外发射的原理

一般红外电视遥控器的输出都是用编码后串行数据对38~40kHz的方波进行脉冲幅度调制而发生的.当发射器按键按下后,即有遥控码宣布,所按的键不同遥控编码也不同。这种遥控码具有以下特征:选用脉宽调制的串行码,以脉宽为0.565ms、距离0.56ms、周期为1.125ms的组合表明二进制的“0”;以脉宽为0.565ms、距离1.685ms、周期为2.25ms的组合表明二进制的“1”。上述“0”和“1”组成的32位二进制码经38kHz的载频进行二次调制,然后再经过红外发射二极管发生红外线向空间发射。一般电视遥控器的遥控编码是接连的32位二进制码组,其间前16位为用户识别码,能差异不同的红外遥控设备,避免不同机种遥控码相互搅扰。后16位为8位的操作码和8位的操作反码,用于核对数据是否接纳精确。依据红外编码的格局,发送数据前需求先发送9ms的开端码和4.5ms的成果码。所以红外遥控器发送红外信号时,在低电平处发送38kHz红外信号,高电平处则不发送红外信号。

红外发射器波形,如图:

下面把方位1的波形扩大:

由方位1的波形得知,这108ms发射代码由一个开端码(9ms),一个成果码(4.5ms),低8位地址码(用户编码)(9ms~18ms),高8位地址码(用户编码)(9ms~18ms),8位数据码(键值数据码)(9ms~18ms)和这8位数据的反码(键值数据码反码)(9ms~18ms)组成。

红外发射.rar

网上找了几个代码都无法直接用,后来自己测。在本来程序基础上做修正

1.发送数据从高位开端!

2.引导后,发一个bit0

欢迎沟通:QQ:437796990

后期想象:1.用手机蓝牙与单片机模块衔接,用手机完成遥控器的功用(根本完成)

#include

#define uchar unsigned char

#define uint unsigned int

sbit IR_OUT=P1^0 ;

void delay_ms(uint ms)

{

uint i,j;

for(i=0;i<120;i++)

{

for(j=0;j

}

}

//T1 13us发生一次中止 用于发生38K载波

//T0 方法1 16位 用于守时

void Init_Timer(void)

{

TMOD=0x21; //T0 mode 1 T1 mode 2

TH1=256-(1000*11.0592/38.0/12)/2+0.5;

//特别

TL1=TH1;

ET1=1;

EA=1;

}

//发送引导码 发送方:4.5ms高电平 4.5ms低电平

void Send_Start_Bit(void) //TR1的值=发送的电平

{

//4.5ms 1

TH0=(65536-8295)/256;

TL0=(65536-8295)%256;

TR0=1;

TR1=1;

while(!TF0);

TR1=0;

TF0=0;

TR0=0;

IR_OUT=0;

//4.5ms 0

TH0=(65536-4146)/256;

TL0=(65536-4146)%256;

TR0=1;

TR1=0;

while(!TF0);

TR1=0;

TF0=0;

TR0=0;

IR_OUT=0;

}

//发送0

void Send_Bit_0(void)

{

//0.565ms 1

TH0=(65536-521)/256;

TL0=(65536-521)%256;

TR0=1;

TR1=1;

while(!TF0);

TR1=0;

TF0=0;

TR0=0;

IR_OUT=0;

//0.565ms 0

TH0=(65536-521)/256;

TL0=(65536-521)%256;

TR0=1;

TR1=0;

while(!TF0);

TR1=0;

TF0=0;

TR0=0;

IR_OUT=0;

}

//发送1

void Send_Bit_1(void)

{

//0.565ms 1

TH0=(65536-521)/256;

TL0=(65536-521)%256;

TR0=1;

TR1=1;

while(!TF0);

TR1=0;

TF0=0;

TR0=0;

IR_OUT=0;

//1.685ms 0

TH0=(65536-1563)/256;

TL0=(65536-1563)%256;

TR0=1;

TR1=0;

while(!TF0);

TR1=0;

TF0=0;

TR0=0;

IR_OUT=0;

}

void Send_over(void) //发送一个完毕码,由于最终一个位只要遇到下降沿才干读取(发射端的上升沿)

{

//0.500ms 1 //小于0.5ms 接纳端很难识别到

TH0=(65536-500)/256;

TL0=(65536-500)%256;

TR0=1;

TR1=1;

while(!TF0);

TR1=0;

TF0=0;

TR0=0;

IR_OUT=0;

//0.500ms 0

TH0=(65536-500)/256;

TL0=(65536-500)%256;

TR0=1;

TR1=0;

while(!TF0);

TR1=0;

TF0=0;

TR0=0;

IR_OUT=0;

}

//发送一字节 8位

void Send_Char()

{

unsigned char i,j1,j2,j3,j4;

j1=0xBE;

j2=0x41;

j3=0xDE;

j4=0x20;

Send_Start_Bit();

Send_Bit_0();

//发射引导吗

for(i=0;i<8;i++)

{

if(j1&0x80)

Send_Bit_0();

else

Send_Bit_1();

j1=j1<<1;

//先发射低位

}

for(i=0;i<8;i++)

{

if(j2&0x80)

Send_Bit_0();

else

Send_Bit_1();

j2=j2<<1;

//先发射低位

}

for(i=0;i<8;i++)

{

if(j3&0x80)

Send_Bit_0();

else

Send_Bit_1();

j3=j3<<1;

//先发射低位

}

for(i=0;i<8;i++)

{

if(j4&0x80)

Send_Bit_0();

else

Send_Bit_1();

j4=j4<<1;

//先发射低位

}

Send_over();

//完毕符

}

/*void Delay10ms(void)

{

TH0=(65536-10000)/256;

TL0=(65536-10000)%256;

TR0=1;

while(!TF0);

TF0=0;

}*/

void T1_ISR(void) interrupt 3

{

IR_OUT=!IR_OUT;

}

void main(void)

{

Init_Timer();

while(1)

{

// Send_Start_Bit();

// Send_Bit_1();

Send_Char();

delay_ms(1000);

}

}

//———————————————————————–

//T1 ISR

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/bandaoti/ic/266887.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部