51單片機制作紅外遙控器
你的生活中是否也有這樣的場景,要打開電視,滿屋子找遙控器,翻了一大堆遙控器卻愣是沒找到哪個是電視機的?我們走訪了不少家庭,得到了一個驚人的數(shù)據(jù),至少一個三口之家的家庭會有6個遙控板,更多的甚至達到了10多個。越來越多的電器為了讓操作更簡便,更方便人們使用而采用了遙控的技術(shù),以一般的家庭為例,一臺電視就有一個遙控器、機頂盒一個遙控器,空調(diào)也是一個房間一個,也有三個遙控器、DVD也有一個遙控器。如果再加上客廳的電燈、風扇、音響等等那就更多了。常用的就由5,6個。許多的市民都面臨著遙控器太多的煩惱。迫切需要有一個能代替家里遙控器的裝置。用單片機模擬遙控器發(fā)射紅外線。
本文引用地址:http://m.butianyuan.cn/article/201611/315839.htm一、紅外發(fā)射管電路
二、紅外發(fā)射的原理
一般紅外電視遙控器的輸出都是用編碼后串行數(shù)據(jù)對38~40kHz的方波進行脈沖幅度調(diào)制而產(chǎn)生的.當發(fā)射器按鍵按下后,即有遙控碼發(fā)出,所按的鍵不同遙控編碼也不同。這種遙控碼具有以下特征:采用脈寬調(diào)制的串行碼,以脈寬為0.565ms、間隔0.56ms、周期為1.125ms的組合表示二進制的“0”;以脈寬為0.565ms、間隔1.685ms、周期為2.25ms的組合表示二進制的“1”。上述“0”和“1”組成的32位二進制碼經(jīng)38kHz的載頻進行二次調(diào)制,然后再通過紅外發(fā)射二極管產(chǎn)生紅外線向空間發(fā)射。一般電視遙控器的遙控編碼是連續(xù)的32位二進制碼組,其中前16位為用戶識別碼,能區(qū)別不同的紅外遙控設備,防止不同機種遙控碼互相干擾。后16位為8位的操作碼和8位的操作反碼,用于核對數(shù)據(jù)是否接收準確。根據(jù)紅外編碼的格式,發(fā)送數(shù)據(jù)前需要先發(fā)送9ms的起始碼和4.5ms的結(jié)果碼。所以紅外遙控器發(fā)送紅外信號時,在低電平處發(fā)送38kHz紅外信號,高電平處則不發(fā)送紅外信號。
紅外發(fā)射器波形,如圖:
下面把位置1的波形放大:
由位置1的波形得知,這108ms發(fā)射代碼由一個起始碼(9ms),一個結(jié)果碼(4.5ms),低8位地址碼(用戶編碼)(9ms~18ms),高8位地址碼(用戶編碼)(9ms~18ms),8位數(shù)據(jù)碼(鍵值數(shù)據(jù)碼)(9ms~18ms)和這8位數(shù)據(jù)的反碼(鍵值數(shù)據(jù)碼反碼)(9ms~18ms)組成。
紅外發(fā)射.rar
網(wǎng)上找了幾個代碼都沒法直接用,后來自己測。在原來程序基礎(chǔ)上做修改
1.發(fā)送數(shù)據(jù)從高位開始!
2.引導后,發(fā)一個bit0
歡迎交流:QQ:437796990
后期設想:1.用手機藍牙與單片機模塊連接,用手機實現(xiàn)遙控器的功能(基本實現(xiàn))
#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產(chǎn)生一次中斷 用于產(chǎn)生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; } //發(fā)送引導碼 發(fā)送方:4.5ms高電平 4.5ms低電平 void Send_Start_Bit(void) //TR1的值=發(fā)送的電平 { //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; } //發(fā)送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; } //發(fā)送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) //發(fā)送一個結(jié)束碼,因為最后一個位只有遇到下降沿才能讀?。òl(fā)射端的上升沿) { //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; } //發(fā)送一字節(jié) 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(); //發(fā)射引導嗎 for(i=0;i<8;i++) { if(j1&0x80) Send_Bit_0(); else Send_Bit_1(); j1=j1<<1; //先發(fā)射低位 } for(i=0;i<8;i++) { if(j2&0x80) Send_Bit_0(); else Send_Bit_1(); j2=j2<<1; //先發(fā)射低位 } for(i=0;i<8;i++) { if(j3&0x80) Send_Bit_0(); else Send_Bit_1(); j3=j3<<1; //先發(fā)射低位 } for(i=0;i<8;i++) { if(j4&0x80) Send_Bit_0(); else Send_Bit_1(); j4=j4<<1; //先發(fā)射低位 } Send_over(); //結(jié)束符 } /*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
評論