『壹』 單片機,學習型遙控器,只要求學習(某一款)空調的開關即可,做好了,小弟100分答謝
學習型的遙控器必須要有一個學習的過程,就是首先你得知道你的空調的遙控信號是什麼,然後給這個信號給遙控器,告訴他這個信號是干什麼的,所以當它記憶住了這個信號,以後知道發射這個信號即可。
一般遙控器為紅外信號,所以你只要單片機加上一對紅外對管即可,程序發揮下,能做出很多不同效果。
『貳』 單片機開發板自帶的遙控器是個什麼意思,它裡面和一般鍵盤一樣嗎怎麼用呢
單片機開發板自帶的遙控器通常是NEC編碼的紅外遙控器,是為用戶學習紅外遙控解碼而配備的,用戶需要自己構建遙控器信號的解碼程序,並自己定義遙控器上按鍵的功能。
有些開發板還帶有連接鍵盤的PS/2插口,這是為了讓用戶學習PS/2介面協議而配備的,用戶同樣需要自己構建相關的程序,並定義按鍵功能。
『叄』 學習型紅外遙控器的原理是怎樣的
學習型紅外遙控器的原理:
基本原理是發送端將基帶二進制信號調制為一系列的脈沖串信號,通過紅外發射管發射的紅外信號,常用的有通過脈沖寬度來實現信號調制的脈寬調制(PWM)和通過脈沖串之間的時間間隔來實現信號調制的脈時調制(PPM)兩種方法。
學習型遙控常用的載波頻率為38kHz,這是由發射端編碼晶元所使用的455kHz晶振來決定的,其他的遙控系統採用36kHz、40kHz、56kHz等。現在採用一體化接收頭做為信號的接收,把解調出來的信號送入單片機進行學習(記錄各個高低電平的時間長度),然後存入EEPROM內,學習完成後再將EEPROM的高低電平的時間數據讀取並與38kHz載波進行調制,然後紅外發光管發送出去。
『肆』 基於單片機的家電智能遙控器設計
這個確實比較復雜,現在我只完成了第一步,學習型遙控器的設計費了好大勁兒,第二歩是無線通信,模塊用nfr24L01,便宜,但通信試驗總不成功,急死了!
『伍』 關於單片機 發射紅外線遙控電視機疑問
解碼用單片機接收NEC遙控器32編碼和電視遙控器42位編碼,程序裡面自動識別32和42位的編碼用數碼管進行顯示對應的數值。
『陸』 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; //重新開啟外部中斷
}
『柒』 想自學單片機編程做遙控飛機, 要學哪些東西
學習單片機,它涉及到Linux和ARM?不要嚇唬樓上的人啊。支持一樓,手臂事情變得更加困難的基礎上的單晶元被嵌入。可以用單片機C語言或匯編編程,如果你想使用的新概念郭天祥51單片機,充分C的。如果你想知道該晶元的內部結構,建議學校集會。看似ZLG好。但是,你可以學習C,但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_();
}
}
}
『玖』 用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]!='