📄 复件 main.c.bak
字号:
#include <AT89X52.H>
#include <string.h>
sbit sousel = P1^7;
sbit ch0 = P1^6;
sbit ch1 = P1^5;
sbit ch2 = P1^4;
sbit ch3 = P1^3;
sbit ch4 = P1^2;
sbit ch5 = P1^1;
sbit ch6 = P1^0;
sbit ch7 = P0^0;
sbit ch8 = P0^1;
sbit ch9 = P0^2;
sbit ch10 = P0^3;
sbit jt = P0^4;
sbit rl0 = P0^5;
sbit rl1 = P0^6;
sbit rl2 = P0^7;
sbit rl3 = P2^0;
sbit rl4 = P2^1;
sbit rl10 = P2^2;
sbit rl9 = P2^3;
sbit rl8 = P2^4;
sbit rl7 = P2^5;
sbit rl6 = P2^6;
sbit rl5 = P2^7;
sbit sou = P3^6;
sbit s42 = P3^7;
#define INBUF_LEN 9 //数据长度
unsigned char inbuf[INBUF_LEN], swstr[INBUF_LEN];
unsigned char checksum,count, strleng;
code unsigned char pos[6] = {3, 1, 5, 2, 4, 0};
code unsigned char ss[] = "GuoChao Soft co, V1.2!";
bit read_flag = 0 ;
bit incept = 0;
void init_serialcomm( void )
{
SCON = 0x50 ; //SCON: serail mode 1, 8-bit UART, enable ucvr
TMOD |= 0x20 ; //TMOD: timer 1, mode 2, 8-bit reload
PCON |= 0x80 ; //SMOD=1;
TH1 = 0xFA ; //Baud:9600 fosc=11.0592MHz
IE |= 0x90 ; //Enable Serial Interrupt
TR1 = 1 ; // timer 1 run
// TI=1;
}
//向串口发送一个字符
void send_char_com( unsigned char ch)
{
SBUF=ch;
while (TI== 0 );
TI= 0 ;
}
//向串口发送一个字符串,strlen为该字符串长度
void send_string_com( unsigned char *str, unsigned int strlen)
{
unsigned int k= 0 ;
do
{
send_char_com(*(str + k));
k++;
} while (k < strlen);
}
//串口接收中断函数
void serial () interrupt 4 using 3
{
unsigned char i;
if (RI)
{
unsigned char ch;
RI = 0 ;
ch=SBUF;
if (ch == 0x55 )
{
incept = 1;
count = 0;
for(i = 0; i < 7; i ++)
inbuf[i] = 0x00;
}
if(incept)
{
inbuf[count]=ch;
count++;
}
if (count == 2)
{
if ((inbuf[1] == 0x01) | (inbuf[1] == 0x02))
{
if (inbuf[1] == 0x01) //验证串
strleng = 5;
if (inbuf[1] == 0x02) //命令字
strleng = 9;
}
else
{
incept = 0; //第二字节无效,恢复接收状态
}
}
if (count == strleng)
{
read_flag= 1 ; //如果串口接收的数据达到INBUF_LEN个,且校验没错,
incept = 0;
}
}
}
void delay(unsigned char x)
{
while(x --);
}
unsigned char decode(voi)
{
unsigned char i, tem, tem1, same = 0;
if(read_flag & ((inbuf[1] & 0x03) == inbuf[1]) & ((inbuf[2] & 0x03) == inbuf[2])) //第2第3字节是否合法(整条数据是否合法)
{
if (strleng == 9) //验证串,做编码
{
for(i = 0; i < strleng; i ++)
{
swstr[i] = inbuf[pos[i] + 3];
}
swstr[0] = ~swstr[0]; //第0位取反
tem = swstr[1] & 0x1f; //第1右5
swstr[1] >>= 5;
swstr[1] |= tem << 3;
tem = swstr[2] & 0xb0; //第2位左2
swstr[2] <<= 2;
swstr[2] |= tem >> 4;
tem = swstr[3] & 0x07; //第3位右3
swstr[3] >>= 3;
swstr[3] |= tem << 5;
tem = swstr[4] & 0x3f; //第4位右6
swstr[4] >>= 6;
swstr[4] |= tem << 2;
swstr[5] = ~swstr[5];
send_string_com(swstr, 6);
}
if (strleng == 5) //命令串,解析
{
for (i = 0; i < 5; i ++)
{
if (swstr[i] != inbuf[i])
{same = 1;}
swstr[i] = inbuf[i];
}
if (same)
{
//通道0
if ((inbuf[3] & 0x80) == inbuf[3])
{
ch0 = 0;
rl0 = 0;
}
else
{
ch0 = 1;
rl0 = 1;
}
//通道1
if ((inbuf[3] & 0x40) == inbuf[3])
{
ch1 = 0;
rl1 = 0;
}
else
{
ch1 = 1;
rl1 = 1;
}
//通道2
if ((inbuf[3] & 0x20) == inbuf[3])
{
ch2 = 0;
rl2 = 0;
}
else
{
ch2 = 1;
rl2 = 1;
}
//通道3
if ((inbuf[3] & 0x10) == inbuf[3])
{
ch3 = 0;
rl3 = 0;
}
else
{
ch3 = 1;
rl3 = 1;
}
//通道4
if ((inbuf[3] & 0x08) == inbuf[3])
{
ch5 = 0;
rl5 = 0;
}
else
{
ch0 = 5;
rl0 = 5;
}
//通道6
if ((inbuf[3] & 0x04) == inbuf[3])
{
ch6 = 0;
rl6 = 0;
}
else
{
ch6 = 1;
rl6 = 1;
}
//通道7
if ((inbuf[3] & 0x02) == inbuf[3])
{
ch7 = 0;
rl7 = 0;
}
else
{
ch7 = 1;
rl7 = 1;
}
//通道8
if ((inbuf[4] & 0x80) == inbuf[4])
{
ch8 = 0;
rl8 = 0;
}
else
{
ch8 = 1;
rl8 = 1;
}
//通道9
if ((inbuf[4] & 0x40) == inbuf[4])
{
ch9 = 0;
rl9 = 0;
}
else
{
ch9 = 1;
rl9 = 1;
}
//通道10
if ((inbuf[4] & 0x20) == inbuf[4])
{
ch10 = 0;
rl10 = 0;
}
else
{
ch10 = 1;
rl10 = 1;
}
//监听通道
if ((inbuf[4] & 0x10) == inbuf[4])
{
jt = 0;
// rl0 = 0;
}
else
{
jt = 1;
// rl0 = 1;
}
//音源选择通道1音频
if ((inbuf[2] & 0x02) == inbuf[2])
{
sousel = 0;
sou = 0;
}
else
{
sou = 1;
}
//音源选择通道1TTS
if ((inbuf[2] & 0x01) == inbuf[2])
{
sousel = 1;
s42 = 0;
}
else
{
s42 = 1;
}
}
}
read_flag = 0;
}
}
void main(void)
{
init_serialcomm(); //初始化串口
send_string_com(ss, 22);
while ( 1 )
{
decode();
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -