說明如下:
1:利用陳老板給本人提供的MCD2及DEMO
2:選用PIC16F877A作為軟件解碼芯片
3:單片機時鐘頻率選用外部4MHZ晶振
4:選用外部中斷腳作為編碼信號腳輸入腳
5:可解PT2240芯片(8腳的學習型編碼芯片 編碼地址位:2的20次方 重復幾率100萬分之一)
6:功能有:遙控器學習(DEMO上的S9作為學習按紐) 清除記憶(長按DEMO上的S9即可清除遙控器地址的記憶)
7:學習遙控器數量可以設定(可根據EEPROM的大小 隨便設定)
8:輸出功能(有三路是 單擊遙控器雙穩(wěn),可以通過PORTC上的LED可以看到結果.還有一路是 雙擊遙控器雙穩(wěn))
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)//如果是低電平中斷
{