導航:首頁 > 編程語言 > nec紅外解碼程序

nec紅外解碼程序

發布時間:2023-03-27 07:29:34

① nec紅外遙控器按鍵對應的二進制碼

按鍵的鍵碼二進制是0x0C。反碼就是0xF3,最後跟了一個560us載波停止臘緩位。紅外遙控由發射部分和接收部分兩部分組成,發射部分通過控制控制紅外發光管發射出經過調制好的紅外線來傳毀陪遞需要發送的信息,接收部分電路由紅外接收管等其他紅外接收器件接收發射管發射的紅外光傳遞信號給放大器以及其他解碼設備來還原紅外發射的信息。纖局蠢NEC編碼就是紅外的一種調制方式,對發射的紅外進行特定的編碼來發送需要發送的信息,接收端針對發射端的編碼進行解碼從而達到還原信息。

② 用51單片機製作學習型紅外遙控器的原理

以下是程序,調試成功,LCD1602顯示

//本解碼程序適用於NEC的upd6121及其兼容晶元的解碼,支持大多數遙控器實驗板採用11.0592MHZ晶振

#include<reg52.h>//包含單片機寄存器的頭文件

#include<intrins.h>//包含_nop_()函數定義的頭文件

sbitIR=P3^2;//將IR位定義為P3.2引腳

sbitRS=P2^0;//寄存器選擇位,將RS位定義為P2.0引腳

sbitRW=P2^1;//讀寫選擇位,將RW位定義為P2.1引腳

sbitE=P2^2;//使能信號位,將E位定義為P2.2引腳

sbitBF=P0^7;//忙碌標志位,,將BF位定義為P0.7引腳

sbitBEEP=P3^6;//蜂鳴器控制埠P36

unsignedcharflag;

unsignedcharcodestring[]={"1602IR-CODETEST"};

unsignedchara[4];//儲存用戶碼、用戶反碼與鍵數據碼、鍵數據反碼

unsignedintLowTime,HighTime;//儲存高、低電平的寬度

/*****************************************************

函數功能:延時1ms

***************************************************/

voiddelay1ms()

{

unsignedchari,j;

for(i=0;i<10;i++)

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

;

}

/*****************************************************

函數功能:延時若干毫秒

入口參數:n

***************************************************/

voiddelay(unsignedcharn)

{

unsignedchari;

for(i=0;i<n;i++)

delay1ms();

}

/*********************************************************/

voidbeep()//蜂鳴器響一聲函數

{

unsignedchari;

for(i=0;i<100;i++)

{

delay1ms();

BEEP=!BEEP;//BEEP取反

}

BEEP=1;//關閉蜂鳴器

delay(250);//延時

}

/*****************************************************

函數功能:判斷液晶模塊的忙碌狀態

返回值:result。result=1,忙碌;result=0,不忙

***************************************************/

unsignedcharBusyTest(void)

{

bitresult;

RS=0;//根據規定,RS為低電平,RW為高電平時,可以讀狀態

RW=1;

E=1;//E=1,才允許讀寫

_nop_();//空操作

_nop_();

_nop_();

_nop_();//空操作四個機器周期,給硬體反應時間

result=BF;//將忙碌標志電平賦給result

E=0;

returnresult;

}

/*****************************************************

函數功能:將模式設置指令或顯示地址寫入液晶模塊

入口參數:dictate

***************************************************/

voidWriteInstruction(unsignedchardictate)

{

while(BusyTest()==1);//如果忙就等待

RS=0;//根據規定,RS和R/W同時為低電平時,可以寫入指令

RW=0;

E=0;//E置低電平(根據表8-6,寫指令時,E為高脈沖,

//就是讓E從0到1發生正跳變,所以應先置"0"

_nop_();

_nop_();//空操作兩個機器周期,給硬體反應時間

P0=dictate;//將數據送入P0口,即寫入指令或地址

_nop_();

_nop_();

_nop_();

_nop_();//空操作四個機器周期,給硬體反應時間

E=1;//E置高電平

_nop_();

_nop_();

_nop_();

_nop_();//空操作四個機器周期,給硬體反應時間

E=0;//當E由高電平跳變成低電平時,液晶模塊開始執行命令

}

/*****************************************************

函數功能:指定字元顯示的實際地址

入口參數:x

***************************************************/

voidWriteAddress(unsignedcharx)

{

WriteInstruction(x|0x80);//顯示位置的確定方法規定為"80H+地址碼x"

}

/*****************************************************

函數功能:將數據(字元的標准ASCII碼)寫入液晶模塊

入口參數:y(為字元常量)

***************************************************/

voidWriteData(unsignedchary)

{

while(BusyTest()==1);

RS=1;//RS為高電平,RW為低電平時,可以寫入數據

RW=0;

E=0;//E置低電平(根據表8-6,寫指令時,E為高脈沖,

//就是讓E從0到1發生正跳變,所以應先置"0"

P0=y;//將數據送入P0口,即將數據寫入液晶模塊

_nop_();

_nop_();

_nop_();

_nop_();//空操作四個機器周期,給硬體反應時間

E=1;//E置高電平

_nop_();

_nop_();

_nop_();

_nop_();//空操作四個機器周期,給硬體反應時間

E=0;//當E由高電平跳變成低電平時,液晶模塊開始執行命令

}

/*****************************************************

函數功能:對LCD的顯示模式進行初始化設置

***************************************************/

voidLcdInitiate(void)

{

delay(15);//延時15ms,首次寫指令時應給LCD一段較長的反應時間

WriteInstruction(0x38);//顯示模式設置:16×2顯示,5×7點陣,8位數據介面

delay(5);//延時5ms

WriteInstruction(0x38);

delay(5);

WriteInstruction(0x38);

delay(5);

WriteInstruction(0x0C);//顯示模式設置:顯示開,有游標,游標閃爍

delay(5);

WriteInstruction(0x06);//顯示模式設置:游標右移,字元不移

delay(5);

WriteInstruction(0x01);//清屏幕指令,將以前的顯示內容清除

delay(5);

}

/************************************************************

函數功能:對4個位元組的用戶碼和鍵數據碼進行解碼

說明:解碼正確,返回1,否則返回0

出口參數:dat

*************************************************************/

bitDeCode(void)

{

unsignedchari,j;

unsignedchartemp;//儲存解碼出的數據

for(i=0;i<4;i++)//連續讀取4個用戶碼和鍵數據碼

{

for(j=0;j<8;j++)//每個碼有8位數字

{

temp=temp>>1;//temp中的各數據位右移一位,因為先讀出的是高位數據

TH0=0;//定時器清0

TL0=0;//定時器清0

TR0=1;//開啟定時器T0

while(IR==0)//如果是低電平就等待

;//低電平計時

TR0=0;//關閉定時器T0

LowTime=TH0*256+TL0;//保存低電平寬度

TH0=0;//定時器清0

TL0=0;//定時器清0

TR0=1;//開啟定時器T0

while(IR==1)//如果是高電平就等待

;

TR0=0;//關閉定時器T0

HighTime=TH0*256+TL0;//保存高電平寬度

if((LowTime<370)||(LowTime>640))

return0;//如果低電平長度不在合理范圍,則認為出錯,停止解碼

if((HighTime>420)&&(HighTime<620))//如果高電平時間在560微秒左右,即計數560/1.085=516次

temp=temp&0x7f;//(520-100=420,520+100=620),則該位是0

if((HighTime>1300)&&(HighTime<1800))//如果高電平時間在1680微秒左右,即計數1680/1.085=1548次

temp=temp|0x80;//(1550-250=1300,1550+250=1800),則該位是1

}

a[i]=temp;//將解碼出的位元組值儲存在a[i]

}

if(a[2]=~a[3])//驗證鍵數據碼和其反碼是否相等,一般情況下不必驗證用戶碼

return1;//解碼正確,返回1

}

/*------------------二進制碼轉換為壓縮型BCD碼,並顯示---------------*/

voidtwo_2_bcd(unsignedchardate)

{

unsignedchartemp;

temp=date;

date&=0xf0;

date>>=4;//右移四位得到高四位碼

date&=0x0f;//與0x0f想與確保高四位為0

if(date<=0x09)

{

WriteData(0x30+date);//lcd顯示鍵值高四位

}

else

{

date=date-0x09;

WriteData(0x40+date);

}

date=temp;

date&=0x0f;

if(date<=0x09)

{

WriteData(0x30+date);//lcd顯示低四位值

}

else

{

date=date-0x09;

WriteData(0x40+date);

}

WriteData(0x48);//顯示字元'H'

}

/************************************************************

函數功能:1602LCD顯示

*************************************************************/

voidDisp(void)

{

WriteAddress(0x40);//設置顯示位置為第一行的第1個字

two_2_bcd(a[0]);

WriteData(0x20);

two_2_bcd(a[1]);

WriteData(0x20);

two_2_bcd(a[2]);

WriteData(0x20);

two_2_bcd(a[3]);

}

/************************************************************

函數功能:主函數

*************************************************************/

voidmain()

{

unsignedchari;

LcdInitiate();//調用LCD初始化函數

delay(10);

WriteInstruction(0x01);//清顯示:清屏幕指令

WriteAddress(0x00);//設置顯示位置為第一行的第1個字

i=0;

while(string[i]!='')//''是數組結束標志

{//顯示字元WWW.RICHMCU.COM

WriteData(string[i]);

i++;

}

EA=1;//開啟總中斷

EX0=1;//開外中斷0

ET0=1;//定時器T0中斷允許

IT0=1;//外中斷的下降沿觸發

TMOD=0x01;//使用定時器T0的模式1

TR0=0;//定時器T0關閉

while(1);//等待紅外信號產生的中斷

}

/************************************************************

函數功能:紅外線觸發的外中斷處理函數

*************************************************************/

voidInt0(void)interrupt0

{

EX0=0;//關閉外中斷0,不再接收二次紅外信號的中斷,只解碼當前紅外信號

TH0=0;//定時器T0的高8位清0

TL0=0;//定時器T0的低8位清0

TR0=1;//開啟定時器T0

while(IR==0);//如果是低電平就等待,給引導碼低電平計時

TR0=0;//關閉定時器T0

LowTime=TH0*256+TL0;//保存低電平時間

TH0=0;//定時器T0的高8位清0

TL0=0;//定時器T0的低8位清0

TR0=1;//開啟定時器T0

while(IR==1);//如果是高電平就等待,給引導碼高電平計時

TR0=0;//關閉定時器T0

HighTime=TH0*256+TL0;//保存引導碼的高電平長度

if((LowTime>7800)&&(LowTime<8800)&&(HighTime>3600)&&(HighTime<4700))

{

//如果是引導碼,就開始解碼,否則放棄,引導碼的低電平計時

//次數=9000us/1.085=8294,判斷區間:8300-500=7800,8300+500=8800.

if(DeCode()==1)//執行遙控解碼功能

{

Disp();//調用1602LCD顯示函數

beep();//蜂鳴器響一聲提示解碼成功

}

}

EX0=1;//開啟外中斷EX0

}

③ 單片機紅外解碼程序問題,完全不能理解

「我並非一點基礎也沒有」
很遺憾,從你提的這三個問題來看,你的基礎比0隻多出一點點。
(1)Tc是個16位整型。這是16位整型的基本演算法。Tc保存的是抓出的脈寬。
(2)引導碼就是指定寬度的脈沖,數據碼是短一些的脈沖——所以才會那麼大費周章地抓脈寬判斷是引導碼還是用戶碼。接收是否反相要查你所局銀用接收頭的手冊,有可能跟你的程序是相桐祥宴反的。
(3)m不是字宴碼節序號而是位序號。注意前面的/8。
加油啊

④ 大神幫忙,本程序是HX1838B的NEC解碼程序,把接收到的第三個位元組數據顯示在P1口LED,可是隨意按鍵燈全亮

因為你按手帶鍵按下後開始延時,在延時的這段時畢逗間內CPU不能響應按鍵松開畢數蘆的信號,你要是換成定時器來計時就好了

⑤ 用C語言編寫的紅外發射與接收程序

給你一段430單片機遙控器解碼的程序吧,也就是接收部分
畢竟世界太現實只能這么幫你
#ifndef _IR_
#define _IR_

char t0,t1,t2;

uchar IR;
void DelayIR()
{
uint i=130;
while(i--);
}
void init_port2(void)
{
P2DIR&=~BIT0;
P2SEL&=~BIT0;
P2IES|=BIT0;
P2IE|=BIT0;
}
#pragma vector=PORT2_VECTOR
__interrupt void PORT2_ISR(void)
{
char CounterIR;
P2IES&=~BIT0;
if(P2IFG&BIT0)
{
P2IFG&=~BIT0;
}
CounterIR=0;
while(!(P2IN&BIT0))
{
DelayIR();
CounterIR++;
}

if(CounterIR>85)
{
if(CounterIR<95)
{
t1++;
for(char k=0;k<17;k++)
{
CounterIR=0;
while((P2IN&BIT0)&&(CounterIR<50))
{
DelayIR();
CounterIR++;
}
CounterIR=0;
while((!(P2IN&BIT0))&&(CounterIR<10))
{
DelayIR();
CounterIR++;
}
}
for(char j=0;j<8;j++)
{
CounterIR=0;
while((P2IN&BIT0)&&(CounterIR<25))
{
DelayIR();
CounterIR++;
}
IR<<=1;
if(CounterIR>11)
IR|=BIT0;
CounterIR=0;
while((!(P2IN&BIT0))&&(CounterIR<10))
{
DelayIR();
CounterIR++;
}
}

if((IR!=0xff)&&(IR!=0x00))
{
if(!(flag&dataflag))
{
if(IR==0x22)
{
flag|=runflag;
}
else
{
Tar[0]=Tar[1];
Tar[1]=Tar[2];
Tar[2]=Tar[3];
Tar[3]=Tar[4];
switch (IR)
{
//case 0x22 : flag|=runflag;break;
case 0x68 : Tar[4]=0;flag|=dataflag;break;
case 0x30 : Tar[4]=1;flag|=dataflag;break;
case 0x18 : Tar[4]=2;flag|=dataflag;t2++;break;
case 0x7a : Tar[4]=3;flag|=dataflag;break;
case 0x10 : Tar[4]=4;flag|=dataflag;break;
case 0x38 : Tar[4]=5;flag|=dataflag;break;
case 0x5a : Tar[4]=6;flag|=dataflag;break;
case 0x42 : Tar[4]=7;flag|=dataflag;break;
case 0x4a : Tar[4]=8;flag|=dataflag;break;
case 0x52 : Tar[4]=9;flag|=dataflag;break;
default : break;
}
}
}
}
IR=0;
}
}
for(int m=0;m<250;m++)
DelayIR();
P2IES|=BIT0;
}
#endif
請採納。

⑥ 51單片機紅外接收端的程序怎麼寫,我想知道寫的方法和原理,最好有一個具體的模版,好讓我參考.

這是採用STC12C5A60S2單片機的紅外解碼程序及其說明。
;採用脈寬調制的串列碼,以脈寬為0.565ms、間隔0.56ms、周期為1.125ms的組合表示二進制的"0";
;以脈寬為0.565ms、間隔1.685ms、周期為2.25ms的組合表示二進制的"1
;上述"0"和"1"組成的32位二進制碼經38kHz的載頻進行二次調制以提高發射效率,
;達到降低電源功耗的目的。然後再通過紅外發射二極體產生紅外線向空間發射
;遙控編碼是連續的32位二進制碼組,其中前16位為用戶識別碼,能區別不同的電器設備,
;防止不同機種遙控碼互相干擾。該晶元的用戶識別碼固定為十六進制01H
;後16位為8位操作碼(功能碼)及其反碼。
;當一個鍵按下超過36ms,振盪器使晶元激活,將發射一組108ms的編碼脈沖,這108ms發射代碼由一個起始碼(9ms),
;一個結果碼(4.5ms),低8位地址碼(9ms~18ms),高8位地址碼(9ms~18ms),8位數據碼(9ms~18ms)
;和這8位數據的反碼(9ms~18ms)組成。如果鍵按下超過108ms仍未松開,
;接下來發射的代碼(連發代碼)將僅由起始碼(9ms)和結束碼(2.5ms)組成。
;
;解碼的關鍵是如何識別"0"和"1",接收端而言,"0"是0.56ms的高+0.56ms的低。"1"是1.68ms的高+0.56ms的低。
;所以可以根據高電平的寬度區別"0"和"1"。當高電平出現時開始延時,0.56ms以後,若讀到的電平為低,
;說明該位為"0",反之則為"1",為了可靠起見,延時必須比0.56ms長些,但又不能超過1.12ms,否則如果該位為"0",
;讀到的已是下一位的高電平,因此取(1.12ms+0.56ms)/2=0.84ms最為可靠,一般取0.84ms左右均可。
;為了共用引導部分延時程序,這里用0.9ms延時。
;-------------紅外解碼程序---------------------------
EXINT0:
PUSH ACC
PUSH PSW
PUSH 1
PUSH 2
PUSH 6
CLR EA ;暫時關閉中斷請求
MOV R6,#10
EXINT10:
LCALL DELAY09MS ;調用900us延時子程序
JB IRIN,INTOUT1 ;判斷P3.2是否有高電平,如果有就退出解碼程序
DJNZ R6,EXINT10 ;循環10次,檢測在900微妙中是否存在高電平。以上完成對遙控信號的9000微秒的初始低電平信號的識別。
JNB IRIN,$ ;等待高電平避開9毫秒低電平引導脈沖
LCALL DELAY45MS ;延時4.5毫秒
;-------------接受32位代碼--------------------------
MOV R1,#IRUSERL
MOV R2,#04H
EXINT101:
MOV R6,#08H ;每組數據位8位
EXINT102:
JNB IRIN,$ ;等待地址碼第一組數據的高電平信號
LCALL DELAY09MS ;高電平開始後延時判斷信號此時的高/低狀態
MOV C,IRIN ;將P3.2引腳此時的電平狀態0或1存入C中
JNC INT1OUT ;如果為0跳出
LCALL DELAY1MS
INT1OUT:
MOV A,@R1
RRC A ;將C中的數據0/1移入A中最低位
MOV @R1,A ;將A中的數據暫存在R1
DJNZ R6,EXINT102 ;接受完8位代碼
INC R1
DJNZ R2,EXINT101 ;接受完4組32位代碼
;--------------數據碼比較-------------------------------
MOV A,IRDATAL
; LCALL SENDRXDAT
MOV A,IRDATAL
CPL A
CJNE A,IRDATAH,INTOUT1 ;判斷數碼正誤,不等退出
MOV IR_DAT,IRDATAL ;相等則保存正確數據
MOV A,IR_DAT
; LCALL SENDRXDAT
SETB IRBIT
INTOUT1:
LCALL DELAY45MS
SETB EA ;允許中斷
POP 6
POP 2
POP 1
POP PSW
POP ACC
RETI
;;*****************11.0592*900=9953******************
DELAY09MS: ;6
PUSH 4 ;4
PUSH 3 ;4
MOV R4,#20 ;2
DLY900:
MOV R3,#122 ;2
DJNZ R3,$ ;4
DJNZ R4,DLY900 ;4
MOV R4,#11 ;2
DJNZ R4,$ ;4
POP 3 ;3
POP 4 ;3
RET ;4
;TOTAL=9952
;;*****************11.0592*560=6193******************
DELAY056: ;6
PUSH 4 ;4
PUSH 3 ;4
MOV R4,#12 ;2
DLY5600:
MOV R3,#122 ;2
DJNZ R3,$ ;4
DJNZ R4,DLY5600 ;4
MOV R4,#71 ;2
DJNZ R4,$ ;4
POP 3 ;3
POP 4 ;3
RET ;4
;TOTAL=6194
;;*****************11.0592*4500=49766****************
DELAY45MS: ;6
PUSH 4 ;4
PUSH 3 ;4
MOV R4,#52 ;2
DLY45:
MOV R3,#236 ;2
DJNZ R3,$ ;4
DJNZ R4,DLY45 ;4
MOV R4,#85 ;2
DJNZ R4,$ ;4
POP 3 ;3
POP 4 ;3
RET ;4
;;TOTAL=49768
;;*****************11.0592*1000=11059****************
DELAY1MS: ;6
PUSH 4 ;4
PUSH 3 ;4
MOV R4,#20 ;2
DLY1MS:
MOV R3,#136 ;2
DJNZ R3,$ ;4
DJNZ R4,DLY1MS ;4
MOV R4,#8 ;2
DJNZ R4,$ ;4
POP 3 ;3
POP 4 ;3
RET ;4
;TOTAL=11060
;;***************************************************
DELAY100US: ;6
PUSH 4 ;4
MOV R4,#140 ;2
DJNZ R4,$ ;4
MOV R4,#131 ;2
DJNZ R4,$ ;4
POP 4 ;3
RET ;4
;TOTAL=1105
;;***************************************************

⑦ c51單片機紅外NEC編碼解碼!

這個程序太簡單了,我之前寫過紅外發射程序的,接收程序也很簡單,你這個項目我2個小時內都能幫你解決,容但是89C52單片機發射38K不準需要把晶振加大,提高單片機的運行速度。
你的項目只要主機A發射紅外協議後面加一個地址,單片機B接收的時候全部進入接收狀態,判接收的地址是否符合對於單片機B的地址,如果地址符合,那就先回應一個數據例如:55FF55,主機接收到55FF55後後面開始接收數據,把接收到的數據直接寫入單片機內EEPRM裡面!

⑧ 求單片機紅外遙控解碼識別長按和短按鍵的C語言例子

簡單點的話,其實也可以用定時器,比如你定時器記一個time的數,那麼在整個遙控的過程中,time不會大於( 隔110ms左右發一次引導碼(重復),並不帶任何數據(全部為高電平))150/256us約等於600,那麼你在一個循環里就可以寫 ps:定時器我用的8位自動重裝
if(time<600)//相當於長按了
{寫你想寫的}

⑨ 如何編寫紅外遙控器 客戶碼

以下是程序,調試成功,LCD1602顯示
//本解碼程序適用於NEC的upd6121及其兼容晶元的解碼,支持大多數遙控器 實驗板採用11.0592MHZ晶振
#include<reg52.h> //包含單片機寄存器的頭文件
#include<intrins.h> //包含_nop_()函數定義的頭文件
sbit IR=P3^2; //將IR位定義為P3.2引腳
sbit RS=P2^0; //寄存器選擇位,將RS位定義為P2.0引腳
sbit RW=P2^1; //讀寫選擇位,將RW位定義為P2.1引腳
sbit E=P2^2; /數滑/使能信號位,將E位定義為P2.2引腳
sbit BF=P0^7; //忙碌標志位,,將BF位定義為P0.7引腳
sbit BEEP = P3^6; //蜂鳴器控制埠P36
unsigned char flag;
unsigned char code string[ ]= {"1602IR-CODE TEST"};
unsigned char a[4]; //儲存用戶碼、用戶反碼與鍵數據碼、鍵數據反碼
unsigned int LowTime,HighTime; //儲存高、低電平的寬度
/*****************************************************
函數功能:延時1ms
***************************************************/
void delay1ms()
{
unsigned char i,j;
for(i=0;i<10;i++)
for(j=0;j<33;j++)
;
}
/*****************************************************
函數功能:延時若干毫秒
入口參數:n
***************************************************/
void delay(unsigned char n)
{
unsigned char i;
for(i=0;i<n;i++)
delay1ms();
}

/*********************************************************/
void beep() //蜂鳴器響一聲函數
{
unsigned char i;
for (i=0;i<100;i++)
{
delay1ms();
BEEP=!BEEP; //BEEP取反
}
BEEP=1; //關閉蜂鳴器
delay(250); //延時
}

/*****************************************************
函數功能:判斷液晶模塊的忙碌狀態
返碰畢頃回值:result。result=1,忙碌;result=0,不忙
***************************************************/
unsigned char BusyTest(void)
{
bit result;
RS=0; //根據規定,RS為低電平,RW為高電平時,可以讀狀態
RW=1;
E=1; //E=1,才允許讀寫
_nop_(); //空操作
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給笑陸硬體反應時間
result=BF; //將忙碌標志電平賦給result
E=0;
return result;
}
/*****************************************************
函數功能:將模式設置指令或顯示地址寫入液晶模塊
入口參數:dictate
***************************************************/
void WriteInstruction (unsigned char dictate)
{
while(BusyTest()==1); //如果忙就等待
RS=0; //根據規定,RS和R/W同時為低電平時,可以寫入指令
RW=0;
E=0; //E置低電平(根據表8-6,寫指令時,E為高脈沖,
// 就是讓E從0到1發生正跳變,所以應先置"0"
_nop_();
_nop_(); //空操作兩個機器周期,給硬體反應時間
P0=dictate; //將數據送入P0口,即寫入指令或地址
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬體反應時間
E=1; //E置高電平
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬體反應時間
E=0; //當E由高電平跳變成低電平時,液晶模塊開始執行命令
}
/*****************************************************
函數功能:指定字元顯示的實際地址
入口參數:x
***************************************************/
void WriteAddress(unsigned char x)
{
WriteInstruction(x|0x80); //顯示位置的確定方法規定為"80H+地址碼x"
}
/*****************************************************
函數功能:將數據(字元的標准ASCII碼)寫入液晶模塊
入口參數:y(為字元常量)
***************************************************/
void WriteData(unsigned char y)
{
while(BusyTest()==1);
RS=1; //RS為高電平,RW為低電平時,可以寫入數據
RW=0;
E=0; //E置低電平(根據表8-6,寫指令時,E為高脈沖,
// 就是讓E從0到1發生正跳變,所以應先置"0"
P0=y; //將數據送入P0口,即將數據寫入液晶模塊
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬體反應時間
E=1; //E置高電平
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬體反應時間
E=0; //當E由高電平跳變成低電平時,液晶模塊開始執行命令
}
/*****************************************************
函數功能:對LCD的顯示模式進行初始化設置
***************************************************/
void LcdInitiate(void)
{
delay(15); //延時15ms,首次寫指令時應給LCD一段較長的反應時間
WriteInstruction(0x38); //顯示模式設置:16×2顯示,5×7點陣,8位數據介面
delay(5); //延時5ms
WriteInstruction(0x38);
delay(5);
WriteInstruction(0x38);
delay(5);
WriteInstruction(0x0C); //顯示模式設置:顯示開,有游標,游標閃爍
delay(5);
WriteInstruction(0x06); //顯示模式設置:游標右移,字元不移
delay(5);
WriteInstruction(0x01); //清屏幕指令,將以前的顯示內容清除
delay(5);
}
/************************************************************
函數功能:對4個位元組的用戶碼和鍵數據碼進行解碼
說明:解碼正確,返回1,否則返回0
出口參數:dat
*************************************************************/
bit DeCode(void)
{

unsigned char i,j;
unsigned char temp; //儲存解碼出的數據
for(i=0;i<4;i++) //連續讀取4個用戶碼和鍵數據碼
{
for(j=0;j<8;j++) //每個碼有8位數字
{
temp=temp>>1; //temp中的各數據位右移一位,因為先讀出的是高位數據
TH0=0; //定時器清0
TL0=0; //定時器清0
TR0=1; //開啟定時器T0
while(IR==0) //如果是低電平就等待
; //低電平計時
TR0=0; //關閉定時器T0
LowTime=TH0*256+TL0; //保存低電平寬度
TH0=0; //定時器清0
TL0=0; //定時器清0
TR0=1; //開啟定時器T0
while(IR==1) //如果是高電平就等待
;
TR0=0; //關閉定時器T0
HighTime=TH0*256+TL0; //保存高電平寬度
if((LowTime<370)||(LowTime>640))
return 0; //如果低電平長度不在合理范圍,則認為出錯,停止解碼
if((HighTime>420)&&(HighTime<620)) //如果高電平時間在560微秒左右,即計數560/1.085=516次
temp=temp&0x7f; //(520-100=420, 520+100=620),則該位是0
if((HighTime>1300)&&(HighTime<1800)) //如果高電平時間在1680微秒左右,即計數1680/1.085=1548次
temp=temp|0x80; //(1550-250=1300,1550+250=1800),則該位是1
}
a[i]=temp; //將解碼出的位元組值儲存在a[i]
}
if(a[2]=~a[3]) //驗證鍵數據碼和其反碼是否相等,一般情況下不必驗證用戶碼
return 1; //解碼正確,返回1
}

/*------------------二進制碼轉換為壓縮型BCD碼,並顯示---------------*/

void two_2_bcd(unsigned char date)
{

unsigned char temp;
temp=date;
date&=0xf0;
date>>=4; //右移四位得到高四位碼
date&=0x0f; //與0x0f想與確保高四位為0
if(date<=0x09)
{
WriteData(0x30+date); //lcd顯示鍵值高四位
}
else
{
date=date-0x09;
WriteData(0x40+date);
}
date=temp;
date&=0x0f;
if(date<=0x09)
{
WriteData(0x30+date); //lcd顯示低四位值
}
else
{
date=date-0x09;
WriteData(0x40+date);
}
WriteData(0x48); //顯示字元'H'
}
/************************************************************
函數功能:1602LCD顯示
*************************************************************/
void Disp(void)
{
WriteAddress(0x40); // 設置顯示位置為第一行的第1個字
two_2_bcd(a[0]);
WriteData(0x20);
two_2_bcd(a[1]);
WriteData(0x20);
two_2_bcd(a[2]);
WriteData(0x20);
two_2_bcd(a[3]);

}
/************************************************************
函數功能:主函數
*************************************************************/
void main()
{
unsigned char i;
LcdInitiate(); //調用LCD初始化函數
delay(10);
WriteInstruction(0x01);//清顯示:清屏幕指令
WriteAddress(0x00); // 設置顯示位置為第一行的第1個字
i = 0;
while(string[i] != '\0') //'\0'是數組結束標志
{ // 顯示字元 www.RICHMCU.COM
WriteData(string[i]);
i++;
}
EA=1; //開啟總中斷
EX0=1; //開外中斷0
ET0=1; //定時器T0中斷允許
IT0=1; //外中斷的下降沿觸發
TMOD=0x01; //使用定時器T0的模式1
TR0=0; //定時器T0關閉
while(1); //等待紅外信號產生的中斷

}
/************************************************************
函數功能:紅外線觸發的外中斷處理函數
*************************************************************/
void Int0(void) interrupt 0
{
EX0=0; //關閉外中斷0,不再接收二次紅外信號的中斷,只解碼當前紅外信號
TH0=0; //定時器T0的高8位清0
TL0=0; //定時器T0的低8位清0
TR0=1; //開啟定時器T0
while(IR==0); //如果是低電平就等待,給引導碼低電平計時
TR0=0; //關閉定時器T0
LowTime=TH0*256+TL0; //保存低電平時間
TH0=0; //定時器T0的高8位清0
TL0=0; //定時器T0的低8位清0
TR0=1; //開啟定時器T0
while(IR==1); //如果是高電平就等待,給引導碼高電平計時
TR0=0; //關閉定時器T0
HighTime=TH0*256+TL0; //保存引導碼的高電平長度
if((LowTime>7800)&&(LowTime<8800)&&(HighTime>3600)&&(HighTime<4700))
{
//如果是引導碼,就開始解碼,否則放棄,引導碼的低電平計時
//次數=9000us/1.085=8294, 判斷區間:8300-500=7800,8300+500=8800.
if(DeCode()==1) // 執行遙控解碼功能
{

Disp();//調用1602LCD顯示函數
beep();//蜂鳴器響一聲 提示解碼成功
}
}
EX0=1; //開啟外中斷EX0
}

⑩ 怎麼知道空調NEC紅外協議的命令碼分別代表什麼功能(如控制溫度,風速,濕度等)

紅外協議之NEC協議

NEC協議載波:38khz

其邏輯1與邏橡蘆輯0的表示如圖所示:

重復碼由9ms高電平和2.25ms的低電平以及560us的高電平組成。

需要注意的是:1838紅外一體接收頭為了提高接受靈敏度。輸入高電平,其輸出的是相反的低電平。

NEC解碼出來還是有點細微差錯。查了很久,也沒有收獲。心裡有點小郁悶。今早起來,仔細地看了看他人的參考代碼。突然被下面一個小小的細節折服了。

請注意這段代碼:

1 void hal_NEC_decode(uchar *addr,uchar *addrt,uchar *comm,uchar *commt)
2 {
3 uchar i,j,k;
4 uchar tmp1=0;
5
6 while(NECFinshFlag==0);
7 NECFinshFlag=0;
8
9 for(i=0,k=1;i<4;i=i+1)
10 {
11 for(j=1;j<=8;j++)
12 {
13 if(NECTimerTable[k++] > 7)
14 {
15 tmp1 |=0x80;
16 }
17 tmp1 >>=1;
18 }
19 switch(i)
20 {
21 case 0:*addr=tmp1;break;
22 case 1:*addrt=tmp1;break;
23 case 2:*comm=tmp1;break;
24 case 3:*commt=tmp1;break;
25 }
26 tmp1=0;
27 }
28 }

閱讀全文

與nec紅外解碼程序相關的資料

熱點內容
maya粒子表達式教程 瀏覽:84
抖音小視頻如何掛app 瀏覽:283
cad怎麼設置替補文件 瀏覽:790
win10啟動文件是空的 瀏覽:397
jk網站有哪些 瀏覽:134
學編程和3d哪個更好 瀏覽:932
win10移動硬碟文件無法打開 瀏覽:385
文件名是亂碼還刪不掉 瀏覽:643
蘋果鍵盤怎麼打開任務管理器 瀏覽:437
手機桌面文件名字大全 瀏覽:334
tplink默認無線密碼是多少 瀏覽:33
ipaddgm文件 瀏覽:99
lua語言編程用哪個平台 瀏覽:272
政采雲如何導出pdf投標文件 瀏覽:529
php獲取postjson數據 瀏覽:551
javatimetask 瀏覽:16
編程的話要什麼證件 瀏覽:94
錢脈通微信多開 瀏覽:878
中學生學編程哪個培訓機構好 瀏覽:852
榮耀路由TV設置文件共享錯誤 瀏覽:525

友情鏈接