10 amp 12c语言,STC12C2052AD单片机AD转换程序设计

#include     //定义的 系统头文件和全局变量

#include

#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

**************************************************************************/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值