導航:首頁 > 操作系統 > 基於單片機紅外遙控系統

基於單片機紅外遙控系統

發布時間:2022-11-27 10:33:16

❶ 51單片機紅外遙控程序

#include<reg52.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned int
sbit lcden = P2^7;
sbit lcdrs = P2^6;
sbit lcdwr = P2^5;
sbit IR = P3^2;
uchar IRCOM[6];//數組,用於存儲紅外編碼
uchar code table1[] = "remote control";
uchar code table2[] = "CODE:";
void delayms(uchar x)// 延時x*0.14ms
{
uchar i;
while(x--)
for(i=0;i<13;i++){}
}
void delay(uchar x) //延時xms
{
uchar i,j;
for(i=x;i>0;i--)
for(j=110;j>0;j--);
}
/****************************LCD部分***********************************************/
void write_com(uchar com)
{
lcden = 0;
lcdrs = 0;
lcdwr = 0;
P0 = com;
delay(5);
lcden = 1;
delay(5);
lcden = 0; //別忘了lcden拉低
}
void write_date(uchar date)
{
lcden = 0;
lcdrs = 1;
lcdwr = 0;
P0 = date;
delay(5);
lcden = 1;
delay(5);
lcden = 0;
}
void lcd_init(void)
{
lcden = 0;
lcdrs = 0;
lcdwr = 0;
delay(5);
write_com(0x38);
write_com(0x0c);
write_com(0x06);
write_com(0x01);
}
/*****************main()************************/
void main(void)
{
uchar count=0;
IR = 1;
lcd_init();
write_com(0x80);
while(table1[count]!='\0')
{
write_date(table1[count]);
count++;
delay(5);
}
count = 0;
write_com(0x80+0x40);
while(table2[count]!='\0')
{
write_date(table2[count]);
count++;
delay(5);
}

IE = 0x81; //開中斷
TCON = 0x01;//脈沖負邊沿觸發
while(1);

}
/*********************紅外中斷**************************/
void IR_time() interrupt 0
{
uchar i,j,TimeNum=0;//TimeNum用來計IR高電平次數 從而判斷是0還是1
EX0 = 0; //關閉中斷
delayms(5);
if(1 == IR)
{
EX0 = 1;
return;
}
while(!IR) //跳過9ms前導低電平
delayms(1);
for(i=0;i<4;i++)
{
for(j=0;j<8;j++)
{
while(IR) //跳過4.5ms的前導高電平
delayms(1);
while(!IR) //跳過0.56ms的低電平
delayms(1);

while(IR)
{
TimeNum++; //計時高電平時間從而判斷讀取的是0還是1
delayms(1);
}
if(TimeNum>=30)//按鍵按下時間過長 跳過
{
EX0 = 1;
return;
}
IRCOM[i] = IRCOM[i]>>1;
if(TimeNum >= 8) //8*0.14ms 這時讀取的是1;
{
IRCOM[i] = IRCOM[i]|0x80;
}
TimeNum = 0;
}
}
if(IRCOM[2]!=~IRCOM[3])//判斷八位數據和八位數據反碼是否相等
{
EX0 = 1;
return;
}
IRCOM[4] = IRCOM[2]&0x0f;//取低四位
IRCOM[5] = IRCOM[2]>>4; //IRCOM[5]取IRCOM[2]高四位
if(IRCOM[4] > 9) //轉換成字元
{
IRCOM[4] = IRCOM[4] + 0x37;
}
else
IRCOM[4] = IRCOM[4] + 0x30;
if(IRCOM[5] > 9)
{
IRCOM[5] = IRCOM[5] + 0x37;
}
else
IRCOM[5] = IRCOM[5] + 0x30;
delay(5);
write_com(0x80 + 0x40 + 5);
write_date(IRCOM[5]);
write_date(IRCOM[4]);
EX0 = 1; //重新開啟外部中斷
}

❷ 基於單片機的紅外萬能空調遙控的源代碼

我也認為這個該付費的,網上上搜了很多,找不到合適的,自己研究了很長時間,不很成功,不過已能學習幾個按鍵,方法就是用定時器把所有的高低電平持續時間測出來,存入EEPROM中,並不識別什麼是0,什麼是1,原樣保存,原樣使用,這樣對單片機的速度和內存要求高一些,空調器的控制碼有100多位,實際上能學習一個按鍵,就成功了一半,但下一部還是要與析它的代碼規律,以舍棄一些不必要的代碼,空調器常用的按鍵就沒幾個,但不同工作條件下同一個按鍵發出的控制碼是不同的,全部存儲,不僅浪費存儲空間,而且會給查找調用帶來不方便

❸ 基於單片機的紅外遙控收發系統的設計與實現

紅外遙控一般採用38KHz載波

❹ 51單片機最小系統怎樣連接紅外遙控模塊

紅外信號的發射由紅外發射電路中的紅外發光二極體完成,通常情況下為了提高抗干擾能力與降低電源消耗,遙控器將遙控信號(二進制脈沖碼)調制在載波(載波是傳送信息的物理基礎和承載工具)上經放大後發送至紅外二極體,再由二極體轉換為紅外信號發送出去。遙控器上不同的按鍵有著不一樣的鍵值,按下相對應的鍵,紅外二極體就會發送對應的信號,接收裝置接收到信號後會對信號進行信號解調後會得到相應按鍵的鍵值,再根據不同的鍵值執行相應的操作。

❺ 基於51單片機紅外遙控代碼(C語言)

以下文件是51單片機實現遙控解碼,通過數碼管顯示鍵碼的程序,P0口驅動數碼管段選,p2.6和p2.7為數碼管位選,接收頭連到P3.2口。此程序以通過驗證,可以直接編譯使用,另外還有一個繼電器和蜂鳴器的控制,不用可以屏蔽掉。

;********************************************************************************
;* 描述: *
;* 遙控鍵值讀取器 *
;* 數碼管顯示, P0口為數碼管的數據口 *
;* *
;********************************************************************************
;遙控鍵值解碼-數碼管顯示 *
;********************************************************************************/

#include <reg51.h>
#include <intrins.h>

void IR_SHOW();
void delay(unsigned char x);//x*0.14MS
void delay1(unsigned char ms);
void beep();

sbit IRIN = P3^2;
sbit BEEP = P3^7;
sbit RELAY= P1^3;
sbit GEWEI= P2^7;
sbit SHIWEI= P2^6;

unsigned char IRCOM[8];
unsigned char code table[16] =
{0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e};
main()
{
IE = 0x81; //允許總中斷中斷,使能 INT0 外部中斷
TCON = 0x1; //觸發方式為脈沖負邊沿觸發
delay(1);

IRIN=1;
BEEP=1;
RELAY=1;
for(;;)
{
IR_SHOW();
}

} //end main

void IR_IN() interrupt 0 using 0
{
unsigned char i,j,k,N=0;
EA = 0;
I1:
for (i=0;i<4;i++)
{
if (IRIN==0) break;
if (i==3) {EA =1;return;}
}
delay(20);
if (IRIN==1) goto I1; //確認IR信號出現
while (!IRIN) //等 IR 變為高電平
{delay(1);}

for (j=0;j<4;j++)
{
for (k=0;k<8;k++)
{
while (IRIN) //等 IR 變為低電平
{delay(1);}
while (!IRIN) //等 IR 變為高電平
{delay(1);}
while (IRIN) //計算IR高電平時長
{
delay(1);
N++;
if (N>=30) {EA=1;return;}
}
IRCOM[j]=IRCOM[j] >> 1;
if (N>=8) {IRCOM[j] = IRCOM[j] | 0x80;}
N=0;
}//end for k
}//end for j

if (IRCOM[2]!=~IRCOM[3]) {EA=1;return;}
IRCOM[5]=IRCOM[2] & 0x0F;
IRCOM[6]=IRCOM[2] & 0xF0;
IRCOM[6]=IRCOM[6] >> 4;
beep();
EA = 1;

}

void IR_SHOW()
{
P0 = table[IRCOM[5]];
GEWEI = 0;
SHIWEI = 1;
delay1(4);
P0 = table[IRCOM[6]];
SHIWEI = 0;
GEWEI = 1;
delay1(4);
}

void beep()
{
unsigned char i;
for (i=0;i<100;i++)
{
delay(5);
BEEP=!BEEP;
}
BEEP=1;
}

void delay(unsigned char x)//x*0.14MS
{
unsigned char i;
while(x--)
{
for (i = 0; i<13; i++) {}
}
}

void delay1(unsigned char ms)
{
unsigned char i;
while(ms--)
{
for(i = 0; i<120; i++)
{
_nop_();
_nop_();
_nop_();
_nop_();
}
}
}

❻ 課程設計:紅外遙控解碼器(基於單片機AT89C51),能同過數碼管把相應的按鍵顯示出來~ 各位高手幫幫忙

//實例97:用紅外遙控器控制繼電器
#include<reg51.h> //包含單片機寄存器的頭文件
sbit IR=P3^2; //將IR位定義為P3.2引腳
unsigned char a[4]; //儲存用戶碼、用戶反碼與鍵數據碼、鍵數據反碼
unsigned int LowTime,HighTime; //儲存高、低電平的寬度
sbit Relay=P1^3; //將Relay位定義為P1.3引腳
/************************************************************
函數功能:對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
}
/************************************************************
函數功能:執行遙控功能
*************************************************************/
void Function(void)
{
Relay=!Relay; //對P1.3引腳取反,控制繼電器的吸合、釋放

}
/************************************************************
函數功能:主函數
*************************************************************/
void main()
{
EA=1; //開啟總中斷
EX0=1; //開外中斷0
ET0=1; //定時器T0中斷允許
IT0=1; //外中斷的下降沿觸發
TMOD=0x01; //使用定時器T0的模式1
TR0=0; //定時器T0關閉
while(1) //等待紅外信號產生的中斷
;
}
/************************************************************
函數功能:紅外線觸發的外中斷處理函數
*************************************************************/
void Int0(void) interrupt 0 using 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)
Function(); //如果滿足條件,執行遙控功能
}
EX0=1; //開啟外中斷EX0
}

❼ 用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

}

❽ 紅外遙控器與51單片機

org 00h ORG 30H MOV P1,#0FFH MOV P2,#0FFH MOV P3,#0FFH START:

JB P3.7,$;等待遙控信號出現 SB: MOV R4,#8 ;8毫秒為高電平錯誤 SBA: MOV R5,#250 SBB: JB P3.7,SXB1 DJNZ R5,SBB DJNZ R4,SBA MOV R4,#2 JMP SBC SXB1: MOV R5,#5 SXB2: ;去掉20US的尖峰干擾信號 JNB P3.7,SBB DJNZ R5,SXB2 JMP START SBC: MOV R5,#250 SB1: JB P3.7,SB2 ;2MS內不為高電平錯誤(監測9MS的低電 平引導碼) DJNZ R5,SB1 DJNZ R4,SBC JMP START SB2: ;去掉20US的尖峰干擾信號 MOV R5,#5 SB2_A: JNB P3.7,SB1 DJNZ R5,SB2_A MOV R4,#3 SB2_1: MOV R5,#250 SB3: ;監測4.5MS高電平,如3MS內出現低電平錯誤 JNB P3.7,SXC DJNZ R5,SB3 DJNZ R4,SB2_1 MOV R4,#2 JMP SB3_1 SXC: ;去掉20US的尖峰干擾信號 MOV R5,#5 SXC1: JB P3.7,SB3 DJNZ R5,SXC1 JMP START SB3_1: ;監測4.5MS高電平,如5MS內不為低電平錯誤 MOV R5,#250 SB3_2: JNB P3.7,SB4 DJNZ R5,SB3_2 DJNZ R4,SB3_1 JMP START SB4: ;去掉20US的尖峰干擾信號 MOV R5,#5 SB4_1: JB P3.7,SB3_2 DJNZ R5,SB4_1 MOV R1,#1AH ;設定1AH為起始RAM區 MOV R2,#4 PP: MOV R3,#8 JJJJ: MOV R5,#250 JJJJ2: ;1MS內不為低電平錯誤 JB P3.7,JJJJ3 DJNZ R5,JJJJ2 JMP START JJJJ3: LCALL YS1 ;高電平開始後用882微秒的時間尺去判斷信 號此時的高低電平狀態 MOV C,P3.7 ;將P3.7引腳此時的電平狀態0或1存入C中 JNC UUU ;如果為0就跳轉到UUU MOV R5,#250 JJJJ4: JNB P3.7,UUU NOP DJNZ R5,JJJJ4 JMP START UUU:MOV A,@R1 ;將R1中地址的給A RRC A ;將C中的值0或1移入A中的最低位 MOV @R1,A ;將A中的數暫時存放在R1中 DJNZ R3,JJJJ ;接收地址碼的高8位 INC R1 ;對R1中的值加1,換成下一個RAM DJNZ R2,PP ;接收完16位地址碼和8位數據碼和8位數據 反碼,存放在1AH/1BH/1CH/1DH的RAM中 ;以下對代碼是否正確和定義進行識別 MOV A,1AH;比較高8位地址碼 XRL A,#00000000B;判斷1AH的值是否等於00000000, 相等的話A為0 JNZ EXIT;如果不相等說明解碼失敗退出解碼程序 MOV A,1BH;比較低8位地址 XRL A,#11111111B;再判斷高8位地址是否正確 JNZ EXIT;如果不相等說明解碼失敗退出解碼程序 LCALL YS3 MOV A,1CH;比較數據碼和數據反碼是否正確? CPL A XRL A,1DH ;將1CH的值取反後和1DH比較 不同則無效丟 棄,核對數據是否准確 JNZ EXIT;如果不相等說明解碼失敗退出解碼程序 LCALL YS3 AJMP BIJIAO ;判斷在118毫秒內是否有連發碼 AA:MOV R1,#25 XX:ACALL YS2 JNB P3.7,HH;跳轉到判斷連發代碼是否正確的程序段 DJNZ R1,XX EXIT: ;對所有埠清零

AJMP START ;連發碼判斷程序段-----------HH:MOV R6,#4 S: ACALL YS1;調用882微秒延時子程序 JB P3.7,EXIT;延時882微秒後判斷P3.7腳是否出現高電平 如果有就退出解碼程序 DJNZ R6, S;重復4次,目的是確認連發碼的低電平信號波 形 JNB P3.7, $ ;等待高電? LCALL YS3 AJMP AA

BIJIAO:MOV A,1CH;按鍵數值判斷執 CJNE A,#10h,TT1 clr p0.0 TT1: CJNE A,#03h,T2 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p0.1 T2: CJNE A,#01h,T3 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p0.2 T3: CJNE A,#06h,T4 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p0.3 T4: CJNE A,#09h,T5 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p0.4 T5: CJNE A,#1dh,T6 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p0.5 T6:CJNE A,#1fh,T7 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p0.6 T7: CJNE A,#0dh,T8 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p0.7 T8:CJNE A,#19h,t9 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p1.0 T9:CJNE A,#1bh,t10 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p1.1 T10: CJNE A,#11h,t11 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p1.2 T11: CJNE A,#15h,t12 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p1.3 T12: CJNE A,#17h,t13 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p1.4 T13: CJNE A,#12h,t14 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p1.5 T14: CJNE A,#16h,t15 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p1.6 T15: CJNE A,#4ch,t16 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p1.7 T16: CJNE A,#40h,t17 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p2.0 T17: CJNE A,#48h,t18 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p2.1 T18: CJNE A,#04h,t19 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p2.2 T19: CJNE A,#00h,t20 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p2.3 T20: CJNE A,#02h,t21 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p2.4 T21: CJNE A,#05h,t22 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p2.5 T22: CJNE A,#54h,t23 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p2.6 T23: CJNE A,#4dh,t24 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p2.7 T24: CJNE A,#0ah,t25 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p3.0 T25: CJNE A,#1eh,t26 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p3.1 T26: CJNE A,#0eh,t27 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p3.2 T27: CJNE A,#,t28 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p3.3 T28: CJNE A,#1ch,t29 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p3.4 T29: CJNE A,#14h,t31 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

clr p3.5 T31: CJNE A,#0ch,t32 mov p0,#0ffh mov p1,#0ffh mov p2,#0ffh mov p3,#0ffh

t32:AJMP AA YS1:MOV R4,#20 ;延時子程序1,精確延時882微秒 D1: MOV R5,#20 DJNZ R5,$ DJNZ R4,D1 RET YS2: MOV R4,#10 ;延時子程序2,精確延時4740微秒 D2: MOV R5,#235 DJNZ R5,$ DJNZ R4,D2 RET YS3:MOV R4,#2;延時程序3,精確延時1000微秒 D3:MOV R5,#248 DJNZ R5,$ DJNZ R4,D3 RET END

❾ 單片機的紅外遙控的原理

1、發送端由單片機和紅外發光二極體組成。
單片機控制紅外發光二極體發射38KHz左右的紅外光,這個紅外光就可能起到傳遞信號的作用。你可以在你的程序中規定發射紅外線時表示二進制的一個位『1』無紅外線時表示二進制的『0』。這樣你就可以發出一系列由『1』和『0』所級成的信號。
2、接收端是由紅外接收二極體和單片機組成。
前面我們讓發射端發出信號,現在接收頭就開始收信號。

閱讀全文

與基於單片機紅外遙控系統相關的資料

熱點內容
cad中y命令無法使用 瀏覽:724
如何查看linux編碼格式 瀏覽:531
輕音樂app怎麼下載不承是那裡過 瀏覽:830
電腦上解壓7z軟體免費版 瀏覽:624
如何在安卓手機上登錄蘋果的號 瀏覽:294
雲棲大會和程序員關系 瀏覽:670
伺服器託管使用cdn有什麼好處 瀏覽:145
app看視頻怎麼很卡 瀏覽:421
python輸出語句加引號 瀏覽:103
怎麼弄有密碼的便簽安卓 瀏覽:336
程序員都愛玩的足球 瀏覽:565
程序員摸魚怎麼處理 瀏覽:685
pdf裝備 瀏覽:281
鄉鎮程序員 瀏覽:848
php運行環境一鍵安裝包 瀏覽:884
python編寫排序函數 瀏覽:876
51單片機定時器中斷程序 瀏覽:561
win7iisphp安裝 瀏覽:810
有限元網格劃分演算法 瀏覽:565
sql中查詢命令 瀏覽:800