目录
一、主要功能
二、硬件资源
三、程序编程
四、实现现象
一、主要功能
基于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.1void dec01(void); //步进减0.1void add1(void); //步进加1void dec1(void); //步进减1void 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