目录
一、主要功能
基于51单片机,采用DAC0832和ADC0832检测电压,0到8.5V,设计复位电路
LED管显示实际稳压值,初始电压0
二、硬件资源
基于KEIL5编写C++代码,PROTEUS8.15进行仿真,全部资源在页尾,提供安装包。
编辑
三、程序编程
#include <REGX52.H>#include<intrins.h> //定义头文件#include<stdio.h> //定义头文件#define uchar unsigned char#define uchar unsigned char#define uchar unsigned char //定义变量#define uint unsigned int //定义变量
//管脚定义
sbit jia=P1^6;
sbit jian=P1^7;
sbit LED1=P3^4;
sbit LED2=P3^5;
sbit LED3=P3^6;
sbit LED4=P3^7;
sbit CS=P3^0; //adc0832引脚
sbit CLK=P3^1; //adc0832引脚
sbit DIO=P3^2; //adc0832引脚
//函数声明
void delay(void); //延时
void key(void); //按键
void add01(void); //步进加0.1
void dec01(void); //步进减0.1
void add1(void); //步进加1
void dec1(void); //步进减1
void shuchu(void); //显示输出和电压调节
void DA(void); //模数转换
void beepwarning(int n);
uchar a\[11\]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0x8c};
static unsigned char bw=0,sw=0,gw=0,dw=0; static unsigned char fvol=00; static int number=0; static unsigned char st=0;uchar get\_AD\_Res() //ADC0832启动读取函数{
uchar i, data1=0, data2=0; //赋值变量
CS=0; //CS赋值低电平
CLK=0;DIO=1;\_nop\_(); //赋值变量 并且等待
CLK=1;\_nop\_(); //赋值变量 并且等待
CLK=0;DIO=1;\_nop\_(); //赋值变量 并且等待
CLK=1;\_nop\_(); //赋值变量 并且等待
CLK=0;DIO=0;\_nop\_(); //赋值变量 并且等待
CLK=1;\_nop\_(); //赋值变量 并且等待
CLK=0;DIO=1;\_nop\_(); //赋值变量 并且等待
for(i=0; i<8; i++) //循环
{
CLK=1;\_nop\_(); //赋值变量 并且等待
CLK=0;\_nop\_(); //赋值变量 并且等待
data1=(data1<<1)|(uchar)DIO;//赋值变量 并且等待
}
for(i=0; i<8; i++) //循环
{
data2=data2|(uchar)DIO<<i;//赋值变量 并且等待
CLK=1;\_nop\_(); //赋值变量 并且等待
CLK=0;\_nop\_(); //赋值变量 并且等待
}
CS=1; //赋值高电平
return(data1 == data2)?data1:0; //返回值}
void main(void) //主程序{
double u;
TMOD = 0x01;
TH0 = (65535-2000)/256;
TL0 = (65535-2000)%256;
EA=1;
ET0=1;
TR0=1;
while(1)
{
key();
DA();
u=get\_AD\_Res();
}
}void delay(void) //延时程序{
unsigned char i,j;
for(i=10;i>0;i--)
for(j=248;j>0;j--);
}
void key(void) //按键{
uchar k;
P1=0xff;
k=P1; if(k==0xff) return; delay();
k=P1; if(k==0xff) return; while(P1!=0xff) delay();
switch(k)
{ case 0xbf:add01();break;
case 0x7f:dec01();break; case 0xfe:add1();break; case 0xfd:dec1();break;
}
}
void add1(void){ if(fvol<85)
{
fvol=fvol+10; if(fvol>85)
fvol = 85;
}
sw=fvol/100;
gw=fvol%100/10;
dw=fvol%10;
}void dec1(void){ if(fvol>00) fvol=fvol-10;
sw=fvol/100;
gw=fvol%100/10;
dw=fvol%10;
}void add01(void) //步进加 0.1{
if(fvol<85) fvol++;
sw=fvol/100;
gw=fvol%100/10;
dw=fvol%10;
}
void dec01(void) //步进减0.1{
if(fvol>00) fvol--;
sw=fvol/100;
gw=fvol%100/10;
dw=fvol%10;
}
void Timer0() interrupt 1{
TH0 = (65535-2000)/256;
TL0 = (65535-2000)%256; switch(st)
{ case 0: st=1;LED2=1;LED3=1;LED4=1;P0=a\[bw\];LED1=0;break; case 1: st=2;LED3=1;LED4=1;LED1=1;P0=a\[gw\]+0x80;LED2=0;break; case 2: st=3;LED1=1;LED2=1;LED4=1;P0=a\[dw\];LED3=0;break; case 3: st=0;LED1=1;LED2=1;LED3=1;P0=a\[10\];LED4=0;break;
}
}void DA(void) //模数转换{ unsigned char temp,dianya;
temp=sw\*100+gw\*10+dw;
dianya=temp\*2.13\*0.9*0.984;
P2=dianya;
}
四、实现现象
具体动态效果看B站演示视频:
B站演示视频
基于单片机的精确电压表DA-AD转换
全部资料(源程序、仿真文件、安装包、演示视频):
百度网盘下载资料https://pan.baidu.com/s/1F3iOjg7KN7wQQkEIwByUxQ?pwd=ef5v