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