51单片机制作红外遥控器
你的生活中是否也有这样的场景,要打开电视,满屋子找遥控器,翻了一大堆遥控器却愣是没找到哪个是电视机的?我们走访了不少家庭,得到了一个惊人的数据,至少一个三口之家的家庭会有6个遥控板,更多的甚至达到了10多个。越来越多的电器为了让操作更简便,更方便人们使用而采用了遥控的技术,以一般的家庭为例,一台电视就有一个遥控器、机顶盒一个遥控器,空调也是一个房间一个,也有三个遥控器、DVD也有一个遥控器。如果再加上客厅的电灯、风扇、音响等等那就更多了。常用的就由5,6个。许多的市民都面临着遥控器太多的烦恼。迫切需要有一个能代替家里遥控器的装置。用单片机模拟遥控器发射红外线。
本文引用地址:https://www.eepw.com.cn/article/201611/315839.htm一、红外发射管电路
二、红外发射的原理
一般红外电视遥控器的输出都是用编码后串行数据对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
评论