ADC0809 C程序

 #include<reg52.h>
#include<intrins.h>
#define uint  unsigned int
#define uchar unsigned char
uint date;
uchar mm=0,n=0;
uint k1,k2,k3,k4,k5,k6;
uchar code b[]={
    0x3f,0x06,0x5b,0x4f,0x66,   //0,1,2,3,4,
    0x6d,0x7d,0x07,0x7f,0x6f,   //5,6,7,8,9,C
    0xbf,0x86,0xdb,0xcf,0xe6,   //0.,1.,2.,3.,4.,
    0xed,0xfd,0x87,0xff,0xef,   //5.,6.,7.,8.,9.,
    };
sbit P20=P2^0;
sbit P21=P2^1;
sbit P22=P2^2;
sbit P27=P2^7;
sbit wr=P3^6;
sbit rd=P3^7;
sbit P32=P3^2;
void delay_10us(uchar n)    //10微秒级延时
{ do
  { _nop_();
    _nop_();
    _nop_();
    _nop_();
    _nop_();
  }while(--n);
}
void delay_ms(uint n)     //毫秒级延时
{ do delay_10us(131);
  while(--n);
}
uchar adc0809()
{
 wr=0;
 _nop_();
 _nop_();
 wr=1;
  _nop_();
  _nop_();
 while(P32);
  rd=0;
  date=P0;
  delay_10us(10);
  rd=1;
  delay_ms(1000);
  date=date*19.607843;
  //date=date*(1000/51);
 n=0;
 k1=date/1000;//1
 k2=date%1000;//234
 k3=k2/100;//2
 k4=k2%100;//34
 k5=k4/10;//3
 k6=k4%10;//4
 if(n==0)
 {TI=0;
 SBUF=b[k6];
 while(!TI);
 TI=0;
 SBUF=b[k5];
 while(!TI);
 TI=0;
 SBUF=b[k3];
 while(!TI);
 TI=0;
 SBUF=b[k1+10];
 while(!TI);
 n=1;
}
}
void main()
{P0=0xff;
 P20=0;
 P21=0;
 P22=0;
 P27=0;
 while(1)
{
 adc0809();
}
}

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值