说明如下:
1:利用陈老板给本人提供的MCD2及DEMO
2:选用PIC16F877A作为软件解码芯片
3:单片机时钟频率选用外部4MHZ晶振
4:选用外部中断脚作为编码信号脚输入脚
5:可解PT2240芯片(8脚的学习型编码芯片 编码地址位:2的20次方 重复几率100万分之一)
6:功能有:遥控器学习(DEMO上的S9作为学习按纽) 清除记忆(长按DEMO上的S9即可清除遥控器地址的记忆)
7:学习遥控器数量可以设定(可根据EEPROM的大小 随便设定)
8:输出功能(有三路是 单击遥控器双稳,可以通过PORTC上的LED可以看到结果.还有一路是 双击遥控器双稳)
9:可选用315MHZ/433MHZ的饿超再生/超外差接收模块
10:过几天将公布PT2260-PT2262的单片机软件解码资料
/******************************************************************************/
/****************************** 遥控器接收程序 ********************************/
/******************************************************************************/
#include
#include
#define remote_geshu 10
/******************************************************************************/
union BIT_16
{
int TIMER1_REG;
unsigned char REG[2];
}
union BIT_32
{
unsigned long data_temp_long;
unsigned char data_temp_byte[4];
}
/******************************************************************************/
static union BIT_16 TIMER1_TEMP;//16位定时器1
static union BIT_32 data_temp;
/******************************************************************************/
static volatile unsigned char rec_status @ 97;
static unsigned char data_cout;//接收的遥控器码位数
static unsigned char data;//接收的4位数据
static unsigned int h_pulse;//高电平宽度
static unsigned int l_pulse;//低电平宽度
static unsigned char remote_cout;//遥控器数量
static unsigned char remote_numb;//遥控器编号
/******************************************************************************/
static unsigned char TIMER15S1;//清除学习码按键长按时间
static unsigned char TIMER15S2;//学习等待时间
static unsigned char TIMER15S3;//遥控器数据缓冲时间
static unsigned char TIMER15S4;//LED显示时间
static unsigned char TIMER15S5;//
static unsigned char TIMER15S6;//
static unsigned char TIMER15S7;//
static unsigned char TIMER15S8;//
/******************************************************************************/
static bit head @ ((unsigned)(&rec_status)*8+(0));//同步头标志位
static bit learn @((unsigned)(&rec_status)*8+(1));//学习标志位
static bit recieved @((unsigned)(&rec_status)*8+(2));//接收完成标志位
static bit remote_button_status @((unsigned)(&rec_status)*8+(3));//遥控器按键标志位
static bit first_click_status @((unsigned)(&rec_status)*8+(4));//遥控器按键单击标志位
/******************************************************************************/
/********************************** 数据接收 **********************************/
/******************************************************************************/
unsigned char data_read(void)
{
if(h_pulse>l_pulse)
{
if((l_pulse>200)&&(l_pulse<1000))
{
if(h_pulse<(l_pulse<<2))return 1;//数据为1
}
return 2;//无效的数据
}
else if(h_pulse<l_pulse)
{
if((h_pulse>200)&&(h_pulse<1000))
{
if(l_pulse<(h_pulse<<2))return 0;//数据为0
}
return 2;//无效的数据
}
}
/******************************************************************************/
void clr_head(void)//清除寄存器
{
data_cout=0;
head=0;
}
/******************************************************************************/
#pragma interrupt_level 1
void check_data(void)//检测数据是否正确
{
if(head)
{
switch(data_read())
{
case 0:(data_temp.data_temp_long)<<=1;;data_cout++;break;
case 1:(data_temp.data_temp_long)<<=1;(data_temp.data_temp_long)++;;data_cout++;b
}
}
/******************************************************************************/
void clr_head(void)//清除寄存器
{
data_cout=0;
head=0;
}
/******************************************************************************/
#pragma interrupt_level 1
void check_data(void)//检测数据是否正确
{
if(head)
{
switch(data_read())
{
case 0:(data_temp.data_temp_long)<<=1;;data_cout++;break;
case 1:(data_temp.data_temp_long)<<=1;(data_temp.data_temp_long)++;;data_cout++;b
}
}
/******************************************************************************/
#pragma interrupt_level 1
void interrupt level_h_l(void)
{
/* if(RAIF)//如果是电平中断
{
PORTA=PORTA;
RAIF=0;//
TIMER1_TEMP.REG[0]=TMR1L;
TIMER1_TEMP.REG[1]=TMR1H;
TMR1H=0;
TMR1L=0;
if(RA4)//如果是低电平中断
{