C红外解码程序

相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 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;

}

相关文档
最新文档