/**********************AD采样函*************************************/
uchar AD()
{
uchar value;
adcs=0; //选通AD转换器片选
adwr=0; //AD写入(主要是为了启动AD转换) Delay(1); adwr=1;
P1=0xff; //读取P1口之前先给其写全1 adrd=0; //AD读使能 value=P1; //AD数据读取赋给P1口 adrd=1; adcs=1; P1=0xff; return(value); }
uint ADC0832(uchar channel) {
uchar i; uint dat=0; uchar ndat=0;
if(channel==0)channel=2; if(channel==1)channel=3; ADDI=1; _nop_(); _nop_();
ADCS=0;//拉低CS端 _nop_(); _nop_();
ADCLK=1;//拉高CLK端 _nop_(); _nop_();
ADCLK=0;//拉低CLK端,形成下降沿1 _nop_();
数
_nop_();
ADCLK=1;//拉高CLK端 ADDI=channel&0x1; _nop_(); _nop_();
ADCLK=0;//拉低CLK端,形成下降沿2 _nop_(); _nop_();
ADCLK=1;//拉高CLK端 ADDI=(channel>>1)&0x1; _nop_(); _nop_();
ADCLK=0;//拉低CLK端,形成下降沿3 ADDI=1;//控制命令结束 _nop_(); _nop_(); dat=0; for(i=0;i<8;i++) {
dat|=ADDO;//收数据
ADCLK=1; _nop_(); _nop_();
ADCLK=0;//形成一次时钟脉冲 _nop_(); _nop_(); dat<<=1;
if(i==7)dat|=ADDO; }
for(i=0;i<8;i++)
{
ndat>>=1;
if(ADDO==1) ndat|=0x80;
ADCLK=1; _nop_(); _nop_();
ADCLK=0;//形成一次时钟脉冲 _nop_(); _nop_(); }
ADCS=1;//拉低CS端 ADCLK=0;//拉低CLK端
ADDO=1;//拉高数据端,回到初始状态
if(dat==ndat)
{
return(ndat);
} else {
return(0x00);
}
/**********************AD转换值转温度值函数*************************************/
void Data_temperature() {
float b; uchar i;
for(i=0;i<=74;i++) { if((LPFdata>=temdata[i])&(LPFdatab=temtest[i]+(LPFdata-temdata[i])*((temtest[i+1]-temtest[i])/(temdata[i+1]-temdata[i]));break;
} }
temperature=b*10;//强制转化为整形 }