基于单片机的精确电压表DA-AD转换

目录

一、主要功能

二、硬件资源

三、程序编程

四、实现现象


一、主要功能

基于51单片机,采用DAC0832和ADC0832检测电压,0到8.5V,设计复位电路
LED管显示实际稳压值,初始电压0

二、硬件资源

基于KEIL5编写C++代码,PROTEUS8.15进行仿真,全部资源在页尾,提供安装包。

三、程序编程

cpp 复制代码
#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

相关推荐
The Mr.Nobody2 小时前
STM32MPU开发之旅:从零开始构建嵌入式Linux镜像
linux·stm32·嵌入式硬件
阿川!2 小时前
嵌入式软件--stm32 DAY 3
stm32·单片机·嵌入式硬件
#金毛4 小时前
STM32的定时器输出PWM时,死区时间(DTR)如何计算
stm32·单片机·嵌入式硬件
无脑学c++4 小时前
STM32串口重定向:MDK与GCC重定向需重写的不同函数
stm32·单片机·物联网
Invinciblenuonuo4 小时前
STM32八股【6】-----CortexM3的双堆栈(MSP、PSP)设计
stm32·单片机·嵌入式硬件
2401_888859715 小时前
STM32 TIM编码器接口
stm32·单片机·嵌入式硬件
【0931】5 小时前
51单片机中断
单片机·嵌入式硬件
学习噢学个屁7 小时前
基于51单片机的超声波液位测量与控制系统
c语言·单片机·嵌入式硬件·51单片机
电鱼智能的电小鱼7 小时前
EFISH-SBC-RK3588无人机地面基准站项目
linux·网络·嵌入式硬件·机器人·无人机·边缘计算
电鱼智能的电小鱼7 小时前
基于 EFISH-SBC-RK3588 的无人机环境感知与数据采集方案
linux·网络·嵌入式硬件·数码相机·无人机·边缘计算