基于VB和Access的溫度采集系統(tǒng)的設計與實現(xiàn)
摘要:隨著現(xiàn)代信息技術的高速發(fā)展,數(shù)據(jù)采集方面的技術也在不斷地向前發(fā)展,并在信息技術中占有重要地位,溫度、壓力等參數(shù)在智能家居、工業(yè)控制、智能農業(yè)等方面都得到很高的重視,如何實時直觀地采集到溫度成為焦點。本溫度采集系統(tǒng)下位機采用STC89C52單片機為主控制器,采用單線式DS18B20溫度傳感器采集溫度,通過串口RS232將其傳送到上位機(PC機),上位機使用VB編寫界面和后臺處理程序,將溫度顯示出來并存入Access數(shù)據(jù)庫。最終測試結果顯示上位機有實時接收數(shù)據(jù),并將實時接收到的數(shù)據(jù)存入Access數(shù)據(jù)庫里,并能夠實時的把溫度曲線顯示到界面上。
關鍵詞:溫度采集;下位機;上位機;Access
隨著現(xiàn)代信息技術的高速發(fā)展,數(shù)據(jù)采集方面的技術也在不斷地向前發(fā)展,并在信息技術中占有重要地位,是否及時準確采集數(shù)據(jù)以及數(shù)據(jù)是何方式采集都成為關注的焦點。隨著嵌入式技術的不斷發(fā)展,各種數(shù)據(jù)采集系統(tǒng)不斷應用于各個領域。溫度采集在智能家居、工業(yè)控制、智能農業(yè)等方面都應用。本溫度采集系統(tǒng)下位機采用STC89C52單片機為主控制器,采用DS18B20溫度傳感器采集溫度,上位機使用VB編寫程序,通過串口采集數(shù)據(jù),存入Access數(shù)據(jù)庫,并實時在界面上顯示溫度變化曲線。
1 系統(tǒng)的整體設計
本溫度采集系統(tǒng)的總體框圖如圖1所示,系統(tǒng)下位機即單片機系統(tǒng)采用的是現(xiàn)成的開發(fā)板,開發(fā)板上自帶了DS18B20的溫度傳感器,開發(fā)板也自帶了能夠維持單片機正常工作的外圍電路;上位機用的Microsoft Visual Basic 6.0中文版集成開發(fā)環(huán)境和Microsoft Office Access 2003數(shù)據(jù)庫開發(fā)軟件。
2 上位機的設計與實現(xiàn)
上位機設計的主要重難點在于串口從下位機接收到數(shù)據(jù)和把數(shù)據(jù)送到數(shù)據(jù)庫里并把數(shù)據(jù)實時用曲線顯示出來。上位機總體設計流程圖如圖2所示。
從串口接收數(shù)據(jù)主要采用Mscomm32.ocx控件,在Microsoft Visual Basic 6.0中添加該控件,需要設置COM口(可修改)、波特率(9600)、數(shù)據(jù)位(8)、停止位(1)、校驗位(0)等,通過OnComm()事件驅動方式接收數(shù)據(jù)。
數(shù)據(jù)庫采用的是Microsoft Office Access 2003,先要建立數(shù)據(jù)庫,建立的數(shù)據(jù)庫如圖3所示,有4個字段,分別是編號、溫度、采集日期、采集時間,數(shù)據(jù)類型對應的為自動編號、數(shù)字、文本、文本。
在Microsoft Visual Basic 6.0中編程對數(shù)據(jù)庫Access進行操作,首先連接數(shù)據(jù)源,然后打開數(shù)據(jù)庫并設置相應的數(shù)據(jù)操作,接著更新數(shù)據(jù)庫,最后關閉數(shù)據(jù)庫,在實際的操作中通過控件Adodc與控件Datagrid連接,以實現(xiàn)數(shù)據(jù)源與界面顯示相聯(lián)系。
2.1 主要設計步驟
1)先在VB開發(fā)環(huán)境下新建一個EXE工程,然后再在窗體上安放一些必須的控件,如按鈕(Command)控件、文本框(Textbox)等;
2)在添加部件里添加Microsoft conmm control 6.0、Microsoft datagrid control 6.0和Microsoft ADO data control 6.0在這3個控件;
3)在數(shù)據(jù)庫軟件中新建數(shù)據(jù)庫,并新建一個表temp;
4)連接數(shù)據(jù)庫Access,并測試是否連接成功;
5)通過Adodc與Datagrid連接起來,實現(xiàn)數(shù)據(jù)源與界面顯示聯(lián)系起來;
6)通過Command按鈕與數(shù)據(jù)庫的查找、刪除、修改和添加聯(lián)系起來,能夠實現(xiàn)相應的功能;
7)通過picturebox控件實現(xiàn)繪圖的功能;
8)使串口數(shù)據(jù)與數(shù)據(jù)庫和picturebox控件連接起來。
2.2 上位機程序設計(程序段)
2.2.1 串口處理程序
2.2.2 將數(shù)據(jù)寫到數(shù)據(jù)庫中
3 下位機的設計與實現(xiàn)
3.1 下位機硬件以及原理
溫度采集系統(tǒng)下位機采用STC89C52單片機為主控制器,采用DS18B20溫度傳感器采集溫度,硬件電路圖如圖4所示。
STC89C52單片機具有:
1)它是MCS-51系列單片機的派生產品,在指令系統(tǒng)、硬件結構和片內資源上與標準8052單片機完全兼容,DIP40封裝系列與8051兼容均為Pin-to-Pin,使用時容易掌握;
2)高速(最高時鐘頻率90 MHz)、低功耗、價格低、穩(wěn)定可靠、應用廣泛、通用性強,在系統(tǒng)/在應用可編程(ISP,IAP),不占用戶資源。本系統(tǒng)利用STC89C52單片機的1個中斷,2個定時器以及P0~P3 4個端口。采用外部11.059 2 MHz晶振,并使用30 pF的電容接地,以提高系統(tǒng)的穩(wěn)定性和可靠性。
DS18B20具有:1)只要求一個I/O口即可實現(xiàn)通信;2)在DS18B20中的每個器件上都有獨一無二的序列號;3)實際應用中不需要外部任何元器件即可實現(xiàn)測溫;4)測量溫度范圍在-55~125℃之間;5)數(shù)字溫度計的分辨率用戶可以從9位到12位選擇;6)內部有溫度上、下限告警設置。
DS18B20的使用方法:DS18B20采用的是1—Wire總線協(xié)議方式,而對單片機STC89C52來說,我們必須采用軟件的方法來模擬單總線的協(xié)議時序來完成對DS18B20芯片的訪問。由于DS18B20是在一根I/O線上讀寫數(shù)據(jù),因此,對讀寫的數(shù)據(jù)位有著嚴格的時序要求。DS18B20有嚴格的通信協(xié)議來保證各位數(shù)據(jù)傳輸?shù)恼_性和完整性。該協(xié)議定義了幾種信號的時序:初始化時序、讀時序、寫時序。所有時序都是將主機作為主設備,單總線器件作為從設備。而每一次命令和數(shù)據(jù)的傳輸都是從主機主動啟動寫時序開始,如果要求單總線器件回送數(shù)據(jù),在進行寫命令后,主機需啟動讀時序完成數(shù)據(jù)接收。數(shù)據(jù)和命令的傳輸都是低位在先。
3.2 軟件設計
軟件設計重點是把溫度采集回來并正確的采集回來的溫度通過串口發(fā)送出去,軟件設計流程圖如圖5所示。
軟件開始初始化各種端口以及定時器、串口等,在判斷是否有中斷產生,如果接收到X,則開始發(fā)送數(shù)據(jù),如果接收到字符S,則停止發(fā)送數(shù)據(jù),否則判斷是否到達0.5 s的間隔,如果達到,開始采集溫度并將數(shù)據(jù)發(fā)送出去,否則繼續(xù)判斷是否有中斷產生。
4 測試結果
圖6為本溫度采集系統(tǒng)的實際運行的效果圖。
5 結論與前景
本溫度采集系統(tǒng)通過單片機能夠采集到DS18B20溫度傳感器采集到的數(shù)據(jù),并用串口實時的傳送到上位機;上位機有實時接收數(shù)據(jù)的能力,并將實時接收到的數(shù)據(jù)存入Access數(shù)據(jù)庫里;能夠實時地把溫度曲線顯示到界面上;數(shù)據(jù)庫具有編號、日期、時間以及溫度4個屬性;數(shù)據(jù)庫具有查找、修改、刪除、添加以及查找首記錄、下一條記錄、上一條記錄和末記錄的功能;能夠記錄開始時間、結束時間和時間差;顯示當前時間和日期。