|
本人是單片機小白,來學(xué)習(xí)的新人,還望大家多多照顧?quán)?img src="static/image/smiley/default/em50.gif" smilieid="50" border="0" alt="" />
前段時間去大姐夫家玩,發(fā)現(xiàn)大姐夫有很多l(xiāng)suc這種超級電容,非常適合做儲能式點焊機,而且現(xiàn)在點焊18650等電池也越來越多,于是便親自操刀做一個玩玩!
設(shè)計三層電路板,模塊化設(shè)計,最底層是固定超級電容的均衡電路板,中間層是mos管矩陣電路板,最上邊是單片機控制電路板
下圖是用TL431做的均衡充電板,LSUC超級電容耐壓2.8v容量3000F,均衡起控電壓2.78v 均衡電流800mA
熱轉(zhuǎn)印pc為了降低內(nèi)阻特意買了銅排進(jìn)行關(guān)鍵部位連均衡和mos矩陣板放在一起試一下
打孔加工
安裝上一個,感覺很漂亮啊
裝好的mos管矩陣電路板
組裝在一起看下效果,感覺還是很漂亮的
接下來進(jìn)入正題,進(jìn)行時間控制板的程序設(shè)計和pcb設(shè)計
單片機源程序如下:
#include "reg51.h" //此文件中定義了單片機的一些特殊功能寄存器
typedef unsigned int u16;//對數(shù)據(jù)類型進(jìn)行聲明定義
typedef unsigned char u8;//對數(shù)據(jù)類型進(jìn)行聲明定義
sbit P30=P1^0; //數(shù)碼管第1位
sbit P31=P1^1; //數(shù)碼管第2位
sbit k1=P1^6; //將單片機的P3.2端口定義為時間加
sbit k2=P1^5; //將單片機的P3.3端口定義為時間減
sbit k3=P1^7; //將單片機的P3.4端口定義為檢測點焊筆
sbit out=P1^4; //驅(qū)動脈沖輸出
//數(shù)碼管真值表//
u8 code LED_CODE[]={0x03,0x9f,0x25,0x0d,0x99,0x49,0x41,0x1f,0x01,0x09}; //顯示0~F的段碼
u16 Cntms1=0,Cntms2=0,num1,num2;ke;
u8 num; //定時變量=毫秒
void Delay(unsigned long int t)
{
while(--t);
}
/*===加按鍵檢測===*/
/*當(dāng)此函數(shù)檢測到有效按鍵時返回1,沒有檢測到有效值時返回0*/
bit skey0(void)
{
static unsigned char a = 0;
if(k1 == 0) //如果檢測到按鍵引腳有低電平,記數(shù)變量開始累加.
{
if(a < 50) //控制延時計數(shù)返0,因為當(dāng)按鍵不松開時,j一直在累加
a++; //CPU每檢測到一次按鍵引腳為低電平0,j就累加1次.
}
else //如果按鍵沒有按下或者按下后有高電平(抖動)j清0
a = 0;
if(a == 49) //如果變量j的值累加到49,說明按鍵已跨過抖動區(qū).
return 1; //返回1,說明已檢測到按鍵有效值.
else
return 0; //返回0,說明沒有檢測到有效值.
}
/*===減按鍵檢測===*/
/*當(dāng)此函數(shù)檢測到有效按鍵時返回1,沒有檢測到有效值時返回0*/
bit skey1(void)
{
static unsigned char i = 0; //定義靜態(tài)變量,用來記錄延時用.
if(k2 == 0) //如果檢測到按鍵引腳有低電平,記數(shù)變量開始累加.
{
if(i < 50) //控制延時計數(shù)返0,因為當(dāng)按鍵不松開時,i一直在累加.
i++; //CPU每檢測到一次按鍵引腳為低電平0,i就累加1次.
}
else //如果按鍵沒有按下或者按下后有高電平(抖動)i清0
i = 0;
if(i == 49) //如果變量i的值累加到49,說明按鍵已跨過抖動區(qū)
return 1; //返回1,說明已檢測到按鍵有效值.
else
return 0; //返回0,說明沒有檢測到有效值.
}
bit skey2(void)
{
static unsigned int l = 0; //定義靜態(tài)變量,用來記錄延時用. unsigned long int
if(k3 == 0) //如果檢測到按鍵引腳有低電平,記數(shù)變量開始累加.
{
if(l <5000) //控制延時計數(shù)返0,因為當(dāng)按鍵不松開時,i一直在累加
l++; //CPU每檢測到一次按鍵引腳為低電平0,i就累加1次.
}
else //如果按鍵沒有按下或者按下后有高電平(抖動)i清0
l = 0;
if(l == 4999) //如果變量i的值累加到4999,說明點焊筆已經(jīng)做好準(zhǔn)備,可以焊接了.
return 1; //返回1,說明已檢測到按鍵有效值.
else
return 0; //返回0,說明沒有檢測到有效值.
}
/********************************
數(shù)碼管動態(tài)顯示程序
********************************/
void display()
{
static u8 i=0;
if(i==0)
{
P30=1;
P31=0;
P3=LED_CODE[num/10];
for(ke = 0;ke <100;ke++); //延時一段時間
P31=1;
P3=0Xff;
i=1;
}
else
{
P31=1;
P30=0;
P3=LED_CODE[num%10];
for(ke = 0;ke <100;ke++); //延時一段時間
P30=1;
P3=0Xff; //消隱
i=0;
}
}
//主函數(shù)//
void main()
{
bit m = 0,m1 = 0,m2=0; //聲明一個位變量.用來存儲按鍵狀態(tài).
unsigned char i;
out=1; //初始化輸出端口
num=40;//定時變量賦初值
k1 = 1; //加按鍵輸入端口電平置高
k2 = 1; //減按鍵輸入端口電平置高
k3 = 1;
while(1) //主循環(huán)
{
m = skey0(); //采集加按鍵
m1 = skey1(); //采集減按鍵
m2 = skey2(); //采集按鍵
if(m == 1) //如果采集到加按鍵值.
{
if(num < 99)
num++; //計數(shù)自增
}
if(m1 == 1) //如果采集到減按鍵值.
{
if(num >1)
num--; //計數(shù)自減
}
if(m2 == 1)
{ for(i=0;i<2;i++) //加入 for循環(huán),表明for循環(huán)大括號中的程序循環(huán)執(zhí)行2次
{
out=0; //將P1.0口賦值 0,對外輸出低電平
Delay(num*50); //調(diào)用延時程序;更改延時數(shù)字可以更改延時長度;用于改變輸出脈沖時間
out=1; //將P1.0口賦值 1,對外輸出高電平
Delay(3000);
}
}
display();//數(shù)碼管動態(tài)顯示
}
}
程序及引腳定義完,接下來設(shè)計pcb
第一次使用綠油技術(shù)
接下來下載程序,調(diào)試一下
至此大功告成
測試一下點焊效果
用力
焊的還是很牢固
感謝大家觀看!
|
評分
-
查看全部評分
|