#include<reg52.h>
#define uchar unsigned char
#define uint unsigned int
sbit START=P1^0;//启动信号
sbit EOC=P1^1;//转换结束信号
sbit ENA=P1^2;//输出使能
sbit CLK=P1^3;//时钟信号
sbit P07=P0^7;//小数点位
sbit P14=P1^4;//A地址输入线端
sbit P15=P1^5;//B地址输入线端
sbit P16=P1^6;//C地址输入线端
uchar code DSY_CODE[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//
uchar getdata;
uchar count;
uint i;
uint j;
uint temp;
void Time1(void) interrupt 3 using 0
{
TH1=(65536-200)/256;
TL1=(65536-200)%256;
CLK=~CLK;
}
void Time1_Init()
{
TMOD=0x10;
TH1=(65536-200)/256;
TL1=(65536-200)%256;
EA=1;
ET1=1;
TR1=1;
}
void DelayMS(uint i)
{
uint j;
for(;i>0;i--)
{
for(j=0;j<125;j++)
{
;
}
}
}
void Display(uint temp)
{
P2=0xfe;//第1个数码管显示千位数
P0=DSY_CODE[temp/1000];
DelayMS(1);
P0=0x00;
P2=0xfd;//第2个数码管显示百位数
P0=DSY_CODE[temp%1000/100];
P07=1;
DelayMS(1);
P0=0x00;
P2=0xfb;//第3个数码管显示十位数
P0=DSY_CODE[temp%100/10];
DelayMS(1);
P0=0x00;
P2=0xf7;//第4个数码管显示个位数
P0=DSY_CODE[temp%10];
DelayMS(1);
P0=0x00;
}
void main()
{
Time1_Init();
P14=0;//A地址输入线端
P15=0;//B地址输入线端
P16=0;//C地址输入线端
while(1)
{
START=0;//启动信号初始为低电平
ENA=0;//允许输出信号初始为低电平
START=1;//启动信号由低电平变为高电平,产生上升沿,内部寄存器清零。
START=0;//启动信号由高电平变为低电平,产生下降沿,开始A/D转换。
while(EOC==0);//等待转换完成,开始A/D转换时为低电平,A/D转换结束后为高电平。
ENA=1;//允许输出A/D数据到单片机
getdata=P3;//A/D数据;
temp=getdata*1.0/255*5*100;//由于实际电压的模拟量范围是0~5v,而AD0808测量到的是数字量的信号0~255(即8个0到8个1),也就是你知道AD0808测量到某个数字量dat后,根据x/5v=dat/255公式来算出x为多少伏 。为何乘以100?主要为了取到电压整数值,对应无符号整数型变量temp。至于乘以1.0是为了计算出的结果是浮点数。
Display(temp);//模拟量显示
ENA=0;//关闭允许输出A/D数据到单片机
}
}