/*315M无线解码程序*/
/*无线码宽电平脉冲时间1.8ms,低电平脉冲时间600us,同步码低电平时间18.6ms
用TIMER0和INT0配合实现脉宽测量,这种做法的好处是不用隔一段时间扫描I/O口,方便系统程序的整体设计
硬件上要把无线信号反向后接到INT0脚,用脉宽测量反向后的高电平时间
P1口接LED显示接收到的无线码的最后一字节数据*/
#include <stc12c4052.h>
#define uchar unsigned char
#define uint unsigned int
#define _rlcar_(RX) CY="RX"&0x80 //RX带进位左移1位,数据放入ACC ,此处是CY=RX&0x80,RX处没有双引号
uchar bdata wx_data0,wx_data1,wx_data2; //存储24位无线数据
uchar data wx_code0,wx_code1,wx_code2;
uint data wx_count; //低电平时间计数器
uchar data wx_bit; //无线码位数
bit tb_flag; //同步码接收成功标志
bit wx_ok; //无线码接收成功标志
void mcu_initialize() {
WDT_CONTR=0x00; //关闭看门狗
AUXR=0; //定时器0和1设为传统8051速度,12分频
P1M0=0;P1M1=0x0; //P1为准双向口
P1=0;
P3M0=0x04;P3M1=0x00; //P3.2设置成输入脚
TR0=0;
TH0=0x00;TL0=0x00; //TH0,TL0请零
TMOD|=0x09; //设置T0为16位定时器,设为门控定时
ET0=0; //禁止T0中断
IT0=1; //从高变低跳变引起中断
EX0=1; //开外部中断0
EA=1;
TR0=1; //启动T0
}
void main() {
mcu_initialize();
pca_initiate();
while(1);
}
void int0_isr() interrupt 0 using 1{
wx_count=TH0*256+TL0;
TH0=0;TL0=0; //清零T0定时器
if(tb_flag) { //同步码标志为1
if((0x0170<wx_count)&&(wx_count<0x05c2)){ //高电平脉宽范围在200us到800us之间
CY=1;
}
else if((0x095c<wx_count)&&(wx_count<0x0e66)){ //高电平脉宽范围在1.3ms到2ms之间
CY=0;
}
else{ //干扰码
loop2:wx_count=0;
wx_bit=0;
tb_flag=0;
return;
}
_rlcar_(wx_data0); //移位寄存器,接收一位数据
wx_data0=ACC;
_rlcar_(wx_data1);
wx_data1=ACC;
_rlcar_(wx_data2);
wx_data2=ACC;
if(++wx_bit==24){ //接收完24位码,接收成功标志wx_ok置1
tb_flag=0;
wx_bit=0;
wx_ok=1;
wx_code0=wx_data0;wx_code1=wx_data1;wx_code2=wx_data2;
P1=wx_code0; //p1口接LED显示数据
}
}
else {
if((0x6134<wx_count)&&(wx_count<0x9002))
tb_flag=1; //高电平脉宽范围在13.5ms到20ms之间,把同步码标志置1
else
goto loop2;
}
}
文章评论(0条评论)
登录后参与讨论