C红外解码程序
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
C红外解码程序Prepared on 21 November 2021
2007-01-3011:02:21
#include?
#include?
sfr?p0=0x80;
sfr?p3=0xb0;
sbit?p32=p3^2;
unsignedchardm,i,j,k;
unsignedchardataa[4];//定义4个数组,用来存储代码void?ds0_9ms(void)
{
unsignedcharj,k;
for(j=18;j>0;j--)
for(k=20;k>0;k--)
}
void?ds1ms(void)
{
unsignedchari,j;
for(i=2;i>0;i--)
for(j=230;j>0;j--)
}
void?ds4_5ms(void)
{
unsignedchari,j;
for(i=10;i>0;i--)
for(j=225;j>0;j--)
}
void?ds2s(void)
{
unsignedchari,j,k;
for(i=200;i>0;i--)
for(j=200;j>0;j--)
for(k=10;k>0;k--)
}
void?main()
{
IT0=1;
EX0=1;
EA=1;
dm=0;
ds2s();
p0=0;
while(1);
}
voidt0(void)interrupt0using2//外部中断0的函数{
EA=0;
for(k=0;k<10;k++)
{
ds0_9ms();
if(p32==1){k=10;break;}
elseif(k==9)
{
while(p32==0);
ds4_5ms();
for(i=0;i<4;i++)
{
for(j=1;j<=8;j++)
{
while(p32==0);
ds0_9ms();
if(p32==1)
{ds1ms();
dm=dm|0x80;
if(j<8)dm=dm>>1;
}
elseif(j<8)dm=dm>>1; }
a=dm;
dm=0;
}
for(i=0;i<4;i++) {
p0=a;
ds2s();
}
}
}
p0=0;
EA=1;
}