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

目录

一、主要功能

二、硬件资源

三、程序编程

四、实现现象


一、主要功能

基于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转换

全部资料(源程序、仿真文件、安装包、演示视频):

百度网盘下载资料icon-default.png?t=O83Ahttps://pan.baidu.com/s/1F3iOjg7KN7wQQkEIwByUxQ?pwd=ef5v

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

资源获取请看主页置顶文章

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值