本帖最后由 1五湖四海1 于 2011-7-8 20:51 编辑
经过这几天制作单片机红外线遥控解码的学习研究中,遇到了许多不解的问题,虽然有了难题但是我不愿意请教我的老师,因为不经思考随便跑去问别人问题会失去自己独立学习和解决实际问题的好机会。为了学习单片机技术,满足自己DIY的愿望我努力,认真的分析没一条语句,最终在今天晚上我的DIY单片机红外遥控解码器调试初步成功了,手里拿着遥控器随便按了一个键子,便会在单片机接收器数码管上显示该键子了数据编码。甭提心里有多高兴了,我兴奋了一个晚上。
这回DIY我心爱的数字存储示波器为我立下汗马功劳,帮我捕捉了遥控器发射的数据编码,让我可以借助仪器解出每一个按键数据编码。示波器在调试单片机红外接收器延时程序时,也起到重大作用。这次成功还少不了跟随我5年的台式电脑和USB编写器。
实验电路板
汗马功劳的示波器
#include<reg51.h> //成功时间2011.07.08 // 函数原型
void SystemInit(void);
void Delay_840us(void);
void Delay_2400us(void);
void LedDisp();
unsigned char GetCode(void);//获得码 // 位变量
sbit IRIN = P3^2;
// 变量
unsigned char KeyValue; //机器码
unsigned char MaValue; //键值码;
unsigned char disbuf[4]; //数码管显示缓冲
unsigned char code table[16] =
{~0x3F,~0x06,~0x5B,~0x4F,~0x66,~0x6D,~0x7D,~0x07,~0x7F,~0x6F,~0x77,~0x7C,~0x39,~0x5E,~0x79,~0x71};
* 延时9ms
*/
void Delay_9000us(void)
{
TH1=(65536-27300)/256;
TL1=(65536-27300)%256;
TR1 = 1;
while(!TF1);
TF1 = 0;
TR1 = 0;
} /**
* 延时4.5ms
*/
void Delay_4500us(void)
{
TH1=(65536-13800)/256;
TL1=(65536-13800)%256;
TR1 = 1;
while(!TF1);
TF1 = 0;
TR1 = 0;
} //延时0.84ms
void Delay_840us(void)
{
TH1=(65536-2520)/256;
TL1=(65536-2520)%256;
TR1 = 1;
while(!TF1);
TF1 = 0;
TR1 = 0;
} /**
* 系统初始化
*/
void SystemInit(void)
{
IRIN = 1;
IT0 = 1; //INT0负跳变触发
TMOD = 0x10; //定时器1工作在方式1
EA = 1;
EX0 = 1;
} /**
* 读码
*/
unsigned char GetCode()
{
unsigned char n; static temp = 0; for( n = 0; n < 8; n++ )
{
while(!IRIN); // 等待高电平,开始解码 Delay_840us(); // 延时0.84ms if(IRIN) // 若仍然为高电平,则为1,否则为0
{
temp = (0x80|(temp>>1)); // 1
while(IRIN); //等待跳变成低电平
}
else {
temp=(0x00|(temp>>1)); // 0
}
} return temp;
} /**
* 数码管显示
*/
void LedDisp()
{
/* unsigned char i;
for(i=0;i<4;i++)
{
P1=0xff;
P1=table[disbuf];
P2=0xdf;
delay(4);
P2>>=1;
}*/
P1=table[disbuf[1]];
P2=table[disbuf[0]];
} void main(void)
{
SystemInit(); while(1)
{
//以下是查表显示
disbuf[0]=(((KeyValue&0xf0)>>4)&0x0f);
disbuf[1]=KeyValue&0x0f;
// disbuf[2]=(((MaValue&0xf0)>>4)&0x0f);
// disbuf[3]=MaValue&0x0f;
LedDisp();
}
}
void interr_ir(void) interrupt 0
{
/**
* 用户码和机器码
*/
unsigned char addrl,addrh,num1,num2;
EA = 0; //先关闭外部中断0
Delay_9000us(); // 检测9ms开始码 if (!IRIN) { // 检测是否为干扰信号
EA = 1; // 重新开启外部中断0
return ; // 退出解码
}
while(!IRIN); // 等待跳为高电平 Delay_4500us(); // 检测4.5ms结果码 if (IRIN) { // 检测是否为干扰信号
EA = 1; // 重新开启外部中断0
return ; // 退出解码
} // 读码
addrl=GetCode(); // 用户编码高位
addrh=GetCode(); // 用户编码低位
num1=GetCode(); // 机器码
num2=GetCode(); // 机器码反码 //校验是否为错码
if(num1!=~num2)
{
KeyValue=14;
EA=1;
return;
} KeyValue=num2;
MaValue=addrh; EA=1;
}
|