⑴ 红外线接收头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,我编过相应的程序,用红外遥控控制数码管的显示,按几号键显示几。