⑴ 紅外線接收頭1838引腳圖
1、紅外接收頭一般有三隻引線腳,分別為接地、電源和信號輸出。不同型號的紅外接收頭,其引腳排列也不相同。筆者用電阻法判別紅外接收頭的引腳簡單、快速。
2、用指針式萬用表(數字表不適用)電阻擋R×1k(或R×100),先測量確定接地腳,一般接地腳與屏蔽外殼是相通的,餘下的兩只腳假設為a和b。
3、然後用黑表筆搭接地腳,用紅表筆去測a或b腳的阻值,讀數分別約為6kΩ和8kΩ(有的接收頭相差在1kΩ左右);調換表筆,紅表筆接地,黑表筆測a和b腳,讀數分別約為20kΩ和40kΩ。
4、兩次測量阻值相對應都小的a腳即為電源腳,阻值大的b腳即為信號輸出腳。不過用不同的萬用表和測不同型號的接收頭,所測得的電阻都各不相同。
5、但總的結論是:電源腳對地的電阻值不管正反向都要比信號腳對地的電阻值小。
⑵ 紅外感測器和單片機之間怎麼連接
紅外感測器和單片機之間的連接方法:
紅外感測器絕大部分都是通過測引腳電壓換算成距離。所以一般紅外都有三根引腳,VCC和GND肯定會接噻,然後信號線接到你開啟單片機的ADC通道對應的引腳,讀該引腳的電平換算成距離。
紅外感測器如果是數據信號,有幾個腳,就用單片機幾個腳連接,然後根據輸出信號的時序寫程序讀。如果是模擬信號,就得用到A/D轉換電路。
(2)18引腳單片機紅外遙控接收擴展閱讀:
紅外感測器的相關要求規定:
1、紅外線感測器利用遠紅外線范圍的感度做為人體檢出用,紅外線的波長比可見光長而比電波短。紅外線只由熱的物體放射出來,凡是存在於自然界的物體,如人類、火、冰等等全部都會射出紅外線,只是其波長因其物體的溫度而有差異而已。
2、利用紅外輻射的熱效應,探測器的敏感元件吸收輻射能後引起溫度升高,進而使某些有關物理參數發生變化,通過測量物理參數的變化來確定探測器所吸收的紅外輻射。
3、紅外感測器已經在現代化的生產實踐中發揮著它的巨大作用,隨著探測設備和其他部分的技術的提高,紅外感測器能夠擁有更多的性能和更好的靈敏度。
⑶ 急求:單片機紅外遙控器接受和發射電路圖和程序設計,程序最好C語言編的
//ICC-AVR application builder : 5/12/2010 PM 5:48:11
// Target : M8
// Crystal: 8.0000Mhz
#include <iom8v.h>
#include <eeprom.h>
#include <ctype.h>
#include <stdio.h>
#include <macros.h>
#include <string.h>
#include <stdlib.h>
#include <eeprom.h>
#define uchar unsigned char
#define uint unsigned int
#define xtal 8
#define select_a_low (PORTD &=~(1<<7))
#define select_b_hi (PORTD |=(1<<4))
#define select_b_low (PORTD &=~(1<<4))
#define in_result (PINC )
#define raster (PINB & 0x08)
#define ir (PIND & 0x04)
#define pluse_hi (PORTB |=(1<<1))
#define pluse_low (PORTB &=~(1<<1))
#define press (PINB & 0x01)
extern int _textmode;
uchar key_code=0;
uchar new_code=0;
uint buf_key_code=0;
uchar key_bit_count=0;
uint count=0;
uint buf_count=0;
uchar common_code_count=0;
uchar ir_status=0;
uint total[50];
uchar temp=0;
uchar mm=0;
uchar tp1=0;
unsigned long full=0;
uint all=0;
uchar n=0;
void process(uchar ak);
void port_init(void)
{
PORTB = 0xFF;
DDRB = 0xFE;
PORTC = 0x7F; //m103 output only
DDRC = 0x7F;
PORTD = 0xFF;
DDRD = 0x00;
}
void delay_10us(uchar y)
{
uchar x;
for(x=y;x>0;x--)
;
}
//Watchdog initialize
// prescale: 2048K
void watchdog_init(void)
{
WDR (); //this prevents a timeout on enabling
WDTCR |= (1<<WDCE) | (1<<WDE);/* 30-Oct-2006 Umesh*/
WDTCR = 0x0F; //WATCHDOG ENABLED - dont forget to issue WDRs
}
//TIMER0 initialize - prescale:8
// desired value: 50uSec
// actual value: 50.000uSec (0.0%)
void timer0_init(void)
{
TCCR0 = 0x00; //stop
TCNT0 = 0xCE; //set count
TCCR0 = 0x02; //start timer
}
#pragma interrupt_handler timer0_ovf_isr:iv_TIM0_OVF
void timer0_ovf_isr(void)
{
//uint a;
count++;
/*
a=count%2;
if(a==0)
pluse_low;
else
pluse_hi;
*/
TCNT0 = 0xCE; //reload counter value
}
//UART0 initialize
// desired baud rate: 9600
// actual: baud rate:9615 (0.2%)
void uart0_init(void)
{
UCSRB = 0x00; //disable while setting baud rate
UCSRA = 0x00;
UCSRC = BIT(URSEL) | 0x06;
UBRRL = 0x33; //set baud rate lo
UBRRH = 0x00; //set baud rate hi
UCSRB = 0x18;
}
int putchar(char c)
{
if (_textmode && c == '\n')
putchar('\r');
while (!(UCSRA & (1<<UDRE))) // UDRE, data register empty
;
UDR = c;
return c;
}
void all_zero(void)
{
uchar i;
for(i=0;i<48;i++)
{
total[i]=0;
}
}
void initialize_eeprom(void)
{
all_zero();
timer0_init();
count=0;
}
void display(void)
{
uint i,k,m,w;
uchar s,r,t;
/*
for(i=0;i<35;i++)
printf("total[%d]=%d\r\n",i,total[i]);
*/
m=15;
for(i=0;i<10;i++)
{
if(total[i]>230)
{
m=i;
i=12;
}
}
k=0;
if(0)
{
for(i=0;i<35;i++)
printf("total[%d]=%d\r\n",i,total[i]);
}
//printf("m=%d\r\n",m);
if(m<10)
{
for(i=(m+1);i<(17+m);i++)
{
if(total[i]>18 && total[i]<25)
k>>=1;
if(total[i]>39 && total[i]<45)
{
k>>=1;
k|=0x8000;
}
}
w=0;/*
for(i=(m+17);i<(27+m);i++)
{
if(total[i]>18 && total[i]<25)
w>>=1;
if(total[i]>39 && total[i]<45)
{
w>>=1;
w|=0x8000;
}
}
w>>=6;
printf("K=0x%X total[1]=%d w=0x%x\r\n",k,total[1],w); */
s=0;
for(i=(m+17);i<(25+m);i++)
{
if(total[i]>18 && total[i]<25)
s>>=1;
if(total[i]>39 && total[i]<45)
{
s>>=1;
s|=0x80;
}
}
r=0;
for(i=(m+25);i<(33+m);i++)
{
if(total[i]>18 && total[i]<25)
r>>=1;
if(total[i]>39 && total[i]<45)
{
r>>=1;
r|=0x80;
}
}
t=255-r;
n=0;
if(t==s)
{
printf("s=ox%x, r=0x%x, t=0x%x\r\n",s,r,t);
tp1=12;
switch(s)
{
case 0x43:
n=0x12;
break;
case 0x47:
n=0x16;
break;
case 0x42:
n=0x01;
break;
case 0x41:
n=0x02;
break;
case 0x40:
n=0x03;
break;
case 0x46:
n=0x04;
break;
case 0x45:
n=0x05;
break;
case 0x44:
n=0x06;
break;
case 0x4a:
n=0x07;
break;
case 0x49:
n=0x08;
break;
case 0x48:
n=0x09;
break;
case 0x4e:
n=0x0a;
break;
case 0x4d:
n=0x0;
break;
case 0x4c:
n=0x1a;
break;
case 0x14:
n=0x13;
break;
case 0x16:
n=0x17;
break;
case 0x1d:
n=0x14;
break;
case 0x11:
n=0x10;
break;
case 0x15:
n=0x0e;
break;
}
}
}
}
#pragma interrupt_handler int0_isr:iv_INT0
void int0_isr(void)
{
if(temp==56)
{
if(count>240)
{
total[0]=count;
count=0;
temp=57;
mm=1;
}
}
else
{
total[mm]=count;
count=0;
mm++;
if(mm>34)
{
CLI();
display();
temp=0;
mm=0;
CLI();
all_zero();
}
}
}
//TIMER1 initialize - prescale:8
// WGM: 0) Normal, TOP=0xFFFF
// desired value: 50uSec
// actual value: 50.000uSec (0.0%)
void timer1_init(void)
{
TCCR1B = 0x00; //stop
TCNT1H = 0xFF; //setup
TCNT1L = 0xCE;
OCR1AH = 0x00;
OCR1AL = 0x32;
OCR1BH = 0x00;
OCR1BL = 0x32;
ICR1H = 0x00;
ICR1L = 0x32;
TCCR1A = 0x00;
TCCR1B = 0x02; //start Timer
}
#pragma interrupt_handler timer1_ovf_isr:iv_TIM1_OVF
void timer1_ovf_isr(void)
{
//TIMER1 has overflowed
TCNT1H = 0xFF; //reload counter high value
TCNT1L = 0xCE; //reload counter low value
full++;
}
//TIMER2 initialize - prescale:8
// WGM: Normal
// desired value: 108uSec
// actual value: 108.000uSec (0.0%)
void timer2_init(void)
{
TCCR2 = 0x00; //stop
ASSR = 0x00; //set async mode
TCNT2 = 0x94; //setup
OCR2 = 0x6C;
TCCR2 = 0x02; //start
}
#pragma interrupt_handler timer2_ovf_isr:iv_TIM2_OVF
void timer2_ovf_isr(void)
{
TCNT2 = 0x94; //reload counter value
all++;
}
//call this routine to initialize all peripherals
void init_devices(void)
{
//stop errant interrupts until set up
CLI(); //disable all interrupts
port_init();
//watchdog_init();
timer0_init();
uart0_init();
MCUCR = 0x02;
GICR = 0x40;
TIMSK = 0x45; //timer interrupt sources
SEI(); //re-enable interrupts
//all peripherals are now initialized
}
void full_delay(unsigned long b)
{
full=0;
timer1_init();
while(1)
{
if(full>=b)
{
full=0;
TCCR1B = 0x00; //stop timer1
break;
}
}
}
void timer2_delay(uint b)
{
while(1)
{
if(all>(b-1))
{
all=0;
TCCR2 = 0x00; //stop timer2
break;
}
}
}
void zero_one(uint a)
{
uint b;
if(!a)
{
pluse_hi;
b=696/50;
full_delay(b);
pluse_low;
b=348/50;
full_delay(b);
}
else
{
pluse_hi;
b=696/50;
full_delay(b);
pluse_low;
b=1409/50;
full_delay(b);
}
}
void process(uchar ak)
{
uint b,m,i,a,k;
uchar ok;
SEI();
TCCR1B = 0x00; //stop timer1
full=0;
all=0;
pluse_hi;
b=8344/50;
timer2_init();
full_delay(b);
pluse_low;
b=3915/50;
full_delay(b);
m=0x611c;
for(i=0;i<16;i++)
{
a=m & 0x0001;
zero_one(a);
m>>=1;
}
m=0x3dc;
for(i=0;i<10;i++)
{
a=m & 0x0001;
zero_one(a);
m>>=1;
}
ok=255-ak;
k=ok;
k<<=8;
k|=ak;
m=k;
//printf("k=%x\r\n",k);
for(i=0;i<16;i++)
{
a=m & 0x0001;
zero_one(a);
m>>=1;
}
pluse_hi;
b=696/50;
full_delay(b);
pluse_low;
timer2_delay(978);
pluse_hi;
b=8344/50;
full_delay(b);
pluse_low;
b=3915/50;
full_delay(b);
pluse_hi;
b=696/50;
full_delay(b);
pluse_low;
while(!press)
{
;
}
CLI();
}
void main(void)
{
uint a,b,m;
uint k,msg;
init_devices();
delay_10us(1000);
printf("count1=%d\r\n",count);
timer0_ovf_isr();
CLI();
b=0;
m=0;
pluse_low;
tp1=0;
while(1)
{
if(!ir && temp==0 && a==12)
{
a=0;
initialize_eeprom();
temp=56;
count=0;
mm=0;
TCCR2 = 0x00; //stop TIMER2
TCCR1B = 0x00; //stop timer1
//printf("game_start\r\n");
SEI();
}
if(tp1==12)
{
printf("n=%x\r\n",n);
process(n);
all_zero();
CLI();
tp1=0;
}
if(ir)
a=12;
k++;
if(k>30000)
{
msg++;
k=0;
}
if(!ir)
{
msg=0;
}
if( msg>10)
{
all_zero();
msg=0;
temp=0;
CLI();
printf("time out\r\n");
}
if(!press )
{
process(0x08);
}
}
}
⑷ 求單片機C51紅外線收發方案(最好有詳細解釋)
紅外線遙控器解碼程序
2007-02-07 18:52 紅外線遙控是目前使用最廣泛的一種通信和遙控手段。由於紅外線遙控裝置具有體積小、功耗低、功能強、成本低等特點,因而,繼彩電、錄像機之後,在錄音機、音響設備、空凋機以及玩具等其它小型電器裝置上也紛紛採用紅外線遙控。現在工業設備中,也已經廣泛在使用。。。。。
1 紅外遙控系統
通用紅外遙控系統由發射和接收兩大部分組成,應用編/解碼專用集成電路晶元來進行控制操作,如圖1所示。發射部分包括鍵盤矩陣、編碼調制、LED紅外發送器;接收部分包括光、電轉換放大器、解調、解碼電路。
2 遙控發射器及其編碼
遙控發射器專用晶元很多,根據編碼格式可以分成脈沖寬度調制和脈沖相位調制兩大類,這里我們以運用比較廣泛,解碼比較容易的脈沖寬度調制來加以說明,現以3310組成發射電路為例說明編碼原理。當發射器按鍵按下後,即有遙控碼發出,所按的鍵不同遙控編碼也不同。這種遙控碼具有以下特徵:
採用脈寬調制的串列碼,以脈寬為0.565ms、間隔0.56ms、周期為1.125ms的組合表示二進制的「0」;以脈寬為0.565ms、間隔1.685ms、周期為2.25ms的組合表示二進制的「1」
上述「0」和「1」組成的42位二進制碼經38kHz的載頻進行二次調制以提高發射效率,達到降低電源功耗的目的。然後再通過紅外發射二極體產生紅外線向空間發射,
3310產生的遙控編碼是連續的42位二進制碼組,其中前26位為用戶識別碼,能區別不同的紅外遙控設備,防止不同機種遙控碼互相干擾。後16位為8位的操作碼和8位的操作反碼用於核對數據是否接收准確。
當遙控器上任意一個按鍵按下超過36ms時,LC7461晶元的振盪器使晶元激活,將發射一個特定的同步碼頭,對於接收端而言就是一個9ms的低電平,和一個4.5ms的高電平,這個同步碼頭可以使程序知道從這個同步碼頭以後可以開始接收數據。
解碼的關鍵是如何識別「0」和「1」,從位的定義我們可以發現「0」、「1」均以0.56ms的低電平開始,不同的是高電平的寬度不同,「0」為0.56ms,「1」為1.68ms,所以必須根據高電平的寬度區別「0」和「1」。如果從0.56ms低電平過後,開始延時,0.56ms以後,若讀到的電平為低,說明該位為「0」,反之則為「1」,為了可靠起見,延時必須比0.56ms長些,但又不能超過1.12ms,否則如果該位為「0」,讀到的已是下一位的高電平,因此取(1.12ms+0.56ms)/2=0.84ms最為可靠,一般取0.84ms左右即可。
根據紅外編碼的格式,程序應該等待9ms的起始碼和4.5ms的結果碼完成後才能讀碼。
接收器及解碼
LT0038是塑封一體化紅外線接收器,它是一種集紅外線接收、放大、整形於一體的集成電路,不需要任何外接元件,就能完成從紅外線接收到輸出與TTL電平信號兼容的所有工作,沒有紅外遙控信號時為高電平,收到紅外信號時為低電平,而體積和普通的塑封三極體大小一樣,它適合於各種紅外線遙控和紅外線數據傳輸。
下面是一個對51ISP編程實驗開發板配套的紅外線遙控器的解碼程序,它可以把紅外遙控器每一個按鍵的鍵值讀出來,並且通過實驗板上P1口的8個LED顯示出來,在解碼成功的同時並且能發出「嘀嘀嘀」的提示音。
ORG 0000H
AJMP MAIN;轉入主程序
ORG 0003H ;外部中斷P3.2腳INT0入口地址
AJMP INT ;轉入外部中斷服務子程序(解碼程序)
;以下為主程序進行CPU中斷方式設置
MAIN:SETB EA ;打開CPU總中斷請求
SETB IT0 ;設定INT0的觸發方式為脈沖負邊沿觸發
SETB EX0 ;打開INT0中斷請求
;以下對單片機的所有引腳進行初始化,全部設置成高電平
MOV P2,#11111111B
AJMP $
;以下為進入P3.2腳外部中斷子程序,也就是解碼程序
INT: CLR EA ;暫時關閉CPU的所有中斷請求
MOV R6,#10
SB: ACALL YS1;調用882微秒延時子程序
JB P3.2,EXIT;延時882微秒後判斷P3.2腳是否出現高電平如果有就退出解碼程序
DJNZ R6, SB;重復10次,目的是檢測在8820微秒內如果出現高電平就退出解碼程序
;以上完成對遙控信號的9000微秒的初始低電平信號的識別。
JNB P3.2, $ ;等待高電平避開9毫秒低電平引導脈沖
ACALL YS2 ;延時4.74毫秒避開4.5毫秒的結果碼
MOV R7,#26;忽略前26位系統識別碼
JJJJA:JNB P3.2,$;等待地址碼第一位的高電平信號
LCALL YS1;高電平開始後用882微秒的時間尺去判斷信號此時的高低電平狀態
MOV C,P3.2;將P3.2引腳此時的電平狀態0或1存入C中
JNC UUUA;如果為0就跳轉到UUUA
LCALL YS3;檢測到高電平1的話延時1毫秒等待脈沖高電平結束
UUUA: DJNZ R7,JJJJA
MOV R1,#1AH ;設定1AH為起始RAM區
MOV R2,#2;接收從1AH到1BH的2個內存,用於存放操作碼和操作反碼
PP: MOV R3,#8;每組數據為8位
JJJJ: JNB P3.2,$;等待地址碼第一位的高電平信號
LCALL YS1;高電平開始後用882微秒的時間尺去判斷信號此時的高低電平狀態
MOV C,P3.2;將P3.2引腳此時的電平狀態0或1存入C中
JNC UUU;如果為0就跳轉到UUU
LCALL YS3;檢測到高電平1的話延時1毫秒等待脈沖高電平結束
UUU: MOV A,@R1;將R1中地址的給A
RRC A;將C中的值0或1移入A中的最低位
MOV @R1,A;將A中的數暫時存放在R1數值的內存中
DJNZ R3,JJJJ;接收滿8位換一個內存
INC R1;對R1中的值加1,換下一個RAM
DJNZ R2,PP ;接收完8位數據碼和8位數據反碼,存放在1AH/1BH中
MOV A,1AH
CPL A;對1AH取反後和1BH比較
CJNE A,1BH,EXIT;如果不等表示接收數據發生錯誤,放棄
MOV P1,1AH;將按鍵的鍵值通過P1口的8個LED顯示出來!
CLR P2.0;蜂鳴器鳴響-嘀嘀嘀-的聲音,表示解碼成功
LCALL YS2
LCALL YS2
LCALL YS2
SETB P2.0;蜂鳴器停止(使用時可以將J2的YINYUE腳用跳線接J4 的XS1腳才可以使用蜂鳴器)可以看原理圖
EXIT: SETB EA ;允許中斷
RETI ;退出解碼子程序
YS1: MOV R4,#20 ;延時子程序1,精確延時882微秒
D1: MOV R5,#20
DJNZ R5,$
DJNZ R4,D1
RET
YS2: MOV R4,#10 ;延時子程序2,精確延時4740微秒
D2: MOV R5,#235
DJNZ R5,$
DJNZ R4,D2
RET
YS3: MOV R4,#2;延時程序3,精確延時1000微秒
D3:MOV R5,#248
DJNZ R5,$
DJNZ R4,D3
RET
END
以上程序緊供參考。
0A 01
11 12 13 14
15 16 17 18
19 10 1A 1B
0E 02 03 1C
06 04 05 0C
0D 08 09 1D
00 1F 1E 0B
07 0F
這是按照紅外遙控器按鍵的實際位置給出的32個按鍵的鍵值(16進制)
⑸ 用單片機如何作紅外線的接收
你好,我研究過紅外線,網上有賣紅外一體化接收頭的,大概8毛錢一個,它有三個引腳,分別是電源、地、還有信號端。信號端接單片機外部中斷0或外部中斷1,我編過相應的程序,用紅外遙控控制數碼管的顯示,按幾號鍵顯示幾。