用atmega8做简单的红外线报警器
扫描二维码
随时随地手机看文章
本实验将制做一个简单的被动式红外线防盗报警器。该报警器由红外线发射、接收、蜂鸣器和LED指示灯组成。正常情况下,绿色的LED常烁,表示监控区域正常。一旦监控区域有人闯入,绿色LED熄灭,红色的LED快速闪烁,同时蜂鸣器立即报警。需要准备的器材:Atmega8、红色LED一只、绿色LED一只、万能实验板一块、5V电源、电阻、TTL0038或者其他类似38KHZ的红外接收头、5V长鸣型蜂鸣器。
该电路工作原理非常简单,Atmega8的PD0端口输出经过调制的38KHZ的方波信号,然后经Q2驱动红外线发射管LED0发出红外线信号。TL0038是集红外线信号接收放大为一体的接收器。其中心接收频率为38KZH,输出为TTL电平,平时输出高电平,当收到码信号后,输出低电平。BELL为长鸣蜂鸣器,两个引脚分别为正负极,当正负极两端加上5V电压后,蜂鸣器发出响声。注意,该蜂鸣器两脚不能接反,否则蜂鸣器会烧毁。电路工作后,正常情况下TL0038接收不到红外信号,而输出高电平。当有物体出现在发射管前方时,TTL0038会接收到从物体上反射回来的红外光信号,然后输出低电平通知MCU打开蜂鸣器报警。该电路工作原理非常简单,Atmega8的PD0端口输出经过调制的38KHZ的方波信号,然后经Q2驱动红外线发射管LED0发出红外线信号。TL0038是集红外线信号接收放大为一体的接收器。其中心接收频率为38KZH,输出为TTL电平,平时输出高电平,当收到码信号后,输出低电平。BELL为长鸣蜂鸣器,两个引脚分别为正负极,当正负极两端加上5V电压后,蜂鸣器发出响声。注意,该蜂鸣器两脚不能接反,否则蜂鸣器会烧毁。电路工作后,正常情况下TL0038接收不到红外信号,而输出高电平。当有物体出现在发射管前方时,TTL0038会接收到从物体上反射回来的红外光信号,然后输出低电平通知MCU打开蜂鸣器报警。同时,程序通过不断地读取PC5脚的电平值来判断TL0038是否接收到红外信号。一旦连续检测到N次PC5为低电平,则立即打开蜂鸣器和红色的LED。之所以要连续检测N次,主要是防止TL0038上产生杂波信号而误告警。
#include
#include
实验2:简单的被动式红外线报警器
PB1:绿色LED
PB0:红色LED
PD7:蜂鸣器
PC5:连接TL0083的输出端
PD0:红外LED
2004年8月4日
***************************************************************************/
voiddelay_nus(unsignedintn);//voiddelay_nms(unsignedintn);
voidmain(void)//主函数
{
unsignedinti;
unsignedcharn;
OSCCAL=0X98;//系统时钟校准,不同的芯片和不同的频率,
//其校准值是不一样的
TCCR0=BIT(CS01);//T/C0时钟8分频
TIMSK=BIT(TOIE0);//允许定时器T/C0溢出中断
SEI();//开中断
DDRD|=BIT(0)|BIT(7);//设置PD0、7为输出口
DDRC&=~BIT(5);//设置PC5为输入口
DDRB|=BIT(1)|BIT(0);//定义B口的PB0、PB1为输出口
PORTB|=BIT(1);//PB1口输出高电平,绿灯亮
while(1)
{
for(n=0;n<10;n++)
{
delay_nus(60);
if((PINC&0B00100000)==0)//检测PC5是否为低电平
{
i++;
if(i>8)//如果连续检测到有301-399次PC5都为低电平,则报警
{
CLI();
for(i=0;i<10;i++)
{
PORTB&=~BIT(1);//关闭绿灯
PORTD|=BIT(7);//打开蜂鸣器
PORTB^=BIT(0);//翻转PB1口,红灯快闪
delay_nms(300);
}
PORTD&=~BIT(7);//关闭蜂鸣器
PORTB&=~BIT(0);//关闭红灯
i=0;
SEI();
}
PORTB|=BIT(1);//打开绿灯
}
}
/***************码调制*****************************/
CLI();//PD0连续2ms都无输出
PORTD&=~BIT(0);
delay_nms(2);
TCNT0=245;
SEI();//PD0连续600us产生38KHZ信号
}
}
#pragmainterrupt_handlerLED0:iv_TIMER0_OVF//指定中断服务程序的入口
voidLED0(void)//产生38KHz的方波信号
{
PORTD^=BIT(0);//翻转PD0口电平
TCNT0=245;
}
voiddelay_nus(unsignedintn)//n微秒延时函数
{
unsignedinti;
for(i=0;i
asm("nop");
}
}
voiddelay_nms(unsignedintn)//n毫秒延时函数
{
unsignedinti;
for(i=0;i
}