基于uCGUI的數據顯示系統
本文詳細介紹了uC/GUI在A(yíng)RM 內核S3C44B0X的移植。實(shí)踐證明uC/GUI具有良好的實(shí)時(shí)性和穩定性以及廣泛的應用前景。
本文引用地址:http://dyxdggzs.com/article/150750.htm1 硬件連接與液晶顯示原理
本設計使用的硬件采用ARM7開(kāi)發(fā)板,液晶模塊為L(cháng)78C64,它是7.8in 256色STN型LCD顯示屏,分辨率為640×480。
LCD控制器外部接口信號的定義及其與LCD模塊各信號之間的對應關(guān)系如下:
(1)VFRAME:LCD控制器與LCD驅動(dòng)器之間的幀同步信號。該信號負責指出LCD屏新的一幀開(kāi)始的時(shí)間。LCD控制器在一個(gè)完整幀顯示完成后立即插入一個(gè)VFRAME信號,并開(kāi)始新一幀的顯示。該信號與LCD模塊的YD信號相對應;
(2)VLINE:LCD控制器和LCD驅動(dòng)器之間的線(xiàn)同步脈沖信號。該信號用于將LCD驅動(dòng)器水平線(xiàn)(行)移位寄存器的內容傳送給LCD屏顯示。LCD控制器在整個(gè)水平線(xiàn)(整行)數據移入LCD控制器后,插入一個(gè)VLINE信號。該信號與LCD模塊的LP信號相對應;
(3)VCLK:LCD控制器和LCD驅動(dòng)器之間的像素時(shí)鐘信號。由LCD控制器送出的數據在VCLK的上升沿處送出,在VCLK的下降沿被LCD驅動(dòng)器采樣。該信號與LCD模塊的XCK信號相對應;
(4)VM:LCD驅動(dòng)器的AC信號。VM信號被LCD驅動(dòng)器用于改變行和列的電壓極性,從而控制像素點(diǎn)的顯示和熄滅。VM信號可以與每個(gè)幀同步,也可以與可變數量的VLINE信號同步;
(5)VD3~0 LCD:像素點(diǎn)的數據輸入端口。與LCD模塊的D3~0相對應:
(6)VD7~4 LCD:像素點(diǎn)的數據輸入端口。與LCD模塊的D7~4相對應。
液晶顯示原理:寫(xiě)滿(mǎn)整個(gè)屏的數據稱(chēng)為1個(gè)“幀”數據,YD是幀同步信號,該信號啟動(dòng)LCD屏的新一幀數據。兩個(gè)YD脈沖之間的時(shí)間長(cháng)度稱(chēng)為幀周期。根據LCD模塊的特性,刷新時(shí)間為12~14ms,頻率為70~80Hz。每一幀包括480個(gè)LP脈沖。LP為行(共480行)數據輸入鎖存信號,也就是行同步脈沖信號。該信號啟動(dòng)LCD屏的新一行數據。XCK為行數據輸入信號,也就是每1行中像素點(diǎn)數據傳輸的時(shí)鐘信號。每組8位的數據在XCK的下降沿被輸入鎖存,因此,每1行包括640×3/8個(gè)XCK脈沖信號。D0~D7是8位的顯示數據輸入信號。
2 驅動(dòng)程序設計
下面分三步完成液晶的初始化。
(1)I/O口的初始化
由于采用S3C44B0X的PC接口和PD接口作為L(cháng)CD驅動(dòng)接口,因此,需要設置PC接口工作在第3功能狀態(tài)和PD接口工作在第2功能狀態(tài)。
(2)相應控制寄存器的設置方法
S3C44B0X包括一個(gè)LCD控制器時(shí)序發(fā)生器TIMEGEN, 由它來(lái)產(chǎn)生VFRAM,VLINE,VCLK和VM 控制時(shí)序。這些控制信號由寄存器LCOCON1和LCDCON2進(jìn)行配置。通過(guò)對寄存器種配置項目的設置,TIMEGEN就可以產(chǎn)生適應于各種LCD屏的控制信號了。
VFRAM 和VLINE脈沖的產(chǎn)生是通過(guò)對LCDCON2寄存器的HOZVAL和LINEVAL進(jìn)行配置來(lái)完成的。每個(gè)域都與LCD的尺寸和顯示模式有關(guān)。
其中,HOZVAL=(顯示寬度/VD數據線(xiàn)位數)-1。
在彩色模式下,顯示寬度=3×每行的像素點(diǎn)數。
對所選的液晶模塊,HOZVAL=(640×3/8)-1;LINEVAL=(顯示寬度)-1。
對所選的液晶模塊,LlNEVAL=480-1。
VCLK信號的頻率可以通過(guò)LCDCON1寄存器的CLKVAL域來(lái)確定,即
VCLK=MCLK/(CLKVAL×2)
LCD控制器的最大VCLK頻率為16.5MHz,幾乎支持所有已有的LCD驅動(dòng)器。由于上述關(guān)系,CLKVAL的值決定了VCLK的頻率。為了確定CLKVAL的值,應該計算一下LCD控制器向VD端口傳輸數據的速率,以便使VCLK的值大于數據傳輸的速率。
數據傳輸速率的公式為:
數據傳輸速率=HS×VS×FR×MV
其中,HS—LCD的行像素值;VS—LCD的列像素值:FR—幀速率;MV—模式值,這里取8位單掃描,彩色。
對于所選用的液晶模塊:HS=640;VS=480;FR=70Hz:MV=3/8。因此,數據傳輸速率=640×480×70×3/8=8,064,000Hz。
VCLK值應該大于8MHz而小于16MHz,因此,CLKVAL可以取9~15。
評論