基于ARM/Linux的燃料電池溫度監(jiān)控系統(tǒng)GUI設(shè)計
燃料電池(fuel cell)是一種新型綠色能源技術(shù),是把燃料和氧化劑中的化學能直接轉(zhuǎn)化成電能的裝置。燃料電池與一般干電池的不同點是:只要保持燃料供應,電池就會不斷提供電能,而且電池反應的最終產(chǎn)物是水,不會對環(huán)境造成任何污染,以碳氫化合物作燃料時,反應產(chǎn)物僅增加少量二氧化碳[1]。
燃料電池電堆的溫度分布對燃料電池的安全與壽命有重要影響,尤其是在采用質(zhì)子交換膜的車用燃料電池中,溫度不僅影響到催化劑的活性,而且還直接影響到質(zhì)子交換膜的含水性,因此對其溫度的控制有很高的要求。為了在研究過程中對其溫度變化進行實時監(jiān)控,本文基于ARM/Linux構(gòu)建了一個燃料電池溫度監(jiān)控系統(tǒng)。
1 系統(tǒng)結(jié)構(gòu)
本監(jiān)控系統(tǒng)整體結(jié)構(gòu)如圖1所示。
溫控系統(tǒng)采用ARM微處理器S3C2410作為嵌入式微處理器。將經(jīng)過編譯的嵌入式Linux2.6內(nèi)核及Qt/E庫移植到ARM上,溫控系統(tǒng)的GUI控制界面運行于LCD上。
溫控器以freescale公司MC9S12DG128B單片機為控制核心,采用熱電阻作為溫度傳感器,將溫度信號轉(zhuǎn)化為模擬量的電信號,再經(jīng)過放大電路及壓頻變換(V/F變換)后,變?yōu)閿?shù)字量的電信號輸入控制器,實現(xiàn)控制算法??刂破鬏敵龅腜WM信號經(jīng)過光電隔離后直接控制固態(tài)繼電器,從而控制熱風嘴加熱器對控制對象進行加熱操作,實現(xiàn)溫度控制。
Web Server單元采用移植基于Linux的Boa服務(wù)器,通過CGI(公共網(wǎng)關(guān)接口)實現(xiàn)遠程用戶與系統(tǒng)間的交互。
數(shù)據(jù)庫單元采用SQLite數(shù)據(jù)庫,Qt為數(shù)據(jù)庫訪問提供的QtSql模塊實現(xiàn)了數(shù)據(jù)庫與Qt應用程序的無縫鏈接,同時為開發(fā)人員提供了一套與具體所用數(shù)據(jù)庫無關(guān)的調(diào)用接口。
GUI控制界面采用Qt Designer設(shè)計系統(tǒng)的控制界面,利用Qt的信號/槽(signals/slots)機制實現(xiàn)界面對下位機的控制。
2 各部分設(shè)計方法
本文重點研究監(jiān)控系統(tǒng)GUI界面、數(shù)據(jù)庫及遠程監(jiān)控的設(shè)計與開發(fā),主要詳細了介紹GUI界面、數(shù)據(jù)庫以及Web Server的設(shè)計,對于溫控器的設(shè)計本文不作重點介紹。
2.1 GUI界面及Qt程序設(shè)計
2.1.1 Qt的移植
本系統(tǒng)的構(gòu)建是通過編譯Qt4的庫到開發(fā)板來實現(xiàn)的,首先應對源碼進行配置編譯,使庫添加對底層驅(qū)動的支持。設(shè)置環(huán)境變量如下[2]:
Export PATH= /usr/local/arm/3.3.2/bin:$PATH
Export QTDIR=$PWD
Export QTEDIR=$QTDIR
Export LD_LIBRARY_PATH=$QTDIR/lib:$ LD_LIBRARY_PATH
配置Qt使其支持數(shù)據(jù)庫、網(wǎng)絡(luò)、觸摸屏等驅(qū)動,將編譯后的Qt目錄下的lib文件夾下的庫文件加入根文件系統(tǒng)。
為了方便用戶操作,本系統(tǒng)應支持中文字體顯示。為此,一方面將編譯后的Qt/Embedeed的/lib/font目錄下的字體庫文件添加到根文件系統(tǒng)中,為了節(jié)省資源,可以只選擇比較常用的一兩種字體庫;另一方面由于程序中默認的字體不支持中文,故在程序中需指定一種中文字體,方法是在程序的main函數(shù)中添加如下語句:
QTextCodec::setCodecForTr(QTextcodec::codecForName('gb18030'));
2.1.2 程序界面開發(fā)
根據(jù)功能需求分析,設(shè)計構(gòu)建了監(jiān)控系統(tǒng)的層次化GUI界面結(jié)構(gòu)圖[3],如圖2所示。
從圖2中可以看出,子菜單主要分成兩部分:一部分是溫控界面的主要控制菜單,其中主要包括溫度的設(shè)定、工作模式的設(shè)定、通信控制按鈕、和溫度顯示部分;另一部分主要完成歷史數(shù)據(jù)的顯示,通過選擇特定的通道和時間區(qū)間,可以在顯示區(qū)顯示溫度的變化曲線,為此需要在程序中構(gòu)建一個數(shù)據(jù)庫文件用來存放歷史數(shù)據(jù),這部分會在后面詳細介紹。
首先使用設(shè)計器創(chuàng)建界面的對話框,在對話框中添加組件,如:添加按鈕以調(diào)用其他類來實現(xiàn)界面的控制,添加LCDNumber控件來模擬顯示溫度,添加下拉菜單來進行不同通道的選擇等。連接組件的SIGNAL/SLOT以響應事件,修改控件屬性,合理調(diào)整布局。保存GUI界面為Temperature.ui,根據(jù)設(shè)計器保存的界面文件(ui文件)使用uic命令生成.h頭文件。
在Qt下,使用多重繼承的方式設(shè)計我們自己的界面類,這需要從標準的QTabWidget類和Qt設(shè)計器生成的界面類繼承,如圖3所示。
在界面類MytemperWid中,定義GUI界面所需要的槽函數(shù),如:定義Displaynumber()函數(shù)用于顯示接收到的數(shù)據(jù),定義Connect_serial()和Disconnect_serial()分別用于連接和斷開端口,定義CreatSqliteDB()用于創(chuàng)建數(shù)據(jù)庫等。
MytemperWid類的程序片段如下:
class MytemperWid:public QTabWidget,public Ui::Temperature
{ Q_OBJECT
public:
Mytempwid(QWidget *parent =0);
public slots:
void Displaynumber(); //接收并顯示溫度信息
void Connect_serial(); //連接端口
void Disconnect_serial(); //斷開端口
void CreatSqliteDB(); //創(chuàng)建數(shù)據(jù)口
… …
private:
… …
};
2.2 Web Server的設(shè)計
Boa是嵌入式 Web Server中的代表,對于Boa的移植非常簡單[4],配置好交叉編譯器后,編譯Boa源代碼,將生成的應用程序放入根文件系統(tǒng)的/bin目錄下,接下來完成Boa的配置。
Boa需要在/etc目錄下建立一個boa目錄,里面放入Boa的主要配置文件boa.conf。在Boa源碼目錄下已有一個示例boa.conf,可以在其基礎(chǔ)上進行修改。首先修改Group為User,修改User為boa,要根據(jù)自己開發(fā)板的情況設(shè)定,一定要是存在的用戶和組。設(shè)置ServerName可以為想要的任何名字,接下來,從Linux主機的/etc目錄下將mine.types文件復制到文件系統(tǒng)/etc目錄下。最后,創(chuàng)建日志文件所需的目錄/var/log/boa,HTML文檔的主目錄/var/www,CGI腳本所在目錄/var/www/cgi-bin。
配置工作完成以后,設(shè)定開發(fā)板的ip與主機在同一網(wǎng)段,運行boa,即可開啟boa服務(wù)器,將靜態(tài)網(wǎng)頁放入/var/www目錄下,在瀏覽器中輸入開發(fā)板ip即可看到網(wǎng)頁運行,對于動態(tài)網(wǎng)頁,要編寫相應的CGI程序,編譯后放入/var/www/cgi-bin目錄。
CGI是Web服務(wù)器與你的或其他機器上的http程序進行“交談”的一種工具,其程序需運行在網(wǎng)絡(luò)服務(wù)器上。在本設(shè)計中,ARM板通過串口與下位機進行通信,遠程PC無法直接與下位機進行通信,所以采用數(shù)據(jù)庫作為數(shù)據(jù)的中轉(zhuǎn)單元,在數(shù)據(jù)庫中建立兩個字段,一個字段用于存放數(shù)據(jù)信息,另一字段存放控制信息。如圖1系統(tǒng)的結(jié)構(gòu)圖所示,下位機的數(shù)據(jù)信息通過串口發(fā)往ARM,將這些信息在LCD上顯示,同時經(jīng)這些信息保存在數(shù)據(jù)字段中,CGI程序讀取并處理數(shù)據(jù)字段信息后,將這些信息顯示在遠程PC的瀏覽器上;另一方面,PC端的控制信息,經(jīng)CGI編碼后存放于數(shù)據(jù)庫的控制字段中,Qt程序檢查控制字段,根據(jù)這些控制信息改變程序運行狀態(tài)。
2.3 數(shù)據(jù)庫的設(shè)計
SQLite是一款輕型的數(shù)據(jù)庫,它的設(shè)計目標是嵌入式,占用資源低、能夠支持Windows/Linux/Unix等主流的操作系統(tǒng),與Mysql、PostgreSQL這兩款開源世界著名的數(shù)據(jù)庫管理系統(tǒng)相比,它的處理速度快[5]。Qt的QtSql模塊由三部分組成,分別是驅(qū)動層、SQL接口層、用戶接口層。QtSql模塊為不同層次的用戶提供了豐富的數(shù)據(jù)庫操作類。
在進行數(shù)據(jù)庫操作前,必須首先建立與數(shù)據(jù)庫的連接。QtSql模塊使用驅(qū)動插件與不同數(shù)據(jù)庫接口通信,目前Qt4支持幾乎所有主流數(shù)據(jù)庫。在配置Qt時,選擇將SQLite驅(qū)動內(nèi)置于Qt中或者編譯成插件。在使用QtSql模塊時,需要對工程進行配置:在頭文件中加入語句#include;在工程的.pro文件中加入Qt+=sql。經(jīng)配置后,在Qt應用程序中就可以連接并使用SQLite數(shù)據(jù)庫了。在Qt中建立數(shù)據(jù)庫連接的方法是:
QSqlDatabase db=QSqldatabase::addDatabase('QSQ-LITE');
根據(jù)本系統(tǒng)的要求,要監(jiān)控8個通道的溫度數(shù)據(jù),能根據(jù)這些數(shù)據(jù)繪制歷史曲線,所以數(shù)據(jù)庫要包含一個時間字段和八個溫度值字段,同時還要一個數(shù)值字段和一個控制字字段用于與遠程PC的通信,在Qt程序中可以使用如下語句建立數(shù)據(jù)庫:
QSqlQuery q;
q.exec('CREATE TABLE temperature (datetime DOUBLE,''channel1 DOUBLE,''channel2 DOUBLE,''channel3 DOUBLE,''channel4 DOUBLE,''channel5 DOUBLE,''channel6 DOUBLE,''channel7 DOUBLE,''channel8 DOUBLE,''webdate DOUBLE,''webcontrol DOUBLE)');
建立數(shù)據(jù)庫后,就可以使用INSERT、DELETE等SQL語句對數(shù)據(jù)庫進行插入、刪除等操作了。
3 運行實例
根據(jù)上文所提出的技術(shù)方案和Qt/E程序設(shè)計思想,在S3C2410ARM處理器上完成了系統(tǒng)的開發(fā),系統(tǒng)運行界面截圖如圖4所示。
選則好通道和時間區(qū)間,可以查看各通道不同時間段內(nèi)的歷史曲線圖,如圖5所示。
在開發(fā)板上運行Boa服務(wù)器,設(shè)置開發(fā)板ip為192.168.1.100,在遠程PC上打開瀏覽器,輸入“http://192.168.1.100/cgi-bin/temperature”,則可在瀏覽器上監(jiān)控系統(tǒng)運行,如圖6所示。
根據(jù)燃料電池開發(fā)過程中對溫度監(jiān)控的需要設(shè)計了實時監(jiān)控系統(tǒng)及GUI界面,本文詳細介紹了整個系統(tǒng)的結(jié)構(gòu)及系統(tǒng)各部分的開發(fā)流程,基于Qt/E類庫,設(shè)計了監(jiān)控系統(tǒng)的GUI及程序結(jié)構(gòu)。實際運行結(jié)果表明,所提出的設(shè)計方法能夠滿足應用的需要。
本設(shè)計與初步應用表明,采用Qt/Embedded作為開發(fā)圖形界面工具,利用其結(jié)構(gòu)清晰的特點和跨平臺性,能有效縮短項目的開發(fā)周期,提高程序代碼的重用率,是開發(fā)嵌入式系統(tǒng)GUI界面的有效工具。
評論