#include <reg52.h>
#include<intrins.h>
#define uint unsigned int
#define uchar unsigned char
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
sbit LSA=P2^2;
sbit LSB=P2^3;
sbit LSC=P2^4;
uint adc_finished;
float a;
uchar shi,ge,bai;
int b;
sfr adc_contr=0xbc;//adc控制寄存器,不可位寻址,用或运算来设置
sfr adc_res=0xbd;//转换结果寄存器,高八位
sfr adc_low2=0xbe;//转换结果寄存器,低两位
sfr p1asf=0x9d;//设置p1的那一口为输入口,不可位寻址.
/*以下都是控制寄存器的各位地址*/
#define adc_power 0x80;//adc电源,第7位
#define adc_flag 0x10;//转换结束标志位,第4位
#define adc_start 0x08;//转换开始,第3位
#define adc_speedll 0x00;//速度位,第5,6位
#define adc_speedl 0x20;
#define adc_speedh 0x40;
#define adc_speedhh 0x60;
#define adc_chs 0x00;//输入通道为第p1.0,1,2,3三位可设置p10-p17
//位定义完成
void adcinit() //adc初始化函数
{
p1asf=0x01; //设置p10 为ad转换输入口
adc_contr=0xe0; //打开电源,设最高速度
_nop_();
_nop_(); //设置好ADC控制寄存器之后要加>4us
_nop_(); //的延时才能继续正确读取ADC控制寄存器的值
_nop_();
adc_contr|=adc_chs; //设置频道
_nop_();
_nop_(); //设置好ADC控制寄存器之后要加>4us
_nop_(); //的延时才能继续正确读取ADC控制寄存器的值
_nop_();
}
uint huqushuju() //adc转换函数,数据得到
{
adcinit();
adc_res=0;
adc_low2=0;
adc_contr|=adc_start;//启动ad转换,置1为起动,转换结束后自动置0
_nop_();
_nop_();
_nop_();
_nop_();
adc_finished=0;
while(adc_finished==0)
{
adc_finished=adc_contr&adc_flag;//检测是否转换结束,没结束一直等
}
adc_contr=adc_contr&0xef;//转换结束标志清零
//也可写成
_nop_();
_nop_(); //设置好ADC控制寄存器之后要加>4us
_nop_(); //的延时才能继续正确读取ADC控制寄存器的值
_nop_();
a=adc_res*4+adc_low2;
a=a*5/1023;
a=100-20*a;
a=a*10;
adc_contr|=adc_start;
_nop_();
_nop_(); //设置好ADC控制寄存器之后要加>4us
_nop_(); //的延时才能继续正确读取ADC控制寄存器的值
_nop_();
return a;
}
void display(uchar bai,uchar shi,uchar ge)
{
uint i,t;
for(i=0;i<3;i++)
{
switch(i) //位选,选择点亮的数码管,
{
case(0):
LSA=0;LSB=0;LSC=0;P0=table[ge]; break;//显示第0位
case(1):
LSA=1;LSB=0;LSC=0; P0=table[shi];break;//显示第1位
case(2):
LSA=0;LSB=1;LSC=0;P0=table[bai]; break;//显示第2位
}
t=1000;
while(t--);
}
}
void main()
{
while(1)
{
b=(int)a;
ge=b%10;
shi=b/10/10;
bai=b/100;
display(bai,shi,ge);
}
}
这是我的程序 但是数码管显示000 模拟信号没问题
|