目录
一、主要功能
二、硬件资源
三、程序编程
四、实现现象
一、主要功能
基于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站演示视频:
基于单片机的精确电压表DA-AD转换
全部资料(源程序、仿真文件、安装包、演示视频):
百度网盘下载资料https://pan.baidu.com/s/1F3iOjg7KN7wQQkEIwByUxQ?pwd=ef5v