#define uchar unsigned char
#define uint unsigned int
#define DogReset() WDT_CONTR=0x35
// T1 定时 0.1ms.作为系统计时用,
#define vT01ms 2
#define vT10ms 10
#define vT100ms 10
#define vT01S 100 // 1 s = 10 ms * 100
#define vT0HVal 0xfe //0xff //0xfe //0xf6
#define vT0LVal 0x33 //0x9c //0x0c //0x4c
uchar code display_AD_channel_ID[2] = {0x00,0x01};
statIC unsigned char data CS;
uchar data AD_channel_result[2][5]; //各通道A/D转换结果。前是通道号;后是转换的值
uint cT01ms;
uchar cT10ms;
uchar cT100ms;
uchar cT01s;
uchar THTL;
bit OutFlag;
/**************************************************************************
* 函数原型: void delay_ms(uint Count)
* 功 能: 延时Count个ms
**************************************************************************/
void delay_ms(register uint Count){
register uchar T;
for(;Count>0;Count--){
for(T=0;T<80;T++){
_nop_(); _nop_(); _nop_(); _nop_(); _nop_();
_nop_(); _nop_(); _nop_(); _nop_(); _nop_();
}
DogReset();
}
}
/**************************************************************************
* 函数原型: void ComOutChar(unsigned char OutData)
* 功 能: 向串口输出一个字符(非中断方式)
**************************************************************************/
void send_char_com(unsigned char OutData){
SBUF = OutData; //输出字符
while(!TI); //空语句判断字符是否发完
TI = 0; //清TI
}
/**************************************************************************
* 函数原型: void ComOutChar(unsigned char OutData)
* 功 能: 向串口输出一个字符(非中断方式)
**************************************************************************/
void send_string_com(uchar *str,uchar strlen){
uchar i;
for(i=strlen; i>0; i--){
send_char_com(*str);
str++;
DogReset();
}
}
/**************************************************************************
* 函数原型: void Ad_Change(uchar channel)
* 功 能: A/D转换
* 入口:channel = 通道号 .0:0通道;1:1通道。。。。。。。
* 出口:AD_channel_1_result: 10位的数据,16进制。
**************************************************************************/
uchar Ad_Change(uchar channel){
uint AD_Result_Temp = 0 ;
//---------------------将P1.0--P1.1设置成适合AD转换的模式
/// P1 = 0xff; //将P1口置高,为A/D转换作准备
ADC_CONTR = ADC_CONTR|0x80; //1000,0000打开A/D转换电源
P1M0 = 0x03; //0000,0011用于A/D转换的P1.x口,先设为开漏
P1M1 = 0x03; //0000,0011P1.0--P1.1先设为开漏。断开内部上拉电阻
delay_ms(20); //20
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);
}
/**************************************************************************
* 函数原型: void AD_FiLTEr(void)
* 功 能: 串口初始化 晶振为11.0592M 方式1 波特率300-57600
**************************************************************************/
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)
* 功 能: 串口初始化 晶振为11.0592M 方式1 波特率300-57600
**************************************************************************/
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);
* 功 能: 参数初始化
**************************************************************************/
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);
* 功 能: 参数初始化
**************************************************************************/
void Para_initial(void){
OutFlag=0;
cT01ms = vT01ms;
cT10ms = vT10ms;
// cT100ms = vT100ms;
cT01s = vT01S;
CS = 0; //设置CS为0不选任何的音源,如为1则选第1路
}
/**************************************************************************
* 函数原型: void system_initial(void);
* 功 能: 系统初始化
**************************************************************************/
void system_initial(void){
Chip_initial();
Para_initial();
DogReset(); // 已针对 STC89C58RD+ 作修改.06-04-06
}
/**************************************************************************
* 函数原型: void main(void)
* 功 能:
**************************************************************************/
void main(void){
system_initial();
while(1){
DogReset();
if(OutFlag){
OutFlag=0;
send_char_com(AD_Filter());
}
}
}
/**************************************************************************
* 函数原型: void Trint0(void) interrupt 1 using 1;
* 功 能: 全局定时
**************************************************************************/
void Trint0(void) interrupt 1 using 1{
/*
// 1ms 定时设置
time0_tmp = 65536-time0*fosc/12;
TH0 = (time0_tmp/256);
TL0 = (time0_tmp%256);
*/
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;
/* if(++vSecond>59){
vSecond=0;
if(++vMinute>59){
vMinute=0;
if(++vHour>23){
vHour=0;
}
}
}*/
}
}
}
}
/**************************************************************************
* 函数原型: void Trint1(void) interrupt 1 using 1;
* 功 能: 全局定时
**************************************************************************/
/*
void Trint1(void) interrupt 1 using 1{
TR0=0;
TH0 = vT0HVal; // 时基1ms
TL0 = vT0LVal;
TF0=0;
TR0=1;
if(!(--cT01ms)){ //1ms
cT01ms=vT01ms;
if(!(--cT10ms)){ //10ms
cT10ms=vT10ms;
if(!(--cT100ms)){ //100ms
cT100ms=vT100ms;
if(!(--cT01s)){ //1s
cT01s=vT01S;
OutFlag=!OutFlag;
}
}
}
}
}
/**************************************************************************
* 函数原型: void ComInINT(void) interrupt 4 using 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清零
}
}
/**************************************************************************
* end
* end
**************************************************************************/