利用單片機C8051F023作為128×64單色OLED的控制核心器件,采用的是維信諾公司的一款屏VGG12864G,它利用Solomon公司的SSD1303為專用驅動IC。實現文字顯示及圖像的動靜態顯示。硬件整體設計結構框圖如圖1所示
圖 1 硬件設計結構框圖
1 、SSD1303 驅動及接口電路
VGG12864G模塊的OLED顯示屏為128列,64行結構。圖2為SSD1303結構框圖,顯示了模塊邏輯電路和接口電路的框圖。用戶只需要給接口提供電源、產生驅動指令信號和顯示數據信號,就能點亮OLED屏。從圖中可以看出,行、列驅動器的輸出通過FPC邦定到 OLED屏,剩下的MCU接口、電壓和電流控制器需要是其專門設計的接口和驅動電路,模塊的外部信號僅與SSD1303發生關系。所以了解了 SSD1303的輸入特性及指令系統,就能方便地使用本模塊了。
SSD1303是晶門公司推出的驅動單色OLED的IC,采用TAB封裝。這種基于CMOS工藝的驅動IC集成了行、列驅動器、振蕩器、對比度控制器和圖形數據存儲器(GDDRAM),很大程度地減少了外圍器件和功耗。可支持的最大分辨率為132×64,其中OLED屏底部132×16的點陣區域可以顯示4色的局域色,并可編程實現64 級灰度,當用于單色顯示時,可編程控制256級對比度。根據所使用微處理器(MPU)的不同,它提供8位6800系列MPU并行、8位8080系列MPU并行和Serial Peripheral InteRFace (SPI)串行
三種通信接口模式。
控制命令通過MCU接口輸入到控制命令解碼器進行命令解碼,然后輸出時鐘、行同步、場同步信號,從而控制OLED顯示的振蕩頻率、顯示器件的電壓轉換模塊以及OLED顯示內容的行列偏移量的驅動模塊;如果是顯示數據(128×64bits),那么顯示數據由控制電路通過MCU接口輸入到 GDDRAM緩存,然后通過局域色解碼器對數據進行解碼,最后將解碼后的顯示數據通過行列驅動器驅動OLED顯示,OLED上呈現了穩定的顯示效果。
2 、電源的設計
硬件結構設計框圖如圖2所示,外部硬件電路的DC-DC轉換器用TPS7333芯片將5V電源轉換成3.3V電源,并將輸出的電源信號通過電壓和電流控制器控制整個SSD1303的電壓和電流。整個系統需要3.3V和12V的電源,MCU(本文采用 C8051F023)需要提供3.3V的電源電壓,OLED需要3.3V的邏輯電源電壓和9~12V的驅動電源電壓,此驅動電源電壓由外部電源轉換器電路提供。
3、 各種控制信號
再就是關于如何用MCU控制,MCU通過RES#、CS#、D/C、WR#、RD#和D0~D7共13個接口控制SSD1303驅動IC,從而控制OLED顯示屏。CS#為片選信號,當CS#接低電平時MCU才能與驅動IC通信;RES#是復位使能端,當接低電平時,所有控制寄存器均被設定為出廠時的默認狀態,同時圖像寄存器清零;D/C為數據/命令選擇信號;WR#和RD#分別為寫和讀選擇信號,當CS#為低時,在其下降沿讀寫有效。通過改變 D/C、WR#和RD#三個接口的高低,單片機對OLED的控制有四種狀態,可由表1顯示出來。
4 讀寫的時序
只要按照VGG12864G的時序波形圖進行讀和寫,即可完成OLED的顯示。但是,通過軟件編程拼時序的話,要考慮到許多時間參數,有一定的難度。為了使得數據和命令能夠更容易的順利讀寫,我們采用另外一種辦法。如圖1所示,將WR#和RD#分別接C8051F023的/WR和/RD,即 P0.7和P0.6。在C語言編程時定義指針類型為xdata型,它是指向片外存儲器的,通過給指針的賦值訪問片外的數據存儲區,當訪問片外存儲器時,/RD和/WR會在讀和寫時自動變低,同時P3端口為數據總線,非復用方式下,地址總線的高8位使用P1口,低8位使用P2口;復用方式下,地址總線高8位仍使用P1口,低8位和數據總線復用P3口,P2口就不會受到影響。所以最好設置成復用方式(EMIOCF.4=0),P2口就可以用來作別的輸出端口,自由地控制RES#、CS#、DC。雖然不需要地址總線,但訪問片外存儲器時地址線會被使用,所以仍要避開。實驗結果的時序波形圖如圖3所示。只要 CS#為低時,在WR#(RD#)的下降沿寫入(讀出)數據或命令,即可有效地完成讀寫的工作。
軟件程序的設計
整個單片機控制OLED的顯示程序用C語言編寫,主要程序流程圖如圖4所示。單片機初始化包括關閉看門狗、時鐘初始化、端口初始化,以及定時器和中斷的初始化。OLED初始化包括開顯示、設置顯示模式、設置對比度控制器、對比度設置(1~256)、設置行列起始地址、設置具體位置顏色、設置串口管腳配置。清OLED屏和OLED顯示都是往GDDRAM里寫數據,包括讀狀態、寫命令、寫數據子程序,清OLED屏就全寫0,OLED顯示只要寫入所要顯示的文字或圖片的字符代碼即可。每次寫(命令或數據)之前都要讀狀態,看最高位D7是否為0,也稱之為忙檢測,如果為1,表示忙;反之為閑,在閑的狀況下才可以寫操作。
文字和圖片的顯示
VGG12864G內置128×64 bits的顯示存儲器,用于存儲顯示數據,圖5為RAM的地址結構。RAM容量為128×64=8192 bits,它被分成8頁(page0-page7),每頁8行,每頁的第一列剛好是一個字節,低位在上,高位在下;顯示屏上各像素點的顯示狀態與顯示存儲器的各位二進制數據一一對應,顯示存儲器的數據直接作為圖形顯示的驅動信號。數據顯示為1,相應的像素點顯示;數據顯示為0,相應的像素點不顯示。
所顯示文字或圖片的字符庫,需要自己造,但人工的幾乎不可能,可以選用字模提取軟件——字模提取 V2.2 ,該軟件提供兩種取模方式:橫向和縱向。再根據OLED顯示數據的RAM地址結構,選縱向的取模方式,由于OLED模組的字節結構是高位在下低位在上,所以要設置成字節倒序,字符的字體、字形、大小和顯示效果(下劃線和刪除線)可根據需要進行調整,然后采取C51格式(若用匯編語言編程可采取A51格式)取模生成單個字符的點陣顯示代碼,最后根據需要在OLED屏上的顯示效果,對代碼進行相應調整即可得到所需字符庫。
根據所要顯示的文字或圖片生成所需字符庫,通過OLED顯示程序將字符代碼寫入并存儲在SSD1303的GDDRAM模塊后,就可以穩定地顯示出來。通過軟件編程也可實現圖片的動態顯示,如圖6為該系統所完成的文字和圖片顯示。