ir紅外編程
⑴ 紅外發射模塊怎麼用51單片機編程使用
用定時器中斷來做,例如紅外發送引腳連接到P1.0口, 計數一下定時初值(讓P1.0的翻轉頻率為38KHZ),進定時器中斷就對P1.0取反,這樣紅外就發送出去了。
⑵ 關於單片機紅外遙控代碼部分的幾個問題: 1.Ircordpro函數中if(cord>7)是干什麼用的
cord用於取出脈寬的時間判斷是否符合1的脈寬時間,要看你那個紅外通信是什麼協議
⑶ 51單片機紅外接收端的程序怎麼寫,我想知道寫的方法和原理,最好有一個具體的模版,好讓我參考.
額,這個程序我這倒是有,你要不?
⑷ 單片機編程(紅外線遙控器)
十六進制——ASCII碼轉換。
因為你的檢測部分肯定是用的字元串類型。
來檢測你的鍵碼值是否==類似於"5A"這樣的 解碼字元串。
而紅外解碼模塊接到的碼值是二進制的數。(4位即16進制)
所以需要你貼出來的這段轉換程序。
⑸ IR_NEAR紅外感應開關程序代碼,單片機直接控制接收,百度上能找到的,哪位大哥有的分享一下啊
這個代碼是別的模塊的代碼,簡直就是騙人,杜洋對錢很看重,閉門造車,看些奇怪的哲學書,聽些音樂會,吃些海味,買些高級攝影裝備,都是騙愛好者的錢。
產品做不到批量化,自然質量不行,特別是新出的
DoWatch手錶,准確度不高,焊接難度大,焊接失敗200多就捐了。你看頹廢的樣子,一個人自圓其說,現在時團隊研發,他一個人研發,能出好產品嗎。

頹廢的樣子,不可靠的產品。
⑹ 51單片機 紅外控製程序中 if (IRCOM[2]!=~IRCOM[3]) { EX0=1; return; }是什麼意思

0為用戶碼,1為用戶碼或者用戶反碼(看具體遙控器的資料),2和3為數據正反碼;2和3比較是為了糾錯;0和1要不要比較就看你的要求了,用戶碼就是為了確認這個遙控器是不是你指定的,不讓別家的遙控器和你的通用。
⑺ 紅外程序
/********************************************************************************
* 描述: *
* lcd1602顯示 遙控鍵值讀取器 *
* lcd1602顯示 遙控器接p3.2 *
* 喇叭接p1.5 繼電器接p1.4 *
* 17(40h)鍵按下,繼電器吸合。19(04h)鍵按下,繼電器關閉。 *
* 連接方法:使用紅外功能時 J1跳線短接 *
********************************************************************************/
#include <reg51.h>
#include <intrins.h>
#define uchar unsigned char
#define uint unsigned int
#define delayNOP(); {_nop_();_nop_();_nop_();_nop_();};
void delay(uchar x); //x*0.14MS
void delay1(int ms);
void beep();
sbit IRIN = P3^2; //紅外接收器數據線
sbit BEEP = P1^5; //蜂鳴器驅動線
sbit RELAY= P1^4; //繼電器驅動線
uchar IRCOM[9];
sbit LCD_RS = P2^6;
sbit LCD_RW = P2^5;
sbit LCD_EN = P2^7;
uchar code cdis1[ ] = {" Red Control "};
uchar code cdis2[ ] = {"IR-CODE: ----H "};
/*******************************************************************/
/* */
/*檢查LCD忙狀態 */
/*lcd_busy為1時,忙,等待。lcd-busy為0時,閑,可寫指令與數據。 */
/* */
/*******************************************************************/
bit lcd_busy()
{
bit result;
LCD_RS = 0;
LCD_RW = 1;
LCD_EN = 1;
delayNOP();
result = (bit)(P0&0x80);
LCD_EN = 0;
return(result);
}
/*******************************************************************/
/* */
/*寫指令數據到LCD */
/*RS=L,RW=L,E=高脈沖,D0-D7=指令碼。 */
/* */
/*******************************************************************/
void lcd_wcmd(uchar cmd)
{
while(lcd_busy());
LCD_RS = 0;
LCD_RW = 0;
LCD_EN = 0;
_nop_();
_nop_();
P0 = cmd;
delayNOP();
LCD_EN = 1;
delayNOP();
LCD_EN = 0;
}
/*******************************************************************/
/* */
/*寫顯示數據到LCD */
/*RS=H,RW=L,E=高脈沖,D0-D7=數據。 */
/* */
/*******************************************************************/
void lcd_wdat(uchar dat)
{
while(lcd_busy());
LCD_RS = 1;
LCD_RW = 0;
LCD_EN = 0;
P0 = dat;
delayNOP();
LCD_EN = 1;
delayNOP();
LCD_EN = 0;
}
/*******************************************************************/
/* */
/* LCD初始化設定 */
/* */
/*******************************************************************/
void lcd_init()
{
delay1(15);
lcd_wcmd(0x38); //16*2顯示,5*7點陣,8位數據
delay1(5);
lcd_wcmd(0x38);
delay1(5);
lcd_wcmd(0x38);
delay1(5);
lcd_wcmd(0x0c); //顯示開,關游標
delay1(5);
lcd_wcmd(0x06); //移動游標
delay1(5);
lcd_wcmd(0x01); //清除LCD的顯示內容
delay1(5);
}
/*******************************************************************/
/* */
/* 設定顯示位置 */
/* */
/*******************************************************************/
void lcd_pos(uchar pos)
{
lcd_wcmd(pos | 0x80); //數據指針=80+地址變數
}
/*******************************************************************/
main()
{
uchar m;
IE = 0x81; //允許總中斷中斷,使能 INT0 外部中斷
TCON = 0x01; //觸發方式為脈沖負邊沿觸發
IRIN=1; //I/O口初始化
BEEP=1;
RELAY=1;
delay1(10); //延時
lcd_init(); //初始化LCD
lcd_pos(0); //設置顯示位置為第一行的第1個字元
m = 0;
while(cdis1[m] != '\0')
{ //顯示字元
lcd_wdat(cdis1[m]);
m++;
}
lcd_pos(0x40); //設置顯示位置為第二行第1個字元
m = 0;
while(cdis2[m] != '\0')
{
lcd_wdat(cdis2[m]); //顯示字元
m++;
}
while(1) ;
} //end main
/**********************************************************/
void IR_IN() interrupt 0 using 0
{
unsigned char j,k,N=0;
EX0 = 0;
delay(15);
if (IRIN==1)
{ EX0 =1;
return;
}
//確認IR信號出現
while (!IRIN) //等IR變為高電平,跳過9ms的前導低電平信號。
{delay(1);}
for (j=0;j<4;j++) //收集四組數據
{
for (k=0;k<8;k++) //每組數據有8位
{
while (IRIN) //等 IR 變為低電平,跳過4.5ms的前導高電平信號。
{delay(1);}
while (!IRIN) //等 IR 變為高電平
{delay(1);}
while (IRIN) //計算IR高電平時長
{
delay(1);
N++;
if (N>=30)
{ EX0=1;
return;} //0.14ms計數過長自動離開。
} //高電平計數完畢
IRCOM[j]=IRCOM[j] >> 1; //數據最高位補「0」
if (N>=8) {IRCOM[j] = IRCOM[j] | 0x80;} //數據最高位補「1」
N=0;
}//end for k
}//end for j
if (IRCOM[2]!=~IRCOM[3])
{ EX0=1;
return; }
IRCOM[5]=IRCOM[2]/16; //取鍵碼的低四位
IRCOM[6]=IRCOM[2]%16; //右移4次,高四位變為低四位
IRCOM[7]=IRCOM[1]/16; //取鍵碼的低四位
IRCOM[8]=IRCOM[1]/16; //右移4次,高四位變為低四位
/*if(IRCOM[5]>9)
{ IRCOM[5]=IRCOM[5]+0x37;}
else
IRCOM[5]=IRCOM[5]+0x30;
if(IRCOM[6]>9)
{ IRCOM[6]=IRCOM[6]+0x37;}
else
IRCOM[6]=IRCOM[6]+0x30;
if(IRCOM[7]>9)
{ IRCOM[7]=IRCOM[7]+0x37;}
else
IRCOM[7]=IRCOM[7]+0x30;
if(IRCOM[8]>9)
{ IRCOM[8]=IRCOM[8]+0x37;}
else
IRCOM[8]=IRCOM[8]+0x30;*/
lcd_pos(0x4b);
lcd_wdat(IRCOM[6]); //第一位數顯示
lcd_pos(0x4c);
lcd_wdat(IRCOM[5]); //第二位數顯示
lcd_pos(0x49);
lcd_wdat(IRCOM[8]); //第一位數顯示
lcd_pos(0x4a);
lcd_wdat(IRCOM[7]); //第二位數顯示
beep();
EX0 = 1;
}
/**********************************************************/
void beep()
{
unsigned char i;
for (i=0;i<100;i++)
{
delay(4);
BEEP=!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(int ms)
{
unsigned char y;
while(ms--)
{
for(y = 0; y<250; y++)
{
_nop_();
_nop_();
_nop_();
_nop_();
}
}
}
這個應該是可以運行的
