導航:首頁 > 操作系統 > 基於51單片機的遙控器

基於51單片機的遙控器

發布時間:2023-06-13 18:14:55

❶ 基於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_();
}
}
}

❷ 用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單片機的紅外遙控開關的設計原理圖和程序(c語言版)

/*------------------------------------------------*/
#include<reg52.h> //包含頭文件,一般情況不需要改動,頭文件包含特殊功能寄存器的定義

sbit IR=P3^2; //紅外介面標志

#define DataPort P0 //定義數據埠 程序中遇到DataPort 則用P0 替換
sbit DUAN=P2^6;//定義鎖存使能埠 段鎖存
sbit WEI=P2^7;// 位鎖存
/*------------------------------------------------
全局變數聲明
------------------------------------------------*/
unsigned char code dofly_DuanMa[16]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};// 顯示段碼值0~F
unsigned char code dofly_WeiMa[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};//分別對應相應的數碼管點亮,即位碼
unsigned char TempData[8]; //存儲顯示值的全局變數
unsigned char irtime;//紅外用全局變數

bit irpro_ok,irok;
unsigned char IRcord[4];
unsigned char irdata[33];

/*------------------------------------------------
函數聲明
------------------------------------------------*/

void Ir_work(void);
void Ircordpro(void);
/*------------------------------------------------
顯示函數,用於動態掃描數碼管
輸入參數 FirstBit 表示需要顯示的第一位,如賦值2表示從第三個數碼管開始顯示
如輸入0表示從第一個顯示。
Num表示需要顯示的位數,如需要顯示99兩位數值則該值輸入2
------------------------------------------------*/
void Display(unsigned char FirstBit,unsigned char Num)
{
static unsigned char i=0;

DataPort=0; //清空數據,防止有交替重影
DUAN=1; //段鎖存
DUAN=0;

DataPort=dofly_WeiMa[i+FirstBit]; //取位碼
WEI=1; //位鎖存
WEI=0;

DataPort=TempData[i]; //取顯示數據,段碼
DUAN=1; //段鎖存
DUAN=0;

i++;
if(i==Num)
i=0;

}
/*------------------------------------------------
定時器0中斷處理
------------------------------------------------*/

void tim0_isr (void) interrupt 1 using 1
{
irtime++; //用於計數2個下降沿之間的時間
}
/*------------------------------------------------
定時器中斷子程序
------------------------------------------------*/
void Timer1_isr(void) interrupt 3
{

TH1=(65536-2000)/256; //重新賦值 2ms
TL1=(65536-2000)%256;

Display(0,8); // 調用數碼管掃描

}
/*------------------------------------------------
外部中斷0中斷處理
------------------------------------------------*/
void EX0_ISR (void) interrupt 0 //外部中斷0服務函數
{
static unsigned char i; //接收紅外信號處理
static bit startflag; //是否開始處理標志位

if(startflag)
{
if(irtime<63&&irtime>=33)//引導碼 TC9012的頭碼,9ms+4.5ms
i=0;
irdata[i]=irtime;//存儲每個電平的持續時間,用於以後判斷是0還是1
irtime=0;
i++;
if(i==33)
{
irok=1;
i=0;
}
}
else
{
irtime=0;
startflag=1;
}

}

/*------------------------------------------------
定時器0初始化
------------------------------------------------*/
void TIM0init(void)//定時器0初始化
{

TMOD=0x02;//定時器0工作方式2,TH0是重裝值,TL0是初值
TH0=0x00; //重載值
TL0=0x00; //初始化值
ET0=1; //開中斷
TR0=1;
}
/*------------------------------------------------
定時器初始化子程序
------------------------------------------------*/
void Init_Timer1(void)
{
TMOD |= 0x01; //使用模式1,16位定時器,使用"|"符號可以在使用多個定時器時不受影響
//TH1=0x00; //給定初值
//TL1=0x00;
EA=1; //總中斷打開
ET1=1; //定時器中斷打開
TR1=1; //定時器開關打開
}
/*------------------------------------------------
外部中斷0初始化
------------------------------------------------*/
void EX0init(void)
{
IT0 = 1; //指定外部中斷0下降沿觸發,INT0 (P3.2)
EX0 = 1; //使能外部中斷
EA = 1; //開總中斷
}
/*------------------------------------------------
鍵值處理
------------------------------------------------*/

void Ir_work(void)//紅外鍵值散轉程序
{

TempData[0]=dofly_DuanMa[IRcord[0]/16];
TempData[1]=dofly_DuanMa[IRcord[0]%16];
TempData[2]=dofly_DuanMa[IRcord[1]/16];
TempData[3]=dofly_DuanMa[IRcord[1]%16];
TempData[4]=dofly_DuanMa[IRcord[2]/16];
TempData[5]=dofly_DuanMa[IRcord[2]%16];
TempData[6]=dofly_DuanMa[IRcord[3]/16];
TempData[7]=dofly_DuanMa[IRcord[3]%16];
//Display(0,8); // 調用數碼管掃描
irpro_ok=0;//處理完成標志

}
/*------------------------------------------------
紅外碼值處理
------------------------------------------------*/
void Ircordpro(void)//紅外碼值處理函數
{
unsigned char i, j, k;
unsigned char cord,value;

k=1;
for(i=0;i<4;i++) //處理4個位元組
{
for(j=1;j<=8;j++) //處理1個位元組8位
{
cord=irdata[k];
if(cord>7)//大於某值為1,這個和晶振有絕對關系,這里使用12M計算,此值可以有一定誤差
value|=0x80;
if(j<8)
{
value>>=1;
}
k++;
}
IRcord[i]=value;
value=0;
}
irpro_ok=1;//處理完畢標志位置1
}

/*------------------------------------------------
主函數
------------------------------------------------*/
void main(void)
{
EX0init(); //初始化外部中斷
TIM0init();//初始化定時器
Init_Timer1();

while(1)//主循環
{
if(irok) //如果接收好了進行紅外處理
{
Ircordpro();
irok=0;
}

if(irpro_ok) //如果處理好後進行工作處理,如按對應的按鍵後顯示對應的數字等
{
Ir_work();
}
}
}

51P3^2是外部中斷,紅外接收管接這個引腳就能接收到數據然後顯示在數碼管上

❹ N51如何生成遙控器

生成共有五個步驟。
一.同樣使用51單片機作為控制晶元,同樣只需要一個晶元和一個晶振電路單片機就能運行,但是注意可以將需要的引腳外拉。二.將按鍵開關的兩端,一端連接到單片機引腳,另一端接到地,接單片機的一端再通過一個10K電阻上拉到5V,也可以不上拉,親試能用,上拉的話穩定一些,能夠防干擾,按鍵數目自行而定,按照遙控器的那件分布來在洞洞板上焊接。三.藍牙信號腳要結對,只需要單片機的發射腳,即P3.1接到藍牙模塊的接收腳,注意和之前的不一樣;藍牙模塊設置成主模塊,但是注意車上的藍牙設置成從模塊,注意波特率一致。四.需要兩節18650電池(兩節7.2V),使用一個lm2940穩壓晶元就可以產生5V電壓給設備供電,或使用其他的5V電源來供電,比如說充電寶。五.啟動程序。
單片機是一種控制晶元,一個微型的計算機,加上晶振,存儲器,地址鎖存器,邏輯門,顯示器,按鈕,擴展晶元,介面等構成單片機系統。利用51單片機內部UART功能和藍牙模塊實現單片機之間的無限遙控,主要通過編程用於控制其他單片機或微機系統。

❺ 基於51單片機的玩具車遙控器設計

與51單片機的玩具車的話,遙控器設計的遙控器的設計的話,你可以通過它的紅外線控制

❻ 用51單片機製作電視機紅外線遙控器需要哪些元器件,求電路圖和流程圖以及編程,最好是匯編編程

你這個程序,別說20 廢物幣,給 500 rmb,都沒有人做的

❼ 可以用51單片機做紅外遙控器嗎

用 51單片機做紅外接收比較好,發射器的話直接用普通電視或空調遙控器成品,成本很低,省去許多麻煩。

❽ 有關基於51單片機紅外遙控器的問題

沒有干擾的話,就是程序問題

閱讀全文

與基於51單片機的遙控器相關的資料

熱點內容
pdf下拉 瀏覽:367
php去掉小數後面的0 瀏覽:952
阿里備案買什麼伺服器 瀏覽:261
網路驅動下載到哪個文件夾 瀏覽:481
達內程序員培訓西安 瀏覽:505
人保送車主惠app上怎麼年檢 瀏覽:604
android手機開機密碼 瀏覽:480
linux查看某個進程命令 瀏覽:529
閑置的騰訊雲伺服器 瀏覽:437
rar壓縮包mac 瀏覽:626
php混淆加密工具 瀏覽:581
java把數字拆分 瀏覽:464
如何下載svn伺服器舊版本 瀏覽:559
命令與征服4攻略 瀏覽:914
實數四則運演算法則概念 瀏覽:296
cs16優化命令 瀏覽:873
Minecraft雲伺服器免費 瀏覽:830
png壓縮最小 瀏覽:184
老韓綜app怎麼看不了了 瀏覽:229
只有一個程序員的體驗 瀏覽:323