單片機紅外解碼查詢法(HS9148)
void head_scan()//頭碼檢測,實際上是在檢測C1C2C3也就是遙控器類型識別,意思是,你要遙控電視機還是電風扇,本程序并沒有對這幾位碼進行識別,而是把他們當初紅外信號的有無處理
{
HH:
while(RB2);等待RB2腳變成低電平
delay2(100);//延時4.5ms(C1C2C3根據(jù)資料為:110)意思是,低電平過后延時10a的時間,如果RB2為高電平,說明C1C2C3已經(jīng)來到單片機端口。
if(RB2==1)//如果是高電平說明頭碼來了
{
head_ok=1;//頭碼標志置1
}
else goto HH;沒有找到頭碼,繼續(xù)回到HH口尋找。
}
void code_scan()
{
for(i=0;i<3;i++)//檢測H,S1,S2幾位碼
{
delay2(17);//延時0.844MS
code1=code1>>1;
if(RB2==0)//延時0.8MS如果RB2為0說明,是邏輯1。
{
code1=code1|0x80;
while(RB2);//等待RB2變成低電平,為接收下一位做準備
}
else
code1=code1|0x00;
while(RB2);//等待RB2變成低電平,為接收下一位做準備
}
for(n=0;n<6;n++)//解碼K1-K6
{
delay2(17);//延時0.844US
code2=code2>>1;
if(RB2==0)
{
code2=code2|0x80;
while(RB2);
}
else
{
code2=code2|0x00;
while(RB2);
}
delay2(100);//延時4.5MS//由于本程序是檢測按下一次有效的情況,所以,第一次解碼完畢后,發(fā)射器在過了80a時間后會在發(fā)一次碼,本意是作為上次的校驗碼,但是本程序只是檢測第一次的發(fā)生碼,第二次的碼,沒有檢測。
if(RB2==1)如果是為1,說明80a間間隔到來,
{
code_ok=1;//認為解碼成功
return; //并且退出整個解碼程序,回到主程序的其他函數(shù)執(zhí)行。Return語句有退出整個函數(shù)的功能。
}
}
void main()
{
TRISB=0b00000100;
PORTB=0X00;
TRISC=0b00000000;
PORTC=0X00;
while(1)
{
head_scan();//頭碼檢測
if(head_ok==1)
{
code_scan();//解碼函數(shù)
}
if(code_ok==1)//解碼成功
{
switch(code2)//散轉(zhuǎn)功能
{
case 0x20:
RC0=1;
RC1=0;
RC2=0;
RC3=0;
break;
case 0x10:
RC0=0;
RC1=1;
RC2=0;
RC3=0;
break;
case 0x40:
RC0=0;
RC1=0;
RC2=1;
RC3=0;
break;
case 0x80:
RC0=0;
RC1=0;
RC2=0;
RC3=1;
break;
}
}
}
}
本程序是對12位碼元進行解碼,還涉及,解碼成功后,碼元的存放問題,由于定義的變量為char型,只有8位,所以要分別給系統(tǒng)碼和按鍵碼獨立定義變量,code1,code2。以按鍵K1為例,K1的碼為:000001,由于第一次判斷其為1的時候,把他放在char型變量中,其值為,10000000,那么向右移動5次后變成00000100(0X04)。以此類推其他碼為:
K2—00001000;四次移位(0X80)
K3—00010000;三次次移位(0X10)
K4—00100000;二次次移位(0X20)
K5—01000000;一次移位(0X40)
K6—10000000;0次移位(0X80)
本文只是初步實現(xiàn)簡單方法解碼過程,各項指標還要進一步提高。
評論