如何設(shè)計(jì)及實(shí)現(xiàn)基于ARM9的彩色TFT-LCD模塊?
以基于離散余弦變換的順序編碼方式來(lái)說(shuō)明JPEG圖像解碼的過(guò)程。圖像解碼是壓縮編碼的反過(guò)程,解碼的碼流起始位置標(biāo)志信息,解碼器根據(jù)JPEG壓縮圖像的文件頭信息,得到原始圖像的基本信息。得到原始圖像信息后,解碼器根據(jù)JPEG文件中的霍夫曼表進(jìn)行解碼。由于熵編碼過(guò)程中使用霍夫曼編碼分別對(duì)DC及AC系數(shù)進(jìn)行編碼,其中系數(shù)編碼的順序采用zig-zag序列,因此實(shí)現(xiàn)解碼時(shí)需要考慮這些相關(guān)實(shí)現(xiàn)過(guò)程,詳細(xì)信息請(qǐng)參考相關(guān)文獻(xiàn)[5]。根據(jù)量化系數(shù)表,經(jīng)霍夫曼解碼后的系數(shù)與相應(yīng)的量化值進(jìn)行乘積,然后進(jìn)行反余弦變換。需要注意的是,JPEG 圖像使用的是YCrCb模型,其中Y 是亮度分量,Cr及Cb是色度分量,需要將系數(shù)的色彩空間從YCrCb轉(zhuǎn)換到RGB空間,最終得到圖像的R、G、B 數(shù)據(jù)值,這些數(shù)據(jù)才可以在液晶顯示屏上顯示。
根據(jù)JPEG 文件交換格式提供的資料文獻(xiàn)[6],YCrCb色彩空間到RGB色彩空間的轉(zhuǎn)換見(jiàn)公式(1)。
考慮到延時(shí)應(yīng)盡量小,程序在NOR Flash存儲(chǔ)器上執(zhí)行效率低。圖像解碼算法中應(yīng)合理安排在ARM9中的內(nèi)存分配。設(shè)計(jì)過(guò)程中將頻繁訪問(wèn)的程序代碼及數(shù)據(jù)搬運(yùn)到ARM9內(nèi)部高速緩沖存儲(chǔ)器中,從而提高編碼的效率。由于順序編碼方式最常用,它通常稱(chēng)為JPEG 基本系統(tǒng)(BaseLine)。設(shè)計(jì)過(guò)程中,實(shí)現(xiàn)的JPEG 圖像解碼支持順序編碼,完全可以滿足應(yīng)用要求。
2.2 TFT-LCD LQ080V3DG01
實(shí)驗(yàn)中選用LQ080V3DG01彩色液晶顯示模塊測(cè)試設(shè)計(jì)效果。LQ080V3DG01 由彩色TFT-LCD面板、驅(qū)動(dòng)電路、控制電路、供電電路及背光單元組成。它支持最大分辨率為640×480的圖形和文字顯示,數(shù)據(jù)輸入格式為18bit,其中紅綠藍(lán)各占6bit,提供的顏色共262 144種。
TFT-LCD需要+3。3V或+5V供電電壓,背光需要交流電源供電。輸入的控制信號(hào)有4個(gè):幀同步信號(hào)VSYNC、行同步信號(hào)HSYNC、數(shù)據(jù)使能信號(hào)ENAB及時(shí)鐘信號(hào)CK。數(shù)據(jù)線寬度是18bit,紅綠藍(lán)各占6bit,分別是R [0∶5]、G [0∶5]及B [0∶5],顏色配置信息如表1所示。
表1 輸入數(shù)據(jù)信號(hào)及顏色顯示配置
LQ080V3DG01液晶顯示屏的數(shù)據(jù)線共18bit,對(duì)于24bit的彩色圖像以及24bit的ARM9S3C2440X的TFT-LCD控制器而言,其接口并不兼容。設(shè)計(jì)中為了適應(yīng)LQ080V3DG01液晶顯示屏的接口,分別舍棄了8bit R、G、B 值的低2位,測(cè)試結(jié)果顯示效果良好。如果選用的TFTLCD是24bit數(shù)據(jù)線,則可以直接連接到LCD控制器相應(yīng)的數(shù)據(jù)線。
3 模塊設(shè)計(jì)方案的實(shí)現(xiàn)
3.1 工作流程
在ARM9執(zhí)行初始化后,主程序就等待外部模塊通過(guò)串口發(fā)送指令。外接模塊通過(guò)RS232串口與本模塊通信,根據(jù)通信協(xié)議發(fā)送不同的指令,實(shí)現(xiàn)相應(yīng)的功能。在約定的串口波特率下,通信協(xié)議如下:顯示圖像時(shí)首先發(fā)送指令0x55,然后再發(fā)送圖像在圖像庫(kù)中的編號(hào);顯示字符時(shí)首先發(fā)送指令0x56,然后再發(fā)送字符在字符庫(kù)中的編號(hào),最后發(fā)送字符在液晶屏上顯示的橫軸及縱軸坐標(biāo)。需要說(shuō)明的是,在NAND Flash存儲(chǔ)空間中的圖像庫(kù)及字符庫(kù)是自己定義的,可以重新下載更新。軟件流程圖如圖3示。
圖3 軟件流程圖
3.2 彩色圖像顯示
所設(shè)計(jì)的模塊支持24bit彩色RGB及JPEG兩種格式的圖像顯示。因?yàn)橄袼財(cái)?shù)據(jù)可以直接送到液晶接口控制模塊顯示,而JPEG格式的圖像則必須經(jīng)過(guò)解碼之后才能顯示,所以圖像在顯示前,需要先判斷圖像數(shù)據(jù)是什么格式。如果圖像數(shù)據(jù)是JPEG格式,則必須經(jīng)過(guò)圖像解碼,解碼后得到原始彩色圖像的像素?cái)?shù)據(jù)值R、G、B,這些數(shù)據(jù)經(jīng)過(guò)顯示控制單元送到液晶屏顯示。如果圖像是原始圖像的數(shù)據(jù),則可以直接送到液晶控制模塊進(jìn)行顯示。
由于要顯示的圖像存儲(chǔ)在NAND Flash的圖像庫(kù)存儲(chǔ)空間,所以在將彩色圖像輸出到TFT-LCD顯示時(shí),首先要將需要顯示的圖像數(shù)據(jù)從NAND Flash中讀取出來(lái),得到一幅24bit彩色圖像的完整原始圖像數(shù)據(jù)。原始圖像數(shù)據(jù)中,一個(gè)像素占用3byte,其中R、G、B 各占1byte。將數(shù)據(jù)輸出給TFT-LCD 顯示前,需要根據(jù)LCD接收的數(shù)據(jù)格式將圖像數(shù)據(jù)進(jìn)行轉(zhuǎn)換,然后才能輸出顯示,圖像數(shù)據(jù)按照從上到下,自左向右的順序輸出[9]。同樣,將TFT-LCD按照相同的順序進(jìn)行掃描,最終完成整幅圖像的顯示。
NAND Flash存儲(chǔ)著大量的圖像數(shù)據(jù),為了區(qū)分不同的圖像數(shù)據(jù),將相應(yīng)的圖像輸出顯示,模塊采用RS232串口與外界通信。通過(guò)發(fā)送不同的指令,可以將在NAND Flash上存儲(chǔ)的相應(yīng)圖像讀取出來(lái),輸出在TFT-LCD上,最終實(shí)現(xiàn)各種彩色圖像的顯示。
3.3 字符顯示
字符采用16×16點(diǎn)陣,由于每個(gè)像素占用3byte,所以每個(gè)字符占用768byte??梢詫⒊S米址鎯?chǔ)在NAND Flash中,作為字符庫(kù)使用,需要時(shí)調(diào)用即可。當(dāng)顯示字符時(shí),首先要確認(rèn)相應(yīng)字符在存儲(chǔ)器中的位置,然后根據(jù)地址信息對(duì)相應(yīng)字符進(jìn)行操作,最后根據(jù)字符要顯示的位置在液晶屏上輸出,實(shí)現(xiàn)字符在液晶屏上的顯示。
實(shí)驗(yàn)過(guò)程中為字符庫(kù)分配8Mbyte空間,可以存儲(chǔ)10 922個(gè)字符。字符庫(kù)還可以實(shí)現(xiàn)更新,只需將存儲(chǔ)器NAND Flash對(duì)應(yīng)地址空間的內(nèi)容替換即可。
4 實(shí)驗(yàn)結(jié)果
為了測(cè)試模塊的正確性,將一幅分辨率為640×480的圖像AutumnLeaves下載到NANDFlash存儲(chǔ)器中,它在圖像庫(kù)中的編號(hào)為0x01。
根據(jù)串口通信協(xié)議,向液晶顯示模塊發(fā)送指令0x55,然后再發(fā)送圖像在圖像庫(kù)中的編號(hào)0x01。
顯示模塊接收到指令后,液晶屏顯示效果如圖4所示。測(cè)試結(jié)果表明,模塊工作正常,發(fā)送顯示其他圖像及字符的指令同樣效果良好,運(yùn)行可靠,達(dá)到了模塊方案設(shè)計(jì)要求。
評(píng)論