專注電子技術(shù)學(xué)習(xí)與研究
當(dāng)前位置:單片機教程網(wǎng) >> MCU設(shè)計實例 >> 瀏覽文章

單片機紅外解碼查詢法(HS9148)

作者:佚名   來源:本站原創(chuàng)   點擊數(shù):  更新時間:2013年11月11日   【字體:
      本方案解碼對象是蘇州華芯微電子的HS9148發(fā)生芯片的遙控信號;該芯片可以有單發(fā)碼,連發(fā)碼,等組合方式。具體功能可以參考其PDF文件,F(xiàn)在對其中6組連發(fā)碼K1-K6進行解碼。本程序采用PIC16F505進行軟件延時方法,通過查詢紅外接收口的電平變化規(guī)律,來進行按鍵解碼。
 

     先看一下連發(fā)碼的傳輸規(guī)律,如下圖所示

這個是發(fā)射器上面的碼型,經(jīng)過紅外接收模塊后,信號與發(fā)射型號是反相的。如下圖:



 

其中a的值可以左右計算a=(1/fosc)*192,當(dāng)采用455E的晶振時候 a=0.422ms.

在看看“0”和“1”的定義,對單片機接收端而言,下面圖示是01的定義


 

由圖可以看出來,高電平過后,低電平持續(xù)時間為3a定義為邏輯1,高電平過后低電平持續(xù)時間為a定義為邏輯0。(理解了這個規(guī)律對解碼能否成功有著非常重大的意義)。

     為了驗證PDF上的高低電平時間定義的正確性,用示波器檢測了其中某幾個按鍵的紅外接收端的波型。如下所示:


 

 




對其時間測試發(fā)現(xiàn)和
PDF上的資料基本符合。

本程序靈敏度和抗干擾能力還有待提高。本文目的在于尋找紅外解碼的方法,如何做到簡單有效。RB2為遙控接收腳,RC0RC1,RC2RC3鏈接LED指示燈,程序代碼如下(下載地址:http://www.torrancerestoration.com/f/pichon.rar ):

#include<pic.h>

__CONFIG(0X034);

#define uchar unsigned char

#define uint unsigned int

Unsigned char head_ok;//頭碼標(biāo)志

unsigned char code_ok;//解碼成功標(biāo)志

unsigned char code1;//系統(tǒng)碼

unsigned char code2;//按鍵碼

unsigned char i,//系統(tǒng)碼解碼次數(shù)

unsigned char n,//按鍵碼解碼次數(shù)

 

void delay2(uint b)//us級別延時

{

 

unsigned int j;

for(j=0;j<b;j++)

{

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

asm("nop");

}

 

}

void head_scan()//頭碼檢測,實際上是在檢測C1C2C3也就是遙控器類型識別,意思是,你要遙控電視機還是電風(fēng)扇,本程序并沒有對這幾位碼進行識別,而是把他們當(dāng)初紅外信號的有無處理

{

HH:

while(RB2);等待RB2腳變成低電平

delay2(100);//延時4.5msC1C2C3根據(jù)資料為:110)意思是,低電平過后延時10a的時間,如果RB2為高電平,說明C1C2C3已經(jīng)來到單片機端口。

if(RB2==1)//如果是高電平說明頭碼來了

{

 

head_ok=1;//頭碼標(biāo)志置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如果RB20說明,是邏輯1

              {

              code1=code1|0x80;

              while(RB2);//等待RB2變成低電平,為接收下一位做準(zhǔn)備

              }

              else

         code1=code1|0x00;

         while(RB2);//等待RB2變成低電平,為接收下一位做準(zhǔn)備

             

 }

 

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;//認(rèn)為解碼成功

        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次后變成000001000X04)。以此類推其他碼為:

K2—00001000;四次移位(0X80)

K3—00010000;三次次移位(0X10)

K4—00100000;二次次移位(0X20)

K5—01000000;一次移位(0X40)

K6—10000000;0次移位(0X80) 

本文只是初步實現(xiàn)簡單方法解碼過程,各項指標(biāo)還要進一步提高。

關(guān)閉窗口

相關(guān)文章