谁有msp430红外遥控解码程序 C语言,最好有详细讲解。。谢了
发布网友
发布时间:2022-04-30 02:34
我来回答
共2个回答
热心网友
时间:2023-10-08 14:40
我只有51单片机的,给你参考下吧,只需稍作修改(定时器时间设定)就可以的:
//注意,虽然红外编码只有32位,但却有33个编码脉冲,需好好理解
#include<at89x52.h>
unsigned char irtime;
unsigned char count;
unsigned char receivedat[32];
unsigned char decodeddat;
unsigned char receiveok;
unsigned char decodingok;
//定时器初始化
void timer0init()
{
TMOD=0x02;//自动重装的方式
TH0=6;
TL0=6;//初始化为6,定时器每次溢出的间隔为0.25ms
ET0=1;
TR0=1;
}
//外部中断初始化
void ext0init()
{
IT0=1;//下降沿触发
EX0=1;
EA=1;
}
//定时器中断服务程序
void timer0() interrupt 1 using 1
{
irtime++;
}
//外部中断服务程序
void ext0() interrupt 0 using 0
{
if(irtime>=20)//这是4.5ms+0.56ms一段
{
count=0;
irtime=0;
}
else
{
receivedat[count]=irtime;//将红外遥控的32位编码存储起来
irtime=0;
count++;
if(count==32)//有32位以后就可以解码了
receiveok=1;//置位接收完成标志位
}
}
//红外解码函数
void decoding()
{
unsigned char i;
unsigned char temp;
temp=0x00;
for(i=0;i<8;i++)
{
if(receivedat[i+16]>=7 && receivedat[i+16]<=11)//只提取8位数据码
temp=temp|0x80;
if(i<7)
temp=temp>>1;//必须移位,因为发送时是低位在前高位在后
}
decodeddat=temp;
decodingok=1;//置位解码完成标志位
}
//主函数
void main()
{
P3_2=1;
P2=0x00;
P0=0xbf;//数码管显示一横
irtime=0;
receiveok=0;
decodingok=0;
//初始化定时器中断和外部中断。
timer0init();
ext0init();
//主循环
while(1)
{
if(receiveok==1)//如果接收完毕
{
decoding();
receiveok=0;
}
if(decodingok==1)//如果解码完毕
{
switch(decodeddat)
{
case 0:P0=0xf9;P1=0xfe;break;//1 显示相应的按键值
case 1:P0=0xa4;P1=0xfd;break;//2
case 2:P0=0xb0;P1=0xfb;break;//3
case 3:P0=0x99;P1=0xf7;break;//4
case 4:P0=0x92;P1=0xef;break;//5
case 5:P0=0x82;P1=0xdf;break;//6
case 6:P0=0xf8;P1=0xbf;break;//7
case 7:P0=0x80;P1=0x7f;break;//8
case 8:P0=0x90;P1=0x00;break;//9
}
decodingok=0;
}
}
}追问额。。我没用过51 有些地方看不太懂。。
热心网友
时间:2023-10-08 14:40
sp430红外解码成功
#include <msp430x22x4.h>
#define CPU_F ((double)1000000)
#define delay_us(x) __delay_cycles((long)(CPU_F*(double)x/1000000.0))
#define delay_ms(x) __delay_cycles((long)(CPU_F*(double)x/1000.0))
#define IR_DIR_IN P2DIR&=~BIT0 //红外接收头P2.0设置为输入,
#define IRIN (P2IN&BIT0) //红外接收头输入值
char data[4]; //保存地址码,地址反码,数据码,数据反码
char m;
/*****************************************************************************
系统初始化
******************************************************************************/
void InitSys()
{
WDTCTL = WDTPW + WDTHOLD; //关闭看门狗
DCOCTL=CALDCO_1MHZ;
BCSCTL1=CALBC1_1MHZ;
P2IE|=BIT0; //P2.0中断功能打开
P2IES|=BIT0; //P2.0下降沿触发中断
IR_DIR_IN; //P2.0设置为输入
_EINT(); //打开全局中断控制
}
int main( void )
{
InitSys(); //初始化
while(1);
}
/*****************************************************************************
端口1中断函数
******************************************************************************/
#pragma vector=PORT2_VECTOR
__interrupt void Port2()
{
char i,j,k=0,m=1;
if((P2IFG&BIT0) == BIT0)
{
P2IFG &= ~BIT0; //清除P2.0中断标志
P2IE &=~BIT0; //关闭P2.0中断功能
for (i=0;i<8;i++) //等待9ms引导码,在9ms内出现高电平则退出解码
{
delay_ms(1);
if (IRIN==1) m=0;
}
while(!IRIN); //等 IR 变为高电平
delay_ms(4); //等待4.5ms结果码
if(m==1)
{
while (IRIN); //等 IR 变为低电平
for(k=0;k<4;k++)
{
for (j=0;j<8;j++)
{
delay_us(500); //等待560us低电平
while (!IRIN); //等 IR 变为高电平
char n=0;
while (IRIN) //计算IR高电平时长
{
delay_us(140);
n++;
}
data[k]=data[k]>>1;
if (n<7) {data[k]&=0x7f;}
else
if(n>=7&&n<13)
{data[k]|=0x80;}
else
if (n>=13)
{
P2IE|=BIT0;
}
}
}
}
}
P2IE|=BIT0;
}