嵌入式Linux主板EM9x60作為一種高效、低成本的產品解決方案,專門針對小型的單色LCD顯示模塊(分辨率通常在128×64至320×240),設計了一套通用的漢字及圖形顯示接口函數。這些API函數封裝為靜態庫libLCD_API.a,以C的方式提供給客戶,以方便客戶的使用。
EM9x60提供的LCD_API函數庫包括有兩個文件:LCD_API.H和libLCD_API.a。該函數庫目前支持的LCD屏類型包括有:
LCD控制器類型 |
顯示分辨率 |
簡要說明 |
KS0108 | 128×64 | 最常用的LCD模塊 |
T6963C | 240×128 | 具有較大的顯示窗口 |
SED1335 | 320×240 | |
KS0108 | 192×64 | |
UC1698U | 160×160 | 電力集抄終端標準顯示屏 |
在頭文件LCD_API.H中的對應定義如下。
#define LCD_12864 1 // LCD 128×64 KS0108控制器
#define LCD_2401282 // LCD 240×128 T6963C控制器
#define LCD_320240 3 // LCD 320×240 SED1335控制器
#define LCD_19264 4 // LCD 192×64 KS0108控制器
#define LCD_160160 5 // LCD 192×64 UC1698U控制器
LCD_API函數庫提供了一系列對LCD屏進行畫點、畫線、畫Bar條以及字符串(包括漢字和西文)顯示的接口函數,一共包括了14個函數,其中的漢字支持為標準一級全漢字,為16×16點陣字模或者12X12點陣漢字字模,西文(字母、數字和符號)為8×14點陣字模,這兩個字模文件分別為cclib、cclib12.fnt、ascii.chr,放置在EM9x60嵌入式Linux主板的根文件系統“/lib”目錄中。
在各個功能API函數中,特別是字符串顯示函數LCD_WriteString( ),對于顯示16點陣的漢字,為了加快顯示的速度,實現的方式是通過寫一個字節(writebyte)來實現的,所以客戶在調用這些函數時所定義的坐標位置最好是8的倍數。如果客戶需要顯示一些特殊字體的字符,可以利用LCD_API中的畫點函數來實現專門的特殊字符顯示功能。
下面以Step1_LCDTest為例,介紹利用Sourcery G++工具進行應用程序開發時,如何使用LCD_API函數庫來實現對LCD的顯示操作。
首先需要在應用工程項目文件Step1_LCDTest中導入LCD_API函數庫的這兩個文件:LCD_API.H和libLCD_API.a。在Sourcery G++ IDE下導入不僅僅是將這兩個文件加入到項目工程中,同時也會把這兩個文件復制到項目工程所在的目錄下。
然后還需要設置應用工程(Step1_LCDTest)的編譯屬性,指定編譯鏈接的庫文件名稱和路徑libLCD_API.a,設置的方法如下:
在Project Explorer視窗下,選擇Step1_LCDTest工程文件,然后點擊鼠標右鍵,選擇Properties項,在窗口中選擇C/C++ Build -> Settings -> Tool Settings -> Sourcery G++ C++ Linker -> Libraries,如圖5-1所示。其中的一個窗口用于指定庫文件的名稱,Linux靜態鏈接庫命名的方式為lib+name.a,所以此處需要輸入庫文件的名稱應該只是name,即LCD_API;一個用于指定庫文件所在的路徑。
選擇庫文件
在Step1_LCDTest中Test_LCD12864.cpp提供了一個調用LCD_API中相關函數進行LCD顯示的示例,以下為測試代碼:
#include
#include
#include
#include
#include 'lcd_api.h'
int main( )
{
int x, y;
char BufStr[200];
// 對LCD屏進行初始化操作
LCD_Init( LCD_12864 );
// 設置為異或模式
LCD_SetMode( 1 ); // set to XOR mode
// 居中顯示中文、字符
strcpy( BufStr, '** 歡迎測試 **' );
x = (128-strlen(BufStr)*8)/2;
y = 8;
LCD_WriteString( x, y, BufStr, TEXT_COLOR );
strcpy( BufStr, '嵌入式網絡模塊' );
x = (128-strlen(BufStr)*8)/2;
y = 24;
LCD_WriteString( x, y, BufStr, BK_COLOR ); // 反顯
sleep( 1 );
// 畫線
LCD_DrawLine( 0, 42, 127, 42, TEXT_COLOR );
LCD_DrawLine( 0, 63, 127, 63, TEXT_COLOR );
// 畫曲線
for( x=0; x<128; x++ )
{
y = 53 - 10.0*sin( 2.0*M_PI*x/24.0 );
LCD_PutPixel( x, y, TEXT_COLOR );
}
sleep( 1 );
for( x=0; x<128; x++ )
{
y = 53 - 10.0*sin( 2.0*M_PI*x/24.0 );
LCD_PutPixel( x, y, TEXT_COLOR );
}
sleep( 1 );
LCD_FillBar( 0, 42, 127, 63, BK_COLOR );
LCD_FillBar( 0, 42, 127, 63, TEXT_COLOR );
LCD_FillBar( 0, 42, 127, 63, BK_COLOR );
// 退出LCD顯示
LCD_DeInit( );
return 0;
}
-
Linux
+關注
關注
87文章
11342瀏覽量
210146 -
嵌入式主板
+關注
關注
7文章
6086瀏覽量
35529
發布評論請先 登錄
相關推薦
評論