51单片机红外遥控程序是什么?

51单片机红外遥控程序是什么?,第1张

#include\x0d\x0a#include\x0d\x0a#define uchar unsigned char\x0d\x0a#define uint unsigned int\x0d\x0asbit lcden = P2^7\x0d\x0asbit lcdrs = P2^6\x0d\x0asbit lcdwr = P2^5\x0d\x0asbit IR = P3^2\x0d\x0auchar IRCOM[6]//数组,用于存储红外编码\x0d\x0auchar code table1[] = "remote control"\x0d\x0auchar code table2[] = "CODE:"\x0d\x0avoid delayms(uchar x)// 延时x*0.14ms\x0d\x0a{\x0d\x0auchar i\x0d\x0awhile(x--)\x0d\x0afor(i=0i//延时xms\x0d\x0a{\x0d\x0auchar i,j\x0d\x0afor(i=xi>0i--)\x0d\x0afor(j=110j>0j--)\x0d\x0a}\x0d\x0a/****************************LCD部分***********************************************/\x0d\x0avoid write_com(uchar com)\x0d\x0a{\x0d\x0alcden = 0\x0d\x0alcdrs = 0\x0d\x0alcdwr = 0\x0d\x0aP0 = com\x0d\x0adelay(5)\x0d\x0alcden = 1\x0d\x0adelay(5)\x0d\x0alcden = 0//别忘了lcden拉低\x0d\x0a}\x0d\x0avoid write_date(uchar date)\x0d\x0a{\x0d\x0alcden = 0\x0d\x0alcdrs = 1\x0d\x0alcdwr = 0\x0d\x0aP0 = date\x0d\x0adelay(5)\x0d\x0alcden = 1\x0d\x0adelay(5)\x0d\x0alcden = 0\x0d\x0a}\x0d\x0avoid lcd_init(void)\x0d\x0a{\x0d\x0alcden = 0\x0d\x0alcdrs = 0\x0d\x0alcdwr = 0\x0d\x0adelay(5)\x0d\x0awrite_com(0x38)\x0d\x0awrite_com(0x0c)\x0d\x0awrite_com(0x06)\x0d\x0awrite_com(0x01)\x0d\x0a}\x0d\x0a/*****************main()************************/\x0d\x0avoid main(void)\x0d\x0a{\x0d\x0auchar count=0\x0d\x0aIR = 1\x0d\x0alcd_init()\x0d\x0awrite_com(0x80)\x0d\x0awhile(table1[count]!='\0')\x0d\x0a{\x0d\x0awrite_date(table1[count])\x0d\x0acount++\x0d\x0adelay(5)\x0d\x0a}\x0d\x0acount = 0\x0d\x0awrite_com(0x80+0x40)\x0d\x0awhile(table2[count]!='\0')\x0d\x0a{\x0d\x0awrite_date(table2[count])\x0d\x0acount++\x0d\x0adelay(5)\x0d\x0a}\x0d\x0a\x0d\x0aIE = 0x81//开中断\x0d\x0aTCON = 0x01//脉冲负边沿触发\x0d\x0awhile(1)\x0d\x0a\x0d\x0a}\x0d\x0a/*********************红外中断**************************/\x0d\x0avoid IR_time() interrupt 0 \x0d\x0a{\x0d\x0auchar i,j,TimeNum=0//TimeNum用来计IR高电平次数 从而判断是0还是1\x0d\x0aEX0 = 0//关闭中断\x0d\x0adelayms(5)\x0d\x0aif(1 == IR)\x0d\x0a{\x0d\x0aEX0 = 1\x0d\x0areturn\x0d\x0a}\x0d\x0awhile(!IR) //跳过9ms前导低电平\x0d\x0adelayms(1)\x0d\x0afor(i=0i{\x0d\x0afor(j=0j{\x0d\x0awhile(IR) //跳过4.5ms的前导高电平\x0d\x0adelayms(1)\x0d\x0awhile(!IR) //跳过0.56ms的低电平\x0d\x0adelayms(1)\x0d\x0a\x0d\x0awhile(IR) \x0d\x0a{\x0d\x0aTimeNum++//计时高电平时间从而判断读取的是0还是1\x0d\x0adelayms(1)\x0d\x0a}\x0d\x0aif(TimeNum>=30)//按键按下时间过长 跳过\x0d\x0a{\x0d\x0aEX0 = 1\x0d\x0areturn\x0d\x0a}\x0d\x0aIRCOM[i] = IRCOM[i]>>1\x0d\x0aif(TimeNum >= 8) //8*0.14ms 这时读取的是1;\x0d\x0a{\x0d\x0aIRCOM[i] = IRCOM[i]|0x80\x0d\x0a}\x0d\x0aTimeNum = 0\x0d\x0a}\x0d\x0a}\x0d\x0aif(IRCOM[2]!=~IRCOM[3])//判断八位数据和八位数据反码是否相等\x0d\x0a{\x0d\x0aEX0 = 1\x0d\x0areturn\x0d\x0a}\x0d\x0aIRCOM[4] = IRCOM[2]&0x0f//取低四位\x0d\x0aIRCOM[5] = IRCOM[2]>>4//IRCOM[5]取IRCOM[2]高四位\x0d\x0aif(IRCOM[4] >9) //转换成字符\x0d\x0a{\x0d\x0aIRCOM[4] = IRCOM[4] + 0x37\x0d\x0a}\x0d\x0aelse\x0d\x0aIRCOM[4] = IRCOM[4] + 0x30\x0d\x0aif(IRCOM[5] >9)\x0d\x0a{\x0d\x0aIRCOM[5] = IRCOM[5] + 0x37\x0d\x0a}\x0d\x0aelse\x0d\x0aIRCOM[5] = IRCOM[5] + 0x30\x0d\x0adelay(5)\x0d\x0awrite_com(0x80 + 0x40 + 5)\x0d\x0awrite_date(IRCOM[5])\x0d\x0awrite_date(IRCOM[4])\x0d\x0aEX0 = 1//重新开启外部中断\x0d\x0a}

红外解码,先有引导码9ms高电平4.5ms低电平,然后是用户正码,用户反码,按键正码,按键反码,IRCOM[2]是一个4位数组,用来存放红外接受码的,IRCOM[0]是用来存放用户正码IRCOM[1]用户反码、IRCOM[2]按键正码、IRCOM[3]按键反码,你程序里面:

if (IRCOM[2]!=取反IRCOM[3]) //判断如果按键正码不等于取反按键反码

{

EX0=1 //打开外部中断0

return //跳出结束

}

IRCOM[0]用户正码、IRCOM[1]用户反码,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=0j<4j++) //收集四组数据

{

for (k=0k<8k++)//每组数据有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=0i<100i++)

{

delay(4)

BEEP=!BEEP//BEEP取反

}

BEEP=1 //关闭蜂鸣器

}

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

void delay(unsigned char x)//x*0.14MS

{

unsigned char i

while(x--)

{

for (i = 0i<13i++) {}

}

}

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

void delay1(int ms)

{

unsigned char y

while(ms--)

{

for(y = 0y<250y++)

{

_nop_()

_nop_()

_nop_()

_nop_()

}

}

}

这个应该是可以运行的


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11176791.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-14
下一篇 2023-05-14

发表评论

登录后才能评论

评论列表(0条)

保存