这次做的数控电源规划思维没什么新意,便是一个数模转化(ADC0809)和一个模数转化(DAC0832),再加上两个单片机别离操控0809和0832,组成一个反应网络,来得到输入的数字相对应的电压,电压规模很小,只要0~12.75V.显现部分选用四段共阴数码管
整块板子做出来之后有10*7cm那么大,用洞洞板焊的。
实测电路输出精度+/-0.05V在12V规模内。
硬件规划:
榜首块单片机P0口接数码管代码段的驱动,P2.4~P2.7接四位的位选线,P2.0~P2.3节四个独立操作按键[形式][加][减][确认],P1口接ADC0809的八位数据输出.P3.0~P3.3口接0809的操控线.P3.5~P3.7和第二块单片机的P2.0,P2.1,P2.2相连,用来操控数模输出增减。三根操控线效果别离为[输出改动答应操控Control_1][增减信号Control_2][增减速度操控Control_speed]
第二块单片机除了前面的三根操控线,就只剩余和DAC0832的操控线了,看电路图。
用0832输出操控LM317可调三端稳压器的输出电压:
DAC0809所需时钟脉冲由NE555发生
体系电源:5V12VGND-12V
程序清单:榜首块单片机:(接0809,四段数码管,四个独立按键)
#include
#defineucharunsignedchar
inTI=0,a=0;//界说循环算子
ucharhold=5;//当时操作数[0-led1][1-led2][2-led3][3-led4][4-快速调理][5-无]
ucharGet_data=0;//模数转化得到的成果
intGet_data2=0;//将Get_data*5用以便利转化(做电压表时用)//ucharled[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x00};//阳极驱动不带小数点
ucharled[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xFF};//阴极驱动
//ucharpoint[]={0xBF,0x86,0xDB,0xCF,0xE6,0xED,0xFD,0x87,0xFF,0xEF,0x00};//阳极驱动带小数点
ucharpoint[]={0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10,0xFF};
ucharV_list[]={30,36,60,66,90,100,120,180,240};//电压值列表
ucharV_index=6;//预置电压索引.ucharnum[4]={10,5,0,0};//显现缓存
ucharV_num=100;//显现的电压对应在0~255电之间的值,预置压数5V
ucharTIme=0;//操控模数转化频率变量
ucharTImes=0;//操控按键答应速度变量
ucharscan_grant=1;//答应输入
ucharhide_flag=0;//躲藏标志[0躲藏][1显现]和hold合作用于操控某一位数码管的亮灭
ucharhide_TIme=0;//用于操控数码管闪耀快慢
//ucharzhengshu,xiaoshu_1,xiaoshu_2;voiddelay(ints);
voidkey_mode();
voidkey_add();
voidkey_sub();
voidkey_confirm();
voiddisplay();
voidADC();
voidconvert();//将get_data填入到num[]数组中
voidscan_key();//键盘扫描函数
voidcompare();//比较函数(Control_1Control_2)[00-正确][11-加][10减]//界说位选线
sbitled_1=P2^7;
sbitled_2=P2^6;
sbitled_3=P2^5;
sbitled_4=P2^4;
sbitmode=P2^0;
sbitadd=P2^1;
sbitsub=P2^2;
sbitconfirm=P2^3;
//0809四根操控线
sbitALE=P3^0;
sbitSTART=P3^1;
sbitOE=P3^2;
sbitEOC=P3^3;
//两根操控线
sbitControl_1=P3^6;//改变操控线[1改变][0不变]
sbitControl_2=P3^7;//增减操控线[1增][0减]
sbitControl_speed=P3^5;//操控改变速度
sbitclose=P3^4;//当电压稳守时为0;voidmain()
{
//初始化
led_1=0;
led_2=0;
led_3=0;
led_4=0;
//初始化守时器
TMOD=0x01;//守时器0,方法1
TH0=0x3c;
TL0=0xb0;
ET0=1;//答应守时器0中止
TR0=1;//发动守时器0运转
EA=1;//悉数中止答应
Control_1=0;
Control_2=0;
while(1)
{
time++;
if(time》=10)
{
time=0;
//扫描键盘
if(hold==5)
{
ADC();//模数转化
compare();//转化成果比较,修正操控变量
}
else
{
Control_1=0;
Control_2=0;
}
}
if(scan_grant==0)
{
scan_key();
convert();
scan_grant=1;
EA=1;
}
hide_time++;
if(hide_time》=80)
{
hide_time=0;
if(hide_flag==1)
{hide_flag=0;}
else
{hide_flag=1;}
}
display();
}
}
//延时函数
voiddelay(ints)
{
for(i=0;i{}
}
//按键处理————————————
voidkey_mode()
{
delay(1000);
if(mode==0)
{
hold++;
if(hold》=6)
{hold=1;}
}
}
voidkey_add()//加函数
{
delay(1000);
if(add==0)
{
if(hold==0)//当时操作数[0-led1即num[0]]
{
}
if(hold==1)//当时操作数[1-led2即num[1]]
{
if(V_num《=235)
{V_num=V_num+20;}//加1V
}
if(hold==2)//当时操作数[2-led3即num[2]]
{
if(V_num《=253)
{V_num=V_num+2;}//加0.1V
}
if(hold==3)//当时操作数[3-led4即num[3]]
{
if(V_num《=254)
{V_num++;}//加0.05V
}
if(hold==4)//当时操作数[4-快速调理即V_index]
{
if(V_index《=7)
{V_index++;}
V_num=V_list[V_index];
}
if(hold==5)//当时操作数[5-无]
{
}
}
}
voidkey_sub()//减函数
{
delay(1000);
if(sub==0)
{
if(hold==0)//当时操作数[0-led1即num[0]]
{
}
if(hold==1)//当时操作数[1-led2即num[1]]
{
if(V_num》=20)
{V_num=V_num-20;}//减1V
}
if(hold==2)//当时操作数[2-led3即num[2]]
{
if(V_num》=2)
{V_num=V_num-2;}//减0.1V
}
if(hold==3)//当时操作数[3-led4即num[3]]
{
if(V_num》=1)
{V_num–;}//减0.05V
}
if(hold==4)//当时操作数[4-快速调理即V_index]
{
if(V_index》=1)
{V_index–;}
V_num=V_list[V_index];
}
if(hold==5)//当时操作数[5-无]
{
}
}
}
voidkey_confirm()
{
delay(1000);
if(confirm==0)
{
hold=5;
}
}
//————————————————————-
voiddisplay()
{
/*led_1=1;
if(num[0]==0)//假如榜首位是0的话就不显现,led[10]是空
{P0=led[10];}
else
{P0=led[num[0]];}delay(100);
led_1=0;
P0=0xFF;led_2=1;
P0=point[num[1]];
delay(100);
led_2=0;
P0=0xFF;led_3=1;
P0=led[num[2]];
delay(100);
led_3=0;
P0=0xFF;led_4=1;
P0=led[num[3]];
delay(100);
led_4=0;
P0=0xFF;*/
if(hide_flag==1)
{
if(hold==4)
{
delay(400);
return;
}
if(hold!=1)
{
led_1=1;
if(num[0]==0)//假如榜首位是0的话就不显现,led[10]是空
{P0=led[10];}
else
{P0=led[num[0]];}
delay(100);
led_1=0;
P0=0xFF;
led_2=1;
P0=point[num[1]];
delay(100);
led_2=0;
P0=0xFF;
}
if(hold!=2)
{
led_3=1;
P0=led[num[2]];
delay(100);
led_3=0;
P0=0xFF;
}
if(hold!=3)
{
led_4=1;
P0=led[num[3]];
delay(100);
led_4=0;
P0=0xFF;
}
}if(hide_flag==0)
{
led_1=1;
if(num[0]==0)//假如榜首位是0的话就不显现,led[10]是空
{P0=led[10];}
else
{P0=led[num[0]];}
delay(100);
led_1=0;
P0=0xFF;
led_2=1;
P0=point[num[1]];
delay(100);
led_2=0;
P0=0xFF;
led_3=1;
P0=led[num[2]];
delay(100);
led_3=0;
P0=0xFF;
led_4=1;
P0=led[num[3]];
delay(100);
led_4=0;
P0=0xFF;
}
}
voidADC()
{
START=0;
OE=0;
START=1;
delay(65);
START=0;
while(EOC==1)
{}
OE=1;
delay(65);
Get_data=P1;
OE=0;
//convert();
}
voidconvert()
{
//基准电压要为12.8V
/*Get_data2=Get_data*5;
num[0]=Get_data2/1000;
Get_data2=Get_data2%1000;
num[1]=Get_data2/100;
Get_data2=Get_data2%100;
num[2]=Get_data2/10;
Get_data2=Get_data2%10;
num[3]=Get_data2;*/
Get_data2=V_num*5;
//Get_data2=Get_data*5;
num[0]=Get_data2/1000;
Get_data2=Get_data2%1000;
num[1]=Get_data2/100;
Get_data2=Get_data2%100;
num[2]=Get_data2/10;
Get_data2=Get_data2%10;
num[3]=Get_data2;
}
voidscan_key()//键盘扫描后函数分配
{
if(mode==0)
key_mode();
if(add==0)
key_add();
if(sub==0)
key_sub();
if(confirm==0)
key_confirm();
}voidcompare()//比较函数(Control_1Control_2)[00-正确][11-加][10减]
{
Control_1=0;
Control_2=0;if(V_num《(Get_data-1))
{
Control_1=1;
Control_2=0;
if((Get_data-V_num)》=10)
{
Control_speed=1;
close=1;
}
else
{
Control_speed=0;
close=0;
}
}
if(V_num》(Get_data+1))
{
Control_1=1;
Control_2=1;
if((V_num-Get_data)》=10)
{
Control_speed=1;
close=1;
}
else
{
Control_speed=0;
close=0;
}
}
}
//中止函数:
//守时器中止T0用于消除按键等候
//守时器中止T1用于进入AD转化函数
//——————————————————————–
//————————-守时器中止服务程序————————-
//————————–守时器0工作方法1————————–
//使命:
//1:限制进入按键扫描程序的时刻距离,防止在短时刻内屡次进入键盘扫描而形成误操作
//——————————————————————–
voidclear_key()interrupt1using1
声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/yingyong/iot/345534.html