新聞中心

EEPW首頁 > EDA/PCB > 設(shè)計(jì)應(yīng)用 > 基于FPGA的真彩VGA顯示的實(shí)現(xiàn)

基于FPGA的真彩VGA顯示的實(shí)現(xiàn)

作者: 時(shí)間:2012-03-12 來源:網(wǎng)絡(luò) 收藏

Mif文件在中的應(yīng)用,主要是在RAM,ROM中,一般用來存儲(chǔ)字模、波形數(shù)據(jù)、信號采樣、數(shù)據(jù)序列等,可以看做是C語言中的數(shù)組,用來存儲(chǔ)數(shù)據(jù)。Bingo當(dāng)年也是郁悶的很啊,當(dāng)年做電子琴,在Quartus II Memory Initialzation File 也手動(dòng)寫過曲譜的mif文件。眼睛都花了;曾經(jīng)做過波形發(fā)生器,有康芯的Guagle的支持,很方便;對于字符圖片顯示,字模數(shù)據(jù)的龐大,Bingo最后通過C語言,根據(jù)mif格式,設(shè)計(jì)了軟件,今天定格。

本文引用地址:http://butianyuan.cn/article/190667.htm

一、講真彩顯示的理由:

畢竟這是電腦的液晶,為啥我們就不能做的想電腦一樣顯示彩色的圖片呢?只是單純的顯示線條,字符,感覺還是在玩LCD1602、LCD12864似地,不爽,不爽,灰常的不爽。那么大的,不做點(diǎn)像樣的東西,還真的很不甘心。

視覺的沖擊,真彩的誘惑,內(nèi)心的萌動(dòng),如果你是個(gè)不愿意放棄的人,沒做到真彩顯示,我想,你應(yīng)該不會(huì)那么踏實(shí);如果你是一個(gè)對視覺有沖動(dòng)的人,單調(diào)的驅(qū)動(dòng),決不會(huì)甘心。Bingo當(dāng)年就是很不爽,為了那一刻,走一步,再走一步,潛行了很久,終于在某年某月某一天,視覺暫留于熒光屏,彩色的誘惑,阻隔了前面的世界,歷史從此定格。

本章將講述VGA真彩顯示的設(shè)計(jì),通過硬件設(shè)計(jì),軟件設(shè)計(jì),以及各種不同的方案來講解,同時(shí)通過對Bingo設(shè)計(jì)的真彩顯示的一個(gè)工程稍做分析;最后展望未來,繼續(xù)走下一步,視覺暫留的我們不能就此停下腳步,,風(fēng)雨兼程決不放棄,接下來要做的將會(huì)更多更多,其實(shí)這才是真正的開始。

二、真彩顯示的要求

1、數(shù)據(jù)的流通

要想在VGA上顯示一張彩色的圖片,就必須有充足的條件。簡單的說,那就必須要有圖片數(shù)據(jù)源、要能實(shí)現(xiàn)數(shù)據(jù)緩存,最后以標(biāo)準(zhǔn)的時(shí)序給VGA刷屏。整體流程如下圖所示:

55.gif

(1)外部數(shù)據(jù)源,由CPU捕獲

(2)由CPU捕獲的數(shù)據(jù),緩存與SRAM或者SDRAM等顯存

(3)由CPU控制VGA狀態(tài),以固定的時(shí)序給VGA刷屏

關(guān)于標(biāo)準(zhǔn)時(shí)序給VGA刷屏也就是以上的(3),Bingo在前面兩張已經(jīng)講的非常清楚,掌握的朋友應(yīng)該可以應(yīng)用自如了。前文中VGA的驅(qū)動(dòng)沒有數(shù)據(jù)源(暫且認(rèn)為Mif文件的數(shù)據(jù)屬于邏輯電路的描述),我們只是用FPAG邏輯描述的電路,給VGA固定坐標(biāo)顯示固定的內(nèi)容。因此,這一章的關(guān)鍵是將VGA刷屏的數(shù)據(jù)源,以及數(shù)據(jù)緩存處理,Bingo通過分析數(shù)據(jù)流通渠道來分析VGA真彩圖像顯示的技術(shù)。

2、色彩的識別

關(guān)于圖像的格式,有JPEG、BMP、PNG等多種格式;圖像的位數(shù),也有單色、4灰、256色、4096色、16位真彩色、24位真彩色、32位真彩色這幾種。

有一種方法是直接通過讀取存放于SD卡、U盤等移動(dòng)數(shù)據(jù)的圖片,通過圖片解碼來得到圖像數(shù)據(jù),真彩顯示。并行數(shù)據(jù)輸出,經(jīng)過數(shù)模轉(zhuǎn)換(電阻網(wǎng)絡(luò)轉(zhuǎn)換或者視頻轉(zhuǎn)換芯片),得到16位以上的VGA數(shù)據(jù)。人眼不能分辨的極限,至少也需要16位真彩色。16位以上的數(shù)據(jù),24位、32位,人眼基本無法分辨清楚,因此,要求不是很高的情況下16位真彩色已經(jīng)足夠勝任。

前面講過的VGA驅(qū)動(dòng),最基本的分辨率有如下三種:

(1)VGA_640_480_60FPS_25MHz

(2)VGA_800_600_72FPS_50MHz

(3)VGA_1024_768_60FPS_65MHz

可見,至少25MHz的速度刷屏,需要我們在軟件中實(shí)現(xiàn)顯卡刷屏的功能;在最小圖片容量即(1)模式下的數(shù)據(jù)量是640*480*16 = 4915200Bits = 600KB,在(3)模式下的數(shù)據(jù)量是1024*768*16 = 1.5MB。如此大的圖片數(shù)據(jù),需要有如此容量的緩存區(qū)。

綜上,也就是說,要實(shí)現(xiàn)真彩圖像VGA顯示,第一需要16位以上的VGA驅(qū)動(dòng)電路,第二需要足夠的容量來存放圖片。

三、各種方案的匯總

1. 靜態(tài)數(shù)據(jù)源

所謂靜態(tài)數(shù)據(jù)源,就是數(shù)據(jù)已經(jīng)保存在系統(tǒng)中,不能再改變的的數(shù)據(jù)源。為了顯示真彩圖像,我們可以將圖像數(shù)據(jù)存放于SDRAM,或者Flash,從而通過讀取IC上已經(jīng)存儲(chǔ)的圖像數(shù)據(jù),顯存于SRAM,利用前面Bingo設(shè)計(jì)的VGA可移植模塊驅(qū)動(dòng)刷屏,實(shí)現(xiàn)真彩圖像的顯示。基本的架構(gòu)就是:

+ 靜態(tài)數(shù)據(jù)源 + SDRAM/SRAM + VGA

當(dāng)然此處數(shù)據(jù)存放于SDRAM,我們可以用Nios II 的C存放于數(shù)組,通過JTAG下載;FLASH中的數(shù)據(jù),我們可以用Nios II 中的 Flash Programmer來完成配置。關(guān)于SDRAM中存放圖像數(shù)據(jù)來實(shí)現(xiàn)真彩圖像時(shí)最基本最簡單的方法,Bingo將會(huì)在后文講解。


上一頁 1 2 3 4 下一頁

關(guān)鍵詞: FPGA VGA

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉