程序如下:
#include<reg52.h>
#define uchar unsigned char
sbit JDQ=P3^7; //继电器接P3.7
sbit FMQ=P3^6;
sbit LED=P0^0;
sbit LEDra=P0^1;
sbit LEDar=P0^2;
uchar dat[4];
int i=0;
void Delay(unsigned int ii) //1mS
{
unsigned int jj;
for(;ii>0;ii--)
for(jj=0;jj<125;jj++)
{;}
}
void init_serialcom( void ) //串口通信初始设定
{
TMOD|=0x20; //定时器中的方式控制寄存器TMOD,设置T1为工作模式2,当TL1溢出时,TH1的值自动装入TL1,TH1和TL1当然都要赋值.TMOD前四位T1,后四位T0:GATE=0,C/T=0,M1=0,M0=01
TR1=1; //定时器中的运行控制寄存器TCON,允许T1计数
TH1=0xfd; //波特率9600
TL1=0xfd;
SCON = 0x50 ; //SM0=0;SM1=1;REN=1; UART为模式1,8位数据,允许接收,
PCON |= 0 ; //SMOD=1;波特率的问题。
IE|=0x90 ; //中断允许寄存器IE,P97,EA终端总允许标志位,ES串行口中断允许位
}
void jdq() interrupt 4{ //void 函数名() interrupt 4
EA=0;
if(RI)
{
RI=0;
if(i<4)
{
dat[i] = SBUF;
i++;
}
if(dat[2]==0x10 && dat[0]==0xE5 && dat[1]==0xA1 && dat[3]==0x4E) //E5A1 104E
{
JDQ=0;//吸合
LED=0;//P0口LED亮
LEDra=1;
LEDar=1;
}
else if(dat[2]==0x11 && dat[0]==0xE5 && dat[1]==0xA1 && dat[3]==0x4D) //E5A1114D
{
JDQ=1; //释放
LED=1; //P0口LED灯灭
LEDra=1;
LEDar=1;
}
else
{
LEDra=0;
LEDar=0;
LED=1;
}
if(i>=4)i=0;else;
}
EA=1;
}
main() //串口方式1发送时的定时信号,也就是移位脉冲,由定时器1产生。不是定时器0。
{
init_serialcom();
Delay(10);
while(1);
}
第一次独立写的,程序粗糙了点,但是完美运行。
发送:E5A1 104E,继电器闭合
E5A1 114D,继电器断开
这里控制用到了四个字节,所以在中断程序里面我定义了一个数组,最后判断这四个字节是否都正确。如果一个字节的话更简单。