ADC_CONTR = ADC_CONTR&0xE0; //1110,0000 清ADC_FLAG,ADC_START位和低3位
ADC_CONTR = ADC_CONTR|(display_AD_channel_ID[channel]&0x07); //设置当前通道号
delay_ms(1);//延时使输入电压达到稳定
ADC_DATA = 0;//清A/D转换结果寄存器
ADC_LOW2 = 0;
ADC_CONTR = ADC_CONTR|0x08; //0000,1000ADCS = 1,启动转换
do { DogReset();}
while((ADC_CONTR & 0x10)==0);//0001,0000等待A/D转换结束
ADC_CONTR = ADC_CONTR&0xE7; //1110,0111清ADC_FLAG位,停止A/D转换
AD_Result_Temp = ((AD_Result_Temp|ADC_DATA)<2)|(ADC_LOW2&0x03);
//保存返回AD转换的 结果
//----------------------------转换成可由串口显示的字符
AD_channel_result[channel][0] = AD_Result_Temp/1000+0x30;
AD_channel_result[channel][1] = (AD_Result_Temp%1000)/100+0x30;
AD_channel_result[channel][2] = (AD_Result_Temp%100)/10+0x30;
AD_channel_result[channel][3] = AD_Result_Temp%10+0x30;
//------------------------串口监视
//send_char_com(ADC_DATA);//////发送转换 的 到的 值,这里只是 高8位,值的转换需要考虑
// send_char_com(ADC_LOW2);//////发送转换 的 到的 值,这里只是 低2位,值的转换需要考虑
//send_string_com(AD_channel_result[channel],4);
delay_ms(10);//
return(ADC_DATA);
}
uchar AD_Filter(void){
uchar i;
uchar cTemp[32];
uchar cAverage;
for(i=32;i>0;i--){
cTemp[i]=Ad_Change(0);
cAverage=((cAverage+cTemp[i])>>1);
}
return(cAverage);
}
void InitCom(unsigned char BaudRate){
switch (BaudRate){
case 1: THTL = 64; break; //波特率300
case 2: THTL = 160; break; //600
case 3: THTL = 208; break; //1200
case 4: THTL = 232; break; //2400
case 5: THTL = 244; break; //4800
case 6: THTL = 250; break; //9600
case 7: THTL = 253; break; //19200
case 8: THTL = 255; break; //57600
default: THTL = 208; break; //1200
}
}
void Chip_initial(void){
IE=0;
// 定时器控制字初始化
TMOD=0x21;// 定时器1为方式2,定时器0为方式1
TCON=0x50;// 设置外部中断类型
T2CON=0x0d;// 选择定时器1为波特率发生器,T2为捕获工作方式
//ET2=1;
ET0=1; // 允许定时器0、定时器2中断
// 外部中断设置
EX0=0;// FFSK中断初始时关闭,有载波时再开启
EX1=0;
IT1=1;// 外部中断0、1均为下降沿触发
IT0=1;
// 启动定时器0
TH0=vT0HVal;// 启动定时器0
TL0=vT0LVal;
TR0=1;
InitCom(6); //设置波特率为9600 1-7波特率300-19200
SCON = 0x50; //串口方式1,允许接收
TH1 = THTL;
TL1 = THTL;
PCON = 0x80; //波特率加倍控制,SMOD位
RI = 0;//清收发标志
TI = 0;
TR1 = 1;//启动定时器
IP=0x02;//PT2=1
IPH=0x02;//PT2H=1,PT0H=1
EA=1;
delay_ms(10);// 延时是为了避免定时器0无法产生中断的问题
}
void Para_initial(void){
OutFlag=0;
cT01ms=vT01ms;
cT10ms=vT10ms;
//cT100ms= vT100ms;
cT01s= vT01S;
CS = 0; //设置CS为0不选任何的音源,如为1则选第1路
}
void system_initial(void){
Chip_initial();
Para_initial();
DogReset(); // 已针对 STC89C58RD+ 作修改.06-04-06
}
void main(void){
system_initial();
while(1){
DogReset();
if(OutFlag){
OutFlag=0;
send_char_com(AD_Filter());
}
}
}
void Trint0(void) interrupt 1 using 1{
TR0=0; // 时基1mS
TH0=vT0HVal;
TL0=vT0LVal;
TR0=1;
TF0=0;
if(!(--cT01ms)){
cT01ms=vT01ms;
if(!(--cT10ms)){
cT10ms=vT10ms;
if(!(--cT01s)){
cT01s=vT01S;
OutFlag=1;
}
}
}
}
void ComInINT(void) interrupt 4 {
if (RI){ //判断是不收完字符
switch(SBUF){
case 0x61: CS = 1; break; //根据SBUF设置CS 接收abcde调试方便
case 0x62: CS = 2; break;
case 0x63: CS = 3; break;
case 0x64: CS = 4; break;
case 0x65: CS = 0; break;
}
P1 = 255; //P1口全为高电平,4-7通过反相为低不选任何音源,0-3为高用于读取按键
RI = 0; //RI清零
}
}