久久ER99热精品一区二区-久久精品99国产精品日本-久久精品免费一区二区三区-久久综合九色综合欧美狠狠

新聞中心

EEPW首頁 > 嵌入式系統 > 設計應用 > 51單片機制作紅外遙控器

51單片機制作紅外遙控器

作者: 時間:2016-11-18 來源:網絡 收藏

你的生活中是否也有這樣的場景,要打開電視,滿屋子找遙控器,翻了一大堆遙控器卻愣是沒找到哪個是電視機的?我們走訪了不少家庭,得到了一個驚人的數據,至少一個三口之家的家庭會有6個遙控板,更多的甚至達到了10多個。越來越多的電器為了讓操作更簡便,更方便人們使用而采用了遙控的技術,以一般的家庭為例,一臺電視就有一個遙控器、機頂盒一個遙控器,空調也是一個房間一個,也有三個遙控器、DVD也有一個遙控器。如果再加上客廳的電燈、風扇、音響等等那就更多了。常用的就由5,6個。許多的市民都面臨著遙控器太多的煩惱。迫切需要有一個能代替家里遙控器的裝置。用單片機模擬遙控器發射紅外線。

本文引用地址:http://cqxgywz.com/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




評論


技術專區

關閉