10.1 概述
之前在51為核心的系統里面,常用的顯示器件有LED,數碼管,LCD1602和LCD12864,這些器件都有一個共同的特點,那就是只有一個顏色,沒有辦法顯示彩色圖片,為了顯示彩色圖片,我們引入了TFT顯示模組。TFT-LCD即薄膜晶體管液晶顯示器。其英文全稱為:ThinFilmTransistor-Liquid Crystal Display。TFT-LCD與無源TN-LCD、STN-LCD的簡單矩陣不同,它在液晶顯示屏的每一個象素上都設置有一個薄膜晶體管(TFT),可有效地克服非選通時的串擾,使顯示液晶屏的靜態特性與掃描線數無關,因此大大提高了圖像質量。TFT-LCD也被叫做真彩液晶顯示器。
目前常用的TFT顯示模組按照接口類型可以分為MCU屏幕與RGB屏幕,其中MCU在STM32F1系列中比較常用,原因是MCU屏幕內部集成了顯示控制器,只需要按照手冊指定的協議將輸入發送過去即可,但是MCU屏幕受限于屏幕尺寸,一般不會超過4.3英寸,RGB屏幕內部沒有控制器,需要單片機或者CPU自帶控制器,但是RGB屏幕尺寸較大,且刷新速度快,通用性強,在生活中使用的更廣泛,由于STM32F1單片機中沒有RGB控制器(LTDC模塊),所以采用核心為5510的TFT屏幕來進行TFT顯示實驗。
注 :我們在網上看到的大尺寸MCU屏幕一般都是以屏幕+PCB的形式,這是因為板子上攜帶了8080并口轉RGB芯片,所以這種情況下,也可以使用MCU屏幕的驅動方式來進行驅動。
10.2 TFTLCD模塊原理圖
10.2.1 接口描述
以2.8英寸TFT為例,實物圖片如下圖所示。
10.2.2 原理圖
CS:片選,低電平有效
RS:數據命令選擇,低電平代表命令,高電平代表數據
WR:寫控制,高電平有效
RD:讀控制,高電平有效
DB0~DB15:16位并行數據口
VCC:電源正極
GND:電源負極
LEDK:背光LED負極
LEDA:背光LED正極
Y-:觸摸屏Y軸數據
X-:觸摸屏X軸數據
Y+:觸摸屏Y軸數據
X+:觸摸屏X軸數據
10.3 FSMC
10.3.1 FSMC簡介
FSMC,即靈活的靜態存儲控制器,能夠與同步或異步存儲器和16位PC存儲器卡連接,STM32F1的FSMC接口支持包括SRAM、NANDFLASH、NOR FLASH和PSRAM等存儲器。一般大容量,且引腳數目在100腳及以上的 STM32F103芯片都帶有FSMC接口,FSMC的框圖如圖所示。
從上圖可知,STM32的FSMC將設備分為3種:NOR/PSRAM設備,NAND設備和PC設備,共用地址數據總線等信號,通過CS端口來區分不同的設備,比如我們這個實驗中LCD的片選就是接在FSMC_NE4端口上,其實本質上就是把TFTLCD作為SRAM來控制。
外部SRAM設備的連接一般有地址線(A0~A18),數據線(D0~D15),寫信號(WR),讀信號(RD)和片選,TFTLCD顯然除了不具備地址線,其他的信號都是具備的,所以我們可以采用SRAM的方式來進行TFT的控制,這種控制方式的好處就是對比傳統的GPIO翻轉可以更快的將數據送入TFT。
STM32F1的FSMC支持8/16/32位數據寬度,我們的TFT模塊采用的是16位數據寬度,所以只需要將FSMC配置為外置16位寬度即可。FSMC的外部存儲器劃分為了固定的4個256 M的存儲塊,如下圖所示。
我們在驅動TFTLCD的時候,用到的存儲塊是塊1,STM32將FSMC的存儲塊1分為4個區,每個區管理64M的空間,每個區都有獨立的寄存器對連接的存儲器進行配置,BANK1的256M空間由28根地址線尋址,這28根地址線如下表所示,其中低26個位來自外部存儲器的地址,我們可以將TFTLCD的片選接在低26位上,通過發送地址來選中片選,只有高2位才是內部可以控制的。
BANK1區域 | 片選 | 地址范圍 | 地址線 |
---|---|---|---|
[27:26] | [25:0] | ||
區域1 | NE1 | 0x60000000 ~ 0x63FFFFFF | 00 |
區域2 | NE2 | 0x64000000 ~ 0x67FFFFFF | 01 |
區域3 | NE3 | 0x68000000 ~ 0x6BFFFFFF | 10 |
區域4 | NE4 | 0x6C000000 ~ 0x6FFFFFFF | 11 |
注:
當Bank1接的是16位寬度存儲器的時候:地址線的[25:1]對應FSMC_A[24:0]
當Bank1接的是8位寬度存儲器的時候:地址線的[25:0]對應FSMC_A[25:0]
對于NOR FLASH控制器,主要通過3個寄存器來設置FSMC的時序參數,NORFLASH控制器支持同步和異步突發兩種訪問方式。
選用同步突發訪問方式時,FSMC將系統時鐘分頻后,發送給外部存儲器作為同步時鐘信號 FSMC_CLK。此時需要的設置的時間參數有2個,即系統時鐘HCLK與FSMC_CLK的分頻系數(可以2~16分頻),同步突發訪問中獲取第一個數據所需要的等待延遲。
選用異步突發訪問方式時,則需要設置3個時間參數:地址建立時間、數據建立時間和地址保持時間。FSMC綜合了SRAM/ROM、PSRAM和NOR Flash產品的信號特點,定義了4種不同的異步時序模型。選用不同的時序模型時,需要設置不同的時序參數。
在實際擴展時,根據選用存儲器的特征確定時序模型,從而確定各時間參數與存儲器讀/寫周期參數指標之間的計算關系,利用該計算關系和存儲芯片數據手冊中給定的參數指標,可計算出FSMC所需要的各時間參數,從而對時間參數寄存器進行合理的配置。
我們現在使用異步模式A方式來控制LCD,模式A的讀操作時序如下圖所示。
模式A支持獨立的讀寫時序控制,這個對驅動TFTLCD來說非常有用,因為TFTLCD在讀的時候,一般比較慢,而在寫的時候可以比較快,如果讀寫用一樣的時序,那么只能以讀的時序為基準,從而導致寫的速度變慢,或者在讀數據的時候,重新配置FSMC的延時,在讀操作完成的時候,再配置回寫的時序,這樣雖然也不會降低寫的速度,但是頻繁配置,比較麻煩。而如果有獨立的讀寫時序控制,那么我們只要初始化的時候配置好,之后就不用再配置,既可以滿足速度要求,又不需要頻繁改配置。
模式A的寫操作如下圖所示。
10.3.2 相關寄存器
(1)SRAM/NOR 閃存片選控制寄存器:FSMC_BCRx(x=1~4)
31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
- | CBURSTRW | - | |||||||||||||
15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
- | EXTMOD | WAITEN | WREN | WAITCFG | WRAPMOD | WAITPOL | BURSTEN | - | FACCEN | MWID | MTYP | MUXEN | MBKEN |
Bit 19:成組寫使能位
0:寫操作始終處于異步模式
1:寫操作為同步模式
Bit 14:EXTMOD:擴展模式使能(即允許讀和寫使用不同的時序)
0:不使用FSMC_BWTR寄存器(默認)
1:FSMC使用FSMC_BWTR寄存器
Bit 13:等待使能位
0:禁用NWAIT信號,在設置的閃存保持周期之后不會檢測NWAIT信號插入等待狀態
1:使用NWAIT信號,在設置的閃存保持周期之后根據NWAIT信號插入等待狀態(默認)
Bit 12:寫使能位
0:禁止FSMC對存儲器的寫操作,否則產生一個AHB錯誤
1:允許FSMC對存儲器的寫操作(默認)
Bit 11:配置等待時序
0:NWAIT信號在等待狀態前的一個數據周期有效(默認)
1:NWAIT信號在等待狀態期間有效(不適用于Cellular RAM)
Bit 10:支持非對齊的成組模式
0:不允許直接的非對齊成組操作(默認)
1:允許直接的非對齊成組操作
Bit 9:等待信號極性
0:NWAIT等待信號為低時有效(默認)
1:NWAIT等待信號為高時有效
Bit 8:成組模式使能
0:禁用成組訪問模式(默認)
1:使用成組訪問模式
Bit 6:閃存訪問使能
0:禁止對NOR閃存存儲器的訪問操作
1:允許對NOR閃存存儲器的訪問操作
Bit 5~Bit 4:存儲器數據總線寬度
00:8位,
01:16位(默認)
10:保留
11:保留
Bit 3~Bit 2:存儲器類型
00:SRAM、ROM(存儲器塊2,3,4在復位后的默認值)
01:PSRAM(Cellular RAM: CRAM)
10:NOR閃存(存儲器塊1在復位后的默認值)
11:保留
Bit 1:地址/數據復用使能位
0:地址/數據不復用。
1:地址/數據復用數據總線(默認)
Bit 0:存儲器塊使能位
0:禁用對應的存儲器塊
1:啟用對應的存儲器塊
(2)SRAM/NOR 閃存片選時序寄存器:FSMC_BTRx(x=1~4)
31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
- | ACCMOD | DATLAT | CLKDIV | BUSTURN | |||||||||||
15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
DATAST | ADDHLD | ADDSET |
Bit 29~Bit 28:訪問模式(這2位只在FSMC_BCRx寄存器的EXTMOD位為1時起作用)
00:訪問模式A
01:訪問模式B
10:訪問模式C
11:訪問模式D
Bit 27~Bit 24:數據保持時間
0000:第一個數據的保持時間為2個CLK時鐘周期
……
1111:第一個數據的保持時間為17個CLK時鐘周期(默認)
Bit 23~Bit 20:時鐘分頻比
0000:保留
0001:1個CLK周期=2個HCLK周期
0010:1個CLK周期=3個HCLK周期
……
1111:1個CLK周期=16個HCLK周期(默認)
Bit 19~Bit 16:總線恢復時間
0000:總線恢復時間=1個HCLK時鐘周期
……
1111:總線恢復時間=16個HCLK時鐘周期(默認)
Bit 15~Bit 8:數據保持時間
00000000:保留
00000001:DATAST保持時間=2個HCLK時鐘周期
00000010:DATAST保持時間=3個HCLK時鐘周期
……
11111111:DATAST保持時間=256個HCLK時鐘周期(默認)
Bit 7~Bit 4:地址保持時間
0000:ADDHLD保持時間=1個HCLK時鐘周期
……
1111:ADDHLD保持時間=16個HCLK時鐘周期(默認)
Bit 3~Bit 0:地址建立時間
0000:ADDSET建立時間=1個HCLK時鐘周期
……
1111:ADDSET建立時間=16個HCLK時鐘周期(默認)
(3)SRAM/NOR 閃存寫時序寄存器:FSMC_BWTRx(x=1~4)
31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
- | ACCMOD | DATLAT | CLKDIV | BUSTURN | |||||||||||
15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
DATAST | ADDHLD | ADDSET |
Bit 29~Bit 28:訪問模式(這2位只在FSMC_BCRx寄存器的EXTMOD位為1時起作用)
00:訪問模式A
01:訪問模式B
10:訪問模式C
11:訪問模式D
Bit 27~Bit 24:數據保持時間
0000:第一個數據的保持時間為2個CLK時鐘周期
……
1111:第一個數據的保持時間為17個CLK時鐘周期(默認)
Bit 23~Bit 20:時鐘分頻比
0000:保留
0001:1個CLK周期=2個HCLK周期
0010:1個CLK周期=3個HCLK周期
……
1111:1個CLK周期=16個HCLK周期(默認)
Bit 19~Bit 16:總線恢復時間
0000:總線恢復時間=1個HCLK時鐘周期
……
1111:總線恢復時間=16個HCLK時鐘周期(默認)
Bit 15~Bit 8:數據保持時間
00000000:保留
00000001:DATAST保持時間=2個HCLK時鐘周期
00000010:DATAST保持時間=3個HCLK時鐘周期
……
11111111:DATAST保持時間=256個HCLK時鐘周期(默認)
Bit 7~Bit 4:地址保持時間
0000:ADDHLD保持時間=1個HCLK時鐘周期
……
1111:ADDHLD保持時間=16個HCLK時鐘周期(默認)
Bit 3~Bit 0:地址建立時間
0000:ADDSET建立時間=1個HCLK時鐘周期
……
1111:ADDSET建立時間=16個HCLK時鐘周期(默認)
10.4 實驗例程
現有一塊驅動芯片為5510的LCD驅動芯片,廠家提供初始化例程,使用STM32的FSMC功能驅動屏幕顯示字符串,連接關系如下表所示。
片選CS:FSMC_NE4
寫控制WR:FSMC_NWE
讀控制RD:FSMC_NOE
數據命令控制RS:FSMC_A6
背光:PB0
16位并行數據:FSMC_D15~FSMC_D0
(1)創建lcd.h,并輸入以下代碼。
#ifndef _LCD_H_
#define _LCD_H_
#include "sys.h"
//LCD地址結構體
typedef struct
{
vu16 LCD_REG ;
vu16 LCD_RAM ;
}LCD_TypeDef ;
#define LCD_BASE ( ( u32 )( 0x6C000000|0x000007FE ))
#define LCD ( ( LCD_TypeDef* ) LCD_BASE )
//LCD重要參數集
typedef struct
{
u16 width ; //LCD寬度
u16 height ; //LCD高度
u8 dir ; //橫屏豎屏控制
u16 wramcmd ; //開始寫gram指令
u16 setxcmd ; //設置x坐標指令
u16 setycmd ; //設置y坐標指令
}_lcd_dev ;
extern _lcd_dev lcddev ; //管理LCD重要參數
//LCD的畫筆顏色和背景色
extern u16 POINT_COLOR ; //畫筆顏色
extern u16 BACK_COLOR ; //背景顏色
#define LCD_LED PBout(0) //LCD背光
//畫筆顏色
#define WHITE 0xFFFF
#define BLACK 0x0000
#define BLUE 0x001F
#define BRED 0XF81F
#define GRED 0XFFE0
#define GBLUE 0X07FF
#define RED 0xF800
#define MAGENTA 0xF81F
#define GREEN 0x07E0
#define CYAN 0x7FFF
#define YELLOW 0xFFE0
#define BROWN 0XBC40 //棕色
#define BRRED 0XFC07 //棕紅色
#define GRAY 0X8430 //灰色
void LCD_Init( void ) ; //初始化
void LCD_Clear( u16 Color ) ; //清屏
void LCD_Fast_DrawPoint( u16 x, u16 y, u16 color ) ; //快速畫點
void LCD_ShowString( u16 x, u16 y, u8 *p ) ; //顯示一個字符串
#endif
注1 :關于LCD_BASE地址的定義部分,其中0x6C000000代表FSMC的SRAM塊4的開始地址,0x000007FE則代表A10的偏移地址,7FE H換算成2進制就是01111111 1110,由于FSMC在16位數據總線狀態下,地址需要右移一個字節,所以映射到A10A0上的地址數據就是011 1111 1111,A0恰好就是0,如果此時16位地址加1,對應的8位地址就是加2,也就是7FE+2=800,映射到A10A0上的地址就是100 0000 0000,即A10變為了1,這就實現了通過A10來控制RS的效果。我們定義的結構體也可以發現,LCD_REG對應的就是0x6C000000+0x000007FE,而LCD_RAM對應的就變成了0x6C000000+0x000007FE+0x00000002。
注2 :結構體_lcd_dev則定義了一些LCD參數,比如高度,寬度,設置命令,可以通過改變宏定義的方式來改變控制器的輸出。
注3 :顏色數據。
目前的顏色數據都有RGB888,RGB666和RGB565格式,代表了R,G和B的分辨率,其中RGB888代表紅,綠,藍都是8位,可以表示16777216種顏色,但是受制于TFTLCD的數據總線寬度只有16位,所以只能夠采用RGB565模式,這種模式代表紅色和藍色都是5位分辨率,綠色6位分辨率,這種模式中可以最多表示65536種顏色。文件中宏定義的顏色數據就是根據RGB888格式轉換而來,一般都是放棄低2位和低1位,例如RGB888模式中某種顏色為11011110 11011110 11011111,那么轉換為RGB565模式就變成了11011 110111 11011,換成16進制就是1101 1110 1111 1011=DEFB H。
(2)創建lcd.c,并添加以下代碼。
#include "lcd.h"
#include "font.h"
#include "delay.h"
void LCD_WriteReg( u16 LCD_Reg, u16 LCD_RegValue )
{
LCD->LCD_REG = LCD_Reg ; //寫入寄存器序號
LCD->LCD_RAM = LCD_RegValue ; //寫入數據
}
_lcd_dev lcddev ; //管理LCD重要參數
void LCD_SetCursor( u16 Xpos, u16 Ypos )
{
LCD_WriteReg( lcddev.setxcmd, Xpos>>8 ) ;
LCD_WriteReg( lcddev.setxcmd+1, Xpos&0xFF ) ;
LCD_WriteReg( lcddev.setycmd, Ypos>>8 ) ;
LCD_WriteReg( lcddev.setycmd+1, Ypos&0xFF ) ;
}
void LCD_Display_Dir()
{
u16 temp;
lcddev.wramcmd = 0x2C00 ;
lcddev.setxcmd = 0x2A00 ;
lcddev.setycmd = 0x2B00 ;
lcddev.width = 480 ;
lcddev.height = 800 ;
//交換X,Y
if( lcddev.width>lcddev.height )
{
temp = lcddev.width ;
lcddev.width = lcddev.height ;
lcddev.height = temp ;
}
//設置掃描方向
LCD_WriteReg( 0x3600, 0 ) ;
LCD_WriteReg( lcddev.setxcmd, 0 ) ;
LCD_WriteReg( lcddev.setxcmd+1, 0 ) ;
LCD_WriteReg( lcddev.setxcmd+2, ( lcddev.width-1 )>>8 ) ;
LCD_WriteReg( lcddev.setxcmd+3, ( lcddev.width-1 )&0xFF ) ;
LCD_WriteReg( lcddev.setycmd, 0 ) ;
LCD_WriteReg( lcddev.setycmd+1, 0 ) ;
LCD_WriteReg( lcddev.setycmd+2, ( lcddev.height-1 )>>8 ) ;
LCD_WriteReg( lcddev.setycmd+3, ( lcddev.height-1 )&0xFF ) ;
}
void LCD_Init()
{
RCC->AHBENR |= 1<<8 ; //使能FSMC時鐘
RCC->APB2ENR |= 1<<3 ; //使能PORTB時鐘
RCC->APB2ENR |= 1<<5 ; //使能PORTD時鐘
RCC->APB2ENR |= 1<<6 ; //使能PORTE時鐘
RCC->APB2ENR |= 1<<8 ; //使能PORTG時鐘
GPIOB->CRL &= 0xFFFFFFF0 ; //PB0 推挽輸出
GPIOB->CRL |= 0x00000003 ;
//PORTD復用推挽輸出
GPIOD->CRH &= 0x00FFF000 ;
GPIOD->CRH |= 0xBB000BBB ;
GPIOD->CRL &= 0xFF00FF00 ;
GPIOD->CRL |= 0x00BB00BB ;
//PORTE復用推挽輸出
GPIOE->CRH &= 0x00000000 ;
GPIOE->CRH |= 0xBBBBBBBB ;
GPIOE->CRL &= 0x0FFFFFFF ;
GPIOE->CRL |= 0xB0000000 ;
//PORTG12復用推挽輸出
GPIOG->CRH &= 0xFFF0FFFF ;
GPIOG->CRH |= 0x000B0000 ;
GPIOG->CRL &= 0xFFFFFFF0 ; //PG0->RS
GPIOG->CRL |= 0x0000000B ;
FSMC_Bank1->BTCR[ 6 ] = 0x00000000 ;
FSMC_Bank1->BTCR[ 7 ] = 0x00000000 ;
FSMC_Bank1E->BWTR[ 6 ] = 0x00000000 ;
FSMC_Bank1->BTCR[ 6 ] |= 1<<12 ; //存儲器寫使能
FSMC_Bank1->BTCR[ 6 ] |= 1<<14 ; //讀寫使用不同的時序
FSMC_Bank1->BTCR[ 6 ] |= 1<<4 ; //存儲器數據寬度為16bit
FSMC_Bank1->BTCR[ 7 ] |= 0<<28 ; //模式A
FSMC_Bank1->BTCR[ 7 ] |= 1<<0 ; //地址建立時間為2個HCLK 1/36M=27ns
FSMC_Bank1->BTCR[ 7 ] |= 0xF<<8 ; //數據保存時間為16個HCLK
FSMC_Bank1E->BWTR[ 6 ] |= 0<<28 ; //模式A
FSMC_Bank1E->BWTR[ 6 ] |= 0<<0 ; //地址建立時間為1個HCLK
FSMC_Bank1E->BWTR[ 6 ] |= 3<<8 ; //數據保存時間為4個HCLK
FSMC_Bank1->BTCR[ 6 ] |= 1<<0 ; //使能BANK1區域4
delay_ms( 50 ) ; //delay 50 ms
LCD_WriteReg( 0xF000, 0x55 ) ;
LCD_WriteReg( 0xF001, 0xAA ) ;
LCD_WriteReg( 0xF002, 0x52 ) ;
LCD_WriteReg( 0xF003, 0x08 ) ;
LCD_WriteReg( 0xF004, 0x01 ) ;
//AVDD Set AVDD 5.2V
LCD_WriteReg( 0xB000, 0x0D ) ;
LCD_WriteReg( 0xB001, 0x0D ) ;
LCD_WriteReg( 0xB002, 0x0D ) ;
//AVDD ratio
LCD_WriteReg( 0xB600, 0x34 ) ;
LCD_WriteReg( 0xB601, 0x34 ) ;
LCD_WriteReg( 0xB602, 0x34 ) ;
//AVEE -5.2V
LCD_WriteReg( 0xB100, 0x0D ) ;
LCD_WriteReg( 0xB101, 0x0D ) ;
LCD_WriteReg( 0xB102, 0x0D ) ;
//AVEE ratio
LCD_WriteReg( 0xB700, 0x34 ) ;
LCD_WriteReg( 0xB701, 0x34 ) ;
LCD_WriteReg( 0xB702, 0x34 ) ;
//VCL -2.5V
LCD_WriteReg( 0xB200, 0x00 ) ;
LCD_WriteReg( 0xB201, 0x00 ) ;
LCD_WriteReg( 0xB202, 0x00 ) ;
//VCL ratio
LCD_WriteReg( 0xB800, 0x24 ) ;
LCD_WriteReg( 0xB801, 0x24 ) ;
LCD_WriteReg( 0xB802, 0x24 ) ;
//VGH 15V
LCD_WriteReg( 0xBF00, 0x01 ) ;
LCD_WriteReg( 0xB300, 0x0F ) ;
LCD_WriteReg( 0xB301, 0x0F ) ;
LCD_WriteReg( 0xB302, 0x0F ) ;
//VGH ratio
LCD_WriteReg( 0xB900, 0x34 ) ;
LCD_WriteReg( 0xB901, 0x34 ) ;
LCD_WriteReg( 0xB902, 0x34 ) ;
//VGL_REG -10V
LCD_WriteReg( 0xB500, 0x08 ) ;
LCD_WriteReg( 0xB501, 0x08 ) ;
LCD_WriteReg( 0xB502, 0x08 ) ;
LCD_WriteReg( 0xC200, 0x03 ) ;
//VGLX ratio
LCD_WriteReg( 0xBA00, 0x24 ) ;
LCD_WriteReg( 0xBA01, 0x24 ) ;
LCD_WriteReg( 0xBA02, 0x24 ) ;
//VGMP/VGSP 4.5V/0V
LCD_WriteReg( 0xBC00, 0x00 ) ;
LCD_WriteReg( 0xBC01, 0x78 ) ;
LCD_WriteReg( 0xBC02, 0x00 ) ;
//VGMN/VGSN -4.5V/0V
LCD_WriteReg( 0xBD00, 0x00 ) ;
LCD_WriteReg( 0xBD01, 0x78 ) ;
LCD_WriteReg( 0xBD02, 0x00 ) ;
//VCOM
LCD_WriteReg( 0xBE00, 0x00 ) ;
LCD_WriteReg( 0xBE01, 0x64 ) ;
//Gamma Setting
LCD_WriteReg( 0xD100, 0x00 ) ;
LCD_WriteReg( 0xD101, 0x33 ) ;
LCD_WriteReg( 0xD102, 0x00 ) ;
LCD_WriteReg( 0xD103, 0x34 ) ;
LCD_WriteReg( 0xD104, 0x00 ) ;
LCD_WriteReg( 0xD105, 0x3A ) ;
LCD_WriteReg( 0xD106, 0x00 ) ;
LCD_WriteReg( 0xD107, 0x4A ) ;
LCD_WriteReg( 0xD108, 0x00 ) ;
LCD_WriteReg( 0xD109, 0x5C ) ;
LCD_WriteReg( 0xD10A, 0x00 ) ;
LCD_WriteReg( 0xD10B, 0x81 ) ;
LCD_WriteReg( 0xD10C, 0x00 ) ;
LCD_WriteReg( 0xD10D, 0xA6 ) ;
LCD_WriteReg( 0xD10E, 0x00 ) ;
LCD_WriteReg( 0xD10F, 0xE5 ) ;
LCD_WriteReg( 0xD110, 0x01 ) ;
LCD_WriteReg( 0xD111, 0x13 ) ;
LCD_WriteReg( 0xD112, 0x01 ) ;
LCD_WriteReg( 0xD113, 0x54 ) ;
LCD_WriteReg( 0xD114, 0x01 ) ;
LCD_WriteReg( 0xD115, 0x82 ) ;
LCD_WriteReg( 0xD116, 0x01 ) ;
LCD_WriteReg( 0xD117, 0xCA ) ;
LCD_WriteReg( 0xD118, 0x02 ) ;
LCD_WriteReg( 0xD119, 0x00 ) ;
LCD_WriteReg( 0xD11A, 0x02 ) ;
LCD_WriteReg( 0xD11B, 0x01 ) ;
LCD_WriteReg( 0xD11C, 0x02 ) ;
LCD_WriteReg( 0xD11D, 0x34 ) ;
LCD_WriteReg( 0xD11E, 0x02 ) ;
LCD_WriteReg( 0xD11F, 0x67 ) ;
LCD_WriteReg( 0xD120, 0x02 ) ;
LCD_WriteReg( 0xD121, 0x84 ) ;
LCD_WriteReg( 0xD122, 0x02 ) ;
LCD_WriteReg( 0xD123, 0xA4 ) ;
LCD_WriteReg( 0xD124, 0x02 ) ;
LCD_WriteReg( 0xD125, 0xB7 ) ;
LCD_WriteReg( 0xD126, 0x02 ) ;
LCD_WriteReg( 0xD127, 0xCF ) ;
LCD_WriteReg( 0xD128, 0x02 ) ;
LCD_WriteReg( 0xD129, 0xDE ) ;
LCD_WriteReg( 0xD12A, 0x02 ) ;
LCD_WriteReg( 0xD12B, 0xF2 ) ;
LCD_WriteReg( 0xD12C, 0x02 ) ;
LCD_WriteReg( 0xD12D, 0xFE ) ;
LCD_WriteReg( 0xD12E, 0x03 ) ;
LCD_WriteReg( 0xD12F, 0x10 ) ;
LCD_WriteReg( 0xD130, 0x03 ) ;
LCD_WriteReg( 0xD131, 0x33 ) ;
LCD_WriteReg( 0xD132, 0x03 ) ;
LCD_WriteReg( 0xD133, 0x6D ) ;
LCD_WriteReg( 0xD200, 0x00 ) ;
LCD_WriteReg( 0xD201, 0x33 ) ;
LCD_WriteReg( 0xD202, 0x00 ) ;
LCD_WriteReg( 0xD203, 0x34 ) ;
LCD_WriteReg( 0xD204, 0x00 ) ;
LCD_WriteReg( 0xD205, 0x3A ) ;
LCD_WriteReg( 0xD206, 0x00 ) ;
LCD_WriteReg( 0xD207, 0x4A ) ;
LCD_WriteReg( 0xD208, 0x00 ) ;
LCD_WriteReg( 0xD209, 0x5C ) ;
LCD_WriteReg( 0xD20A, 0x00 ) ;
LCD_WriteReg( 0xD20B, 0x81 ) ;
LCD_WriteReg( 0xD20C, 0x00 ) ;
LCD_WriteReg( 0xD20D, 0xA6 ) ;
LCD_WriteReg( 0xD20E, 0x00 ) ;
LCD_WriteReg( 0xD20F, 0xE5 ) ;
LCD_WriteReg( 0xD210, 0x01 ) ;
LCD_WriteReg( 0xD211, 0x13 ) ;
LCD_WriteReg( 0xD212, 0x01 ) ;
LCD_WriteReg( 0xD213, 0x54 ) ;
LCD_WriteReg( 0xD214, 0x01 ) ;
LCD_WriteReg( 0xD215, 0x82 ) ;
LCD_WriteReg( 0xD216, 0x01 ) ;
LCD_WriteReg( 0xD217, 0xCA ) ;
LCD_WriteReg( 0xD218, 0x02 ) ;
LCD_WriteReg( 0xD219, 0x00 ) ;
LCD_WriteReg( 0xD21A, 0x02 ) ;
LCD_WriteReg( 0xD21B, 0x01 ) ;
LCD_WriteReg( 0xD21C, 0x02 ) ;
LCD_WriteReg( 0xD21D, 0x34 ) ;
LCD_WriteReg( 0xD21E, 0x02 ) ;
LCD_WriteReg( 0xD21F, 0x67 ) ;
LCD_WriteReg( 0xD220, 0x02 ) ;
LCD_WriteReg( 0xD221, 0x84 ) ;
LCD_WriteReg( 0xD222, 0x02 ) ;
LCD_WriteReg( 0xD223, 0xA4 ) ;
LCD_WriteReg( 0xD224, 0x02 ) ;
LCD_WriteReg( 0xD225, 0xB7 ) ;
LCD_WriteReg( 0xD226, 0x02 ) ;
LCD_WriteReg( 0xD227, 0xCF ) ;
LCD_WriteReg( 0xD228, 0x02 ) ;
LCD_WriteReg( 0xD229, 0xDE ) ;
LCD_WriteReg( 0xD22A, 0x02 ) ;
LCD_WriteReg( 0xD22B, 0xF2 ) ;
LCD_WriteReg( 0xD22C, 0x02 ) ;
LCD_WriteReg( 0xD22D, 0xFE ) ;
LCD_WriteReg( 0xD22E, 0x03 ) ;
LCD_WriteReg( 0xD22F, 0x10 ) ;
LCD_WriteReg( 0xD230, 0x03 ) ;
LCD_WriteReg( 0xD231, 0x33 ) ;
LCD_WriteReg( 0xD232, 0x03 ) ;
LCD_WriteReg( 0xD233, 0x6D ) ;
LCD_WriteReg( 0xD300, 0x00 ) ;
LCD_WriteReg( 0xD301, 0x33 ) ;
LCD_WriteReg( 0xD302, 0x00 ) ;
LCD_WriteReg( 0xD303, 0x34 ) ;
LCD_WriteReg( 0xD304, 0x00 ) ;
LCD_WriteReg( 0xD305, 0x3A ) ;
LCD_WriteReg( 0xD306, 0x00 ) ;
LCD_WriteReg( 0xD307, 0x4A ) ;
LCD_WriteReg( 0xD308, 0x00 ) ;
LCD_WriteReg( 0xD309, 0x5C ) ;
LCD_WriteReg( 0xD30A, 0x00 ) ;
LCD_WriteReg( 0xD30B, 0x81 ) ;
LCD_WriteReg( 0xD30C, 0x00 ) ;
LCD_WriteReg( 0xD30D, 0xA6 ) ;
LCD_WriteReg( 0xD30E, 0x00 ) ;
LCD_WriteReg( 0xD30F, 0xE5 ) ;
LCD_WriteReg( 0xD310, 0x01 ) ;
LCD_WriteReg( 0xD311, 0x13 ) ;
LCD_WriteReg( 0xD312, 0x01 ) ;
LCD_WriteReg( 0xD313, 0x54 ) ;
LCD_WriteReg( 0xD314, 0x01 ) ;
LCD_WriteReg( 0xD315, 0x82 ) ;
LCD_WriteReg( 0xD316, 0x01 ) ;
LCD_WriteReg( 0xD317, 0xCA ) ;
LCD_WriteReg( 0xD318, 0x02 ) ;
LCD_WriteReg( 0xD319, 0x00 ) ;
LCD_WriteReg( 0xD31A, 0x02 ) ;
LCD_WriteReg( 0xD31B, 0x01 ) ;
LCD_WriteReg( 0xD31C, 0x02 ) ;
LCD_WriteReg( 0xD31D, 0x34 ) ;
LCD_WriteReg( 0xD31E, 0x02 ) ;
LCD_WriteReg( 0xD31F, 0x67 ) ;
LCD_WriteReg( 0xD320, 0x02 ) ;
LCD_WriteReg( 0xD321, 0x84 ) ;
LCD_WriteReg( 0xD322, 0x02 ) ;
LCD_WriteReg( 0xD323, 0xA4 ) ;
LCD_WriteReg( 0xD324, 0x02 ) ;
LCD_WriteReg( 0xD325, 0xB7 ) ;
LCD_WriteReg( 0xD326, 0x02 ) ;
LCD_WriteReg( 0xD327, 0xCF ) ;
LCD_WriteReg( 0xD328, 0x02 ) ;
LCD_WriteReg( 0xD329, 0xDE ) ;
LCD_WriteReg( 0xD32A, 0x02 ) ;
LCD_WriteReg( 0xD32B, 0xF2 ) ;
LCD_WriteReg( 0xD32C, 0x02 ) ;
LCD_WriteReg( 0xD32D, 0xFE ) ;
LCD_WriteReg( 0xD32E, 0x03 ) ;
LCD_WriteReg( 0xD32F, 0x10 ) ;
LCD_WriteReg( 0xD330, 0x03 ) ;
LCD_WriteReg( 0xD331, 0x33 ) ;
LCD_WriteReg( 0xD332, 0x03 ) ;
LCD_WriteReg( 0xD333, 0x6D ) ;
LCD_WriteReg( 0xD400, 0x00 ) ;
LCD_WriteReg( 0xD401, 0x33 ) ;
LCD_WriteReg( 0xD402, 0x00 ) ;
LCD_WriteReg( 0xD403, 0x34 ) ;
LCD_WriteReg( 0xD404, 0x00 ) ;
LCD_WriteReg( 0xD405, 0x3A ) ;
LCD_WriteReg( 0xD406, 0x00 ) ;
LCD_WriteReg( 0xD407, 0x4A ) ;
LCD_WriteReg( 0xD408, 0x00 ) ;
LCD_WriteReg( 0xD409, 0x5C ) ;
LCD_WriteReg( 0xD40A, 0x00 ) ;
LCD_WriteReg( 0xD40B, 0x81 ) ;
LCD_WriteReg( 0xD40C, 0x00 ) ;
LCD_WriteReg( 0xD40D, 0xA6 ) ;
LCD_WriteReg( 0xD40E, 0x00 ) ;
LCD_WriteReg( 0xD40F, 0xE5 ) ;
LCD_WriteReg( 0xD410, 0x01 ) ;
LCD_WriteReg( 0xD411, 0x13 ) ;
LCD_WriteReg( 0xD412, 0x01 ) ;
LCD_WriteReg( 0xD413, 0x54 ) ;
LCD_WriteReg( 0xD414, 0x01 ) ;
LCD_WriteReg( 0xD415, 0x82 ) ;
LCD_WriteReg( 0xD416, 0x01 ) ;
LCD_WriteReg( 0xD417, 0xCA ) ;
LCD_WriteReg( 0xD418, 0x02 ) ;
LCD_WriteReg( 0xD419, 0x00 ) ;
LCD_WriteReg( 0xD41A, 0x02 ) ;
LCD_WriteReg( 0xD41B, 0x01 ) ;
LCD_WriteReg( 0xD41C, 0x02 ) ;
LCD_WriteReg( 0xD41D, 0x34 ) ;
LCD_WriteReg( 0xD41E, 0x02 ) ;
LCD_WriteReg( 0xD41F, 0x67 ) ;
LCD_WriteReg( 0xD420, 0x02 ) ;
LCD_WriteReg( 0xD421, 0x84 ) ;
LCD_WriteReg( 0xD422, 0x02 ) ;
LCD_WriteReg( 0xD423, 0xA4 ) ;
LCD_WriteReg( 0xD424, 0x02 ) ;
LCD_WriteReg( 0xD425, 0xB7 ) ;
LCD_WriteReg( 0xD426, 0x02 ) ;
LCD_WriteReg( 0xD427, 0xCF ) ;
LCD_WriteReg( 0xD428, 0x02 ) ;
LCD_WriteReg( 0xD429, 0xDE ) ;
LCD_WriteReg( 0xD42A, 0x02 ) ;
LCD_WriteReg( 0xD42B, 0xF2 ) ;
LCD_WriteReg( 0xD42C, 0x02 ) ;
LCD_WriteReg( 0xD42D, 0xFE ) ;
LCD_WriteReg( 0xD42E, 0x03 ) ;
LCD_WriteReg( 0xD42F, 0x10 ) ;
LCD_WriteReg( 0xD430, 0x03 ) ;
LCD_WriteReg( 0xD431, 0x33 ) ;
LCD_WriteReg( 0xD432, 0x03 ) ;
LCD_WriteReg( 0xD433, 0x6D ) ;
LCD_WriteReg( 0xD500, 0x00 ) ;
LCD_WriteReg( 0xD501, 0x33 ) ;
LCD_WriteReg( 0xD502, 0x00 ) ;
LCD_WriteReg( 0xD503, 0x34 ) ;
LCD_WriteReg( 0xD504, 0x00 ) ;
LCD_WriteReg( 0xD505, 0x3A ) ;
LCD_WriteReg( 0xD506, 0x00 ) ;
LCD_WriteReg( 0xD507, 0x4A ) ;
LCD_WriteReg( 0xD508, 0x00 ) ;
LCD_WriteReg( 0xD509, 0x5C ) ;
LCD_WriteReg( 0xD50A, 0x00 ) ;
LCD_WriteReg( 0xD50B, 0x81 ) ;
LCD_WriteReg( 0xD50C, 0x00 ) ;
LCD_WriteReg( 0xD50D, 0xA6 ) ;
LCD_WriteReg( 0xD50E, 0x00 ) ;
LCD_WriteReg( 0xD50F, 0xE5 ) ;
LCD_WriteReg( 0xD510, 0x01 ) ;
LCD_WriteReg( 0xD511, 0x13 ) ;
LCD_WriteReg( 0xD512, 0x01 ) ;
LCD_WriteReg( 0xD513, 0x54 ) ;
LCD_WriteReg( 0xD514, 0x01 ) ;
LCD_WriteReg( 0xD515, 0x82 ) ;
LCD_WriteReg( 0xD516, 0x01 ) ;
LCD_WriteReg( 0xD517, 0xCA ) ;
LCD_WriteReg( 0xD518, 0x02 ) ;
LCD_WriteReg( 0xD519, 0x00 ) ;
LCD_WriteReg( 0xD51A, 0x02 ) ;
LCD_WriteReg( 0xD51B, 0x01 ) ;
LCD_WriteReg( 0xD51C, 0x02 ) ;
LCD_WriteReg( 0xD51D, 0x34 ) ;
LCD_WriteReg( 0xD51E, 0x02 ) ;
LCD_WriteReg( 0xD51F, 0x67 ) ;
LCD_WriteReg( 0xD520, 0x02 ) ;
LCD_WriteReg( 0xD521, 0x84 ) ;
LCD_WriteReg( 0xD522, 0x02 ) ;
LCD_WriteReg( 0xD523, 0xA4 ) ;
LCD_WriteReg( 0xD524, 0x02 ) ;
LCD_WriteReg( 0xD525, 0xB7 ) ;
LCD_WriteReg( 0xD526, 0x02 ) ;
LCD_WriteReg( 0xD527, 0xCF ) ;
LCD_WriteReg( 0xD528, 0x02 ) ;
LCD_WriteReg( 0xD529, 0xDE ) ;
LCD_WriteReg( 0xD52A, 0x02 ) ;
LCD_WriteReg( 0xD52B, 0xF2 ) ;
LCD_WriteReg( 0xD52C, 0x02 ) ;
LCD_WriteReg( 0xD52D, 0xFE ) ;
LCD_WriteReg( 0xD52E, 0x03 ) ;
LCD_WriteReg( 0xD52F, 0x10 ) ;
LCD_WriteReg( 0xD530, 0x03 ) ;
LCD_WriteReg( 0xD531, 0x33 ) ;
LCD_WriteReg( 0xD532, 0x03 ) ;
LCD_WriteReg( 0xD533, 0x6D ) ;
LCD_WriteReg( 0xD600, 0x00 ) ;
LCD_WriteReg( 0xD601, 0x33 ) ;
LCD_WriteReg( 0xD602, 0x00 ) ;
LCD_WriteReg( 0xD603, 0x34 ) ;
LCD_WriteReg( 0xD604, 0x00 ) ;
LCD_WriteReg( 0xD605, 0x3A ) ;
LCD_WriteReg( 0xD606, 0x00 ) ;
LCD_WriteReg( 0xD607, 0x4A ) ;
LCD_WriteReg( 0xD608, 0x00 ) ;
LCD_WriteReg( 0xD609, 0x5C ) ;
LCD_WriteReg( 0xD60A, 0x00 ) ;
LCD_WriteReg( 0xD60B, 0x81 ) ;
LCD_WriteReg( 0xD60C, 0x00 ) ;
LCD_WriteReg( 0xD60D, 0xA6 ) ;
LCD_WriteReg( 0xD60E, 0x00 ) ;
LCD_WriteReg( 0xD60F, 0xE5 ) ;
LCD_WriteReg( 0xD610, 0x01 ) ;
LCD_WriteReg( 0xD611, 0x13 ) ;
LCD_WriteReg( 0xD612, 0x01 ) ;
LCD_WriteReg( 0xD613, 0x54 ) ;
LCD_WriteReg( 0xD614, 0x01 ) ;
LCD_WriteReg( 0xD615, 0x82 ) ;
LCD_WriteReg( 0xD616, 0x01 ) ;
LCD_WriteReg( 0xD617, 0xCA ) ;
LCD_WriteReg( 0xD618, 0x02 ) ;
LCD_WriteReg( 0xD619, 0x00 ) ;
LCD_WriteReg( 0xD61A, 0x02 ) ;
LCD_WriteReg( 0xD61B, 0x01 ) ;
LCD_WriteReg( 0xD61C, 0x02 ) ;
LCD_WriteReg( 0xD61D, 0x34 ) ;
LCD_WriteReg( 0xD61E, 0x02 ) ;
LCD_WriteReg( 0xD61F, 0x67 ) ;
LCD_WriteReg( 0xD620, 0x02 ) ;
LCD_WriteReg( 0xD621, 0x84 ) ;
LCD_WriteReg( 0xD622, 0x02 ) ;
LCD_WriteReg( 0xD623, 0xA4 ) ;
LCD_WriteReg( 0xD624, 0x02 ) ;
LCD_WriteReg( 0xD625, 0xB7 ) ;
LCD_WriteReg( 0xD626, 0x02 ) ;
LCD_WriteReg( 0xD627, 0xCF ) ;
LCD_WriteReg( 0xD628, 0x02 ) ;
LCD_WriteReg( 0xD629, 0xDE ) ;
LCD_WriteReg( 0xD62A, 0x02 ) ;
LCD_WriteReg( 0xD62B, 0xF2 ) ;
LCD_WriteReg( 0xD62C, 0x02 ) ;
LCD_WriteReg( 0xD62D, 0xFE ) ;
LCD_WriteReg( 0xD62E, 0x03 ) ;
LCD_WriteReg( 0xD62F, 0x10 ) ;
LCD_WriteReg( 0xD630, 0x03 ) ;
LCD_WriteReg( 0xD631, 0x33 ) ;
LCD_WriteReg( 0xD632, 0x03 ) ;
LCD_WriteReg( 0xD633, 0x6D ) ;
//LV2 Page 0 enable
LCD_WriteReg( 0xF000, 0x55 ) ;
LCD_WriteReg( 0xF001, 0xAA ) ;
LCD_WriteReg( 0xF002, 0x52 ) ;
LCD_WriteReg( 0xF003, 0x08 ) ;
LCD_WriteReg( 0xF004, 0x00 ) ;
//Display control
LCD_WriteReg( 0xB100, 0xCC ) ;
LCD_WriteReg( 0xB101, 0x00 ) ;
//Source hold time
LCD_WriteReg( 0xB600, 0x05 ) ;
//Gate EQ control
LCD_WriteReg( 0xB700, 0x70 ) ;
LCD_WriteReg( 0xB701, 0x70 ) ;
//Source EQ control ( Mode 2 )
LCD_WriteReg( 0xB800, 0x01 ) ;
LCD_WriteReg( 0xB801, 0x03 ) ;
LCD_WriteReg( 0xB802, 0x03 ) ;
LCD_WriteReg( 0xB803, 0x03 ) ;
//Inversion mode ( 2-dot )
LCD_WriteReg( 0xBC00, 0x02 ) ;
LCD_WriteReg( 0xBC01, 0x00 ) ;
LCD_WriteReg( 0xBC02, 0x00 ) ;
//Timing control 4H w/ 4-delay
LCD_WriteReg( 0xC900, 0xD0 ) ;
LCD_WriteReg( 0xC901, 0x02 ) ;
LCD_WriteReg( 0xC902, 0x50 ) ;
LCD_WriteReg( 0xC903, 0x50 ) ;
LCD_WriteReg( 0xC904, 0x50 ) ;
LCD_WriteReg( 0x3500, 0x00 ) ;
LCD_WriteReg( 0x3A00, 0x55 ) ; //16-bit/pixel
LCD->LCD_REG = 0x1100 ;
delay_us( 120 ) ;
LCD->LCD_REG = 0x2900 ;
LCD_Display_Dir() ; //默認為豎屏
LCD_LED = 1 ; //點亮背光
LCD_Clear( WHITE ) ;
}
void LCD_Clear( u16 color )
{
u32 index = 0 ;
u32 totalpoint = lcddev.width ;
totalpoint *= lcddev.height ; //得到總點數
LCD_SetCursor( 0, 0 ) ; //設置光標位置
LCD->LCD_REG = lcddev.wramcmd ; //開始寫入GRAM
for( index=0; index
注1 :省略的初始化代碼是在采購屏幕的時候生產廠家提供的驅動代碼,這部分代碼包括初始化屏幕的伽馬校正以及顯示地址增加等功能,可以不去管,只需要復制到初始化的位置即可。
注2 :清屏函數LCD_Clear
清屏其實就是在屏幕中送入白色或者別的顏色,一般都是全部像素點寫入白色,該函數也可以用于填充顏色使用,程序中首先通過橫坐標點數和縱坐標點數計算出所有像素點的個數,由于初始化中設置了地址自增加功能,所以可以設定開始地址后直接不停的發送白色的數據代碼,直到所有像素點全部填充后結束。
注3 :顯示1個字符函數LCD_ShowChar
TFTLCD由于內部沒有字庫,所以所有的英文包括ASCII碼,中文都需要自己取模,取模的方式類似于之前的51單片機驅動點陣,這種情況下可以采用廠家提供的現成的代碼,或者自己用取模軟件直接生成代碼,文件中包含的頭文件font.h其實就是自己通過軟件得到的ASCII碼的字符點陣數據。讀取點陣的時候,1的位置寫入設置的顏色(畫筆顏色),0的位置寫入背景顏色,當背景顏色和刷屏顏色一樣的時候,看起來就像是顯示了數據一樣(也可以不寫入背景顏色,直接在1的位置寫入畫筆顏色,0的位置不管,這種情況下可以實現字體的透明效果)。
注4 :顯示字符串函數LCD_ShowString
顯示字符串函數實際就是頻繁調用函數LCD_ShowChar,通過while循環來判斷字符串的結尾,將結尾之前的數據全部寫入后退出循環。有的廠家會提供完整的例程,里面包括顯示數字,顯示圖像,其實本質都是通過判斷點陣數據來寫入畫筆顏色和背景顏色。
(3)創建font.h,自己通過取模軟件來添加字符的字模。
#ifndef _FONT_H_
#define _FONT_H_
//常用ASCII表
//陰碼+逐列式+順向+C51格式
const unsigned char asc2_1608[95][16]={
{0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00},/*" ",0*/
{0x00,0x00,0x00,0x00,0x00,0x00,0x1F,0xCC,0x00,0x0C,0x00,0x00,0x00,0x00,0x00,0x00},/*"!",1*/
{0x00,0x00,0x08,0x00,0x30,0x00,0x60,0x00,0x08,0x00,0x30,0x00,0x60,0x00,0x00,0x00},/*""",2*/
{0x02,0x20,0x03,0xFC,0x1E,0x20,0x02,0x20,0x03,0xFC,0x1E,0x20,0x02,0x20,0x00,0x00},/*"#",3*/
{0x00,0x00,0x0E,0x18,0x11,0x04,0x3F,0xFF,0x10,0x84,0x0C,0x78,0x00,0x00,0x00,0x00},/*"$",4*/
{0x0F,0x00,0x10,0x84,0x0F,0x38,0x00,0xC0,0x07,0x78,0x18,0x84,0x00,0x78,0x00,0x00},/*"%",5*/
{0x00,0x78,0x0F,0x84,0x10,0xC4,0x11,0x24,0x0E,0x98,0x00,0xE4,0x00,0x84,0x00,0x08},/*"&",6*/
{0x08,0x00,0x68,0x00,0x70,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00},/*"'",7*/
{0x00,0x00,0x00,0x00,0x00,0x00,0x07,0xE0,0x18,0x18,0x20,0x04,0x40,0x02,0x00,0x00},/*"(",8*/
{0x00,0x00,0x40,0x02,0x20,0x04,0x18,0x18,0x07,0xE0,0x00,0x00,0x00,0x00,0x00,0x00},/*")",9*/
{0x02,0x40,0x02,0x40,0x01,0x80,0x0F,0xF0,0x01,0x80,0x02,0x40,0x02,0x40,0x00,0x00},/*"*",10*/
{0x00,0x80,0x00,0x80,0x00,0x80,0x0F,0xF8,0x00,0x80,0x00,0x80,0x00,0x80,0x00,0x00},/*"+",11*/
{0x00,0x01,0x00,0x0D,0x00,0x0E,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00},/*",",12*/
{0x00,0x00,0x00,0x80,0x00,0x80,0x00,0x80,0x00,0x80,0x00,0x80,0x00,0x80,0x00,0x80},/*"-",13*/
{0x00,0x00,0x00,0x0C,0x00,0x0C,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00},/*".",14*/
{0x00,0x00,0x00,0x06,0x00,0x18,0x00,0x60,0x01,0x80,0x06,0x00,0x18,0x00,0x20,0x00},/*"/",15*/
{0x00,0x00,0x07,0xF0,0x08,0x08,0x10,0x04,0x10,0x04,0x08,0x08,0x07,0xF0,0x00,0x00},/*"0",16*/
{0x00,0x00,0x08,0x04,0x08,0x04,0x1F,0xFC,0x00,0x04,0x00,0x04,0x00,0x00,0x00,0x00},/*"1",17*/
{0x00,0x00,0x0E,0x0C,0x10,0x14,0x10,0x24,0x10,0x44,0x11,0x84,0x0E,0x0C,0x00,0x00},/*"2",18*/
{0x00,0x00,0x0C,0x18,0x10,0x04,0x11,0x04,0x11,0x04,0x12,0x88,0x0C,0x70,0x00,0x00},/*"3",19*/
{0x00,0x00,0x00,0xE0,0x03,0x20,0x04,0x24,0x08,0x24,0x1F,0xFC,0x00,0x24,0x00,0x00},/*"4",20*/
{0x00,0x00,0x1F,0x98,0x10,0x84,0x11,0x04,0x11,0x04,0x10,0x88,0x10,0x70,0x00,0x00},/*"5",21*/
{0x00,0x00,0x07,0xF0,0x08,0x88,0x11,0x04,0x11,0x04,0x18,0x88,0x00,0x70,0x00,0x00},/*"6",22*/
{0x00,0x00,0x1C,0x00,0x10,0x00,0x10,0xFC,0x13,0x00,0x1C,0x00,0x10,0x00,0x00,0x00},/*"7",23*/
{0x00,0x00,0x0E,0x38,0x11,0x44,0x10,0x84,0x10,0x84,0x11,0x44,0x0E,0x38,0x00,0x00},/*"8",24*/
{0x00,0x00,0x07,0x00,0x08,0x8C,0x10,0x44,0x10,0x44,0x08,0x88,0x07,0xF0,0x00,0x00},/*"9",25*/
{0x00,0x00,0x00,0x00,0x00,0x00,0x03,0x0C,0x03,0x0C,0x00,0x00,0x00,0x00,0x00,0x00},/*":",26*/
{0x00,0x00,0x00,0x00,0x00,0x01,0x01,0x06,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00},/*";",27*/
{0x00,0x00,0x00,0x80,0x01,0x40,0x02,0x20,0x04,0x10,0x08,0x08,0x10,0x04,0x00,0x00},/*"<",28*/
{0x02,0x20,0x02,0x20,0x02,0x20,0x02,0x20,0x02,0x20,0x02,0x20,0x02,0x20,0x00,0x00},/*"=",29*/
{0x00,0x00,0x10,0x04,0x08,0x08,0x04,0x10,0x02,0x20,0x01,0x40,0x00,0x80,0x00,0x00},/*">",30*/
{0x00,0x00,0x0E,0x00,0x12,0x00,0x10,0x0C,0x10,0x6C,0x10,0x80,0x0F,0x00,0x00,0x00},/*"?",31*/
{0x03,0xE0,0x0C,0x18,0x13,0xE4,0x14,0x24,0x17,0xC4,0x08,0x28,0x07,0xD0,0x00,0x00},/*"@",32*/
{0x00,0x04,0x00,0x3C,0x03,0xC4,0x1C,0x40,0x07,0x40,0x00,0xE4,0x00,0x1C,0x00,0x04},/*"A",33*/
{0x10,0x04,0x1F,0xFC,0x11,0x04,0x11,0x04,0x11,0x04,0x0E,0x88,0x00,0x70,0x00,0x00},/*"B",34*/
{0x03,0xE0,0x0C,0x18,0x10,0x04,0x10,0x04,0x10,0x04,0x10,0x08,0x1C,0x10,0x00,0x00},/*"C",35*/
{0x10,0x04,0x1F,0xFC,0x10,0x04,0x10,0x04,0x10,0x04,0x08,0x08,0x07,0xF0,0x00,0x00},/*"D",36*/
{0x10,0x04,0x1F,0xFC,0x11,0x04,0x11,0x04,0x17,0xC4,0x10,0x04,0x08,0x18,0x00,0x00},/*"E",37*/
{0x10,0x04,0x1F,0xFC,0x11,0x04,0x11,0x00,0x17,0xC0,0x10,0x00,0x08,0x00,0x00,0x00},/*"F",38*/
{0x03,0xE0,0x0C,0x18,0x10,0x04,0x10,0x04,0x10,0x44,0x1C,0x78,0x00,0x40,0x00,0x00},/*"G",39*/
{0x10,0x04,0x1F,0xFC,0x10,0x84,0x00,0x80,0x00,0x80,0x10,0x84,0x1F,0xFC,0x10,0x04},/*"H",40*/
{0x00,0x00,0x10,0x04,0x10,0x04,0x1F,0xFC,0x10,0x04,0x10,0x04,0x00,0x00,0x00,0x00},/*"I",41*/
{0x00,0x03,0x00,0x01,0x10,0x01,0x10,0x01,0x1F,0xFE,0x10,0x00,0x10,0x00,0x00,0x00},/*"J",42*/
{0x10,0x04,0x1F,0xFC,0x11,0x04,0x03,0x80,0x14,0x64,0x18,0x1C,0x10,0x04,0x00,0x00},/*"K",43*/
{0x10,0x04,0x1F,0xFC,0x10,0x04,0x00,0x04,0x00,0x04,0x00,0x04,0x00,0x0C,0x00,0x00},/*"L",44*/
{0x10,0x04,0x1F,0xFC,0x1F,0x00,0x00,0xFC,0x1F,0x00,0x1F,0xFC,0x10,0x04,0x00,0x00},/*"M",45*/
{0x10,0x04,0x1F,0xFC,0x0C,0x04,0x03,0x00,0x00,0xE0,0x10,0x18,0x1F,0xFC,0x10,0x00},/*"N",46*/
{0x07,0xF0,0x08,0x08,0x10,0x04,0x10,0x04,0x10,0x04,0x08,0x08,0x07,0xF0,0x00,0x00},/*"O",47*/
{0x10,0x04,0x1F,0xFC,0x10,0x84,0x10,0x80,0x10,0x80,0x10,0x80,0x0F,0x00,0x00,0x00},/*"P",48*/
{0x07,0xF0,0x08,0x18,0x10,0x24,0x10,0x24,0x10,0x1C,0x08,0x0A,0x07,0xF2,0x00,0x00},/*"Q",49*/
{0x10,0x04,0x1F,0xFC,0x11,0x04,0x11,0x00,0x11,0xC0,0x11,0x30,0x0E,0x0C,0x00,0x04},/*"R",50*/
{0x00,0x00,0x0E,0x1C,0x11,0x04,0x10,0x84,0x10,0x84,0x10,0x44,0x1C,0x38,0x00,0x00},/*"S",51*/
{0x18,0x00,0x10,0x00,0x10,0x04,0x1F,0xFC,0x10,0x04,0x10,0x00,0x18,0x00,0x00,0x00},/*"T",52*/
{0x10,0x00,0x1F,0xF8,0x10,0x04,0x00,0x04,0x00,0x04,0x10,0x04,0x1F,0xF8,0x10,0x00},/*"U",53*/
{0x10,0x00,0x1E,0x00,0x11,0xE0,0x00,0x1C,0x00,0x70,0x13,0x80,0x1C,0x00,0x10,0x00},/*"V",54*/
{0x1F,0xC0,0x10,0x3C,0x00,0xE0,0x1F,0x00,0x00,0xE0,0x10,0x3C,0x1F,0xC0,0x00,0x00},/*"W",55*/
{0x10,0x04,0x18,0x0C,0x16,0x34,0x01,0xC0,0x01,0xC0,0x16,0x34,0x18,0x0C,0x10,0x04},/*"X",56*/
{0x10,0x00,0x1C,0x00,0x13,0x04,0x00,0xFC,0x13,0x04,0x1C,0x00,0x10,0x00,0x00,0x00},/*"Y",57*/
{0x08,0x04,0x10,0x1C,0x10,0x64,0x10,0x84,0x13,0x04,0x1C,0x04,0x10,0x18,0x00,0x00},/*"Z",58*/
{0x00,0x00,0x00,0x00,0x00,0x00,0x7F,0xFE,0x40,0x02,0x40,0x02,0x40,0x02,0x00,0x00},/*"[",59*/
{0x00,0x00,0x30,0x00,0x0C,0x00,0x03,0x80,0x00,0x60,0x00,0x1C,0x00,0x03,0x00,0x00},/*"\",60*/
{0x00,0x00,0x40,0x02,0x40,0x02,0x40,0x02,0x7F,0xFE,0x00,0x00,0x00,0x00,0x00,0x00},/*"]",61*/
{0x00,0x00,0x00,0x00,0x20,0x00,0x40,0x00,0x40,0x00,0x40,0x00,0x20,0x00,0x00,0x00},/*"^",62*/
{0x00,0x01,0x00,0x01,0x00,0x01,0x00,0x01,0x00,0x01,0x00,0x01,0x00,0x01,0x00,0x01},/*"_",63*/
{0x00,0x00,0x40,0x00,0x40,0x00,0x20,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00},/*"`",64*/
{0x00,0x00,0x00,0x98,0x01,0x24,0x01,0x44,0x01,0x44,0x01,0x44,0x00,0xFC,0x00,0x04},/*"a",65*/
{0x10,0x00,0x1F,0xFC,0x00,0x88,0x01,0x04,0x01,0x04,0x00,0x88,0x00,0x70,0x00,0x00},/*"b",66*/
{0x00,0x00,0x00,0x70,0x00,0x88,0x01,0x04,0x01,0x04,0x01,0x04,0x00,0x88,0x00,0x00},/*"c",67*/
{0x00,0x00,0x00,0x70,0x00,0x88,0x01,0x04,0x01,0x04,0x11,0x08,0x1F,0xFC,0x00,0x04},/*"d",68*/
{0x00,0x00,0x00,0xF8,0x01,0x44,0x01,0x44,0x01,0x44,0x01,0x44,0x00,0xC8,0x00,0x00},/*"e",69*/
{0x00,0x00,0x01,0x04,0x01,0x04,0x0F,0xFC,0x11,0x04,0x11,0x04,0x11,0x00,0x18,0x00},/*"f",70*/
{0x00,0x00,0x00,0xD6,0x01,0x29,0x01,0x29,0x01,0x29,0x01,0xC9,0x01,0x06,0x00,0x00},/*"g",71*/
{0x10,0x04,0x1F,0xFC,0x00,0x84,0x01,0x00,0x01,0x00,0x01,0x04,0x00,0xFC,0x00,0x04},/*"h",72*/
{0x00,0x00,0x01,0x04,0x19,0x04,0x19,0xFC,0x00,0x04,0x00,0x04,0x00,0x00,0x00,0x00},/*"i",73*/
{0x00,0x00,0x00,0x03,0x00,0x01,0x01,0x01,0x19,0x01,0x19,0xFE,0x00,0x00,0x00,0x00},/*"j",74*/
{0x10,0x04,0x1F,0xFC,0x00,0x24,0x00,0x40,0x01,0xB4,0x01,0x0C,0x01,0x04,0x00,0x00},/*"k",75*/
{0x00,0x00,0x10,0x04,0x10,0x04,0x1F,0xFC,0x00,0x04,0x00,0x04,0x00,0x00,0x00,0x00},/*"l",76*/
{0x01,0x04,0x01,0xFC,0x01,0x04,0x01,0x00,0x01,0xFC,0x01,0x04,0x01,0x00,0x00,0xFC},/*"m",77*/
{0x01,0x04,0x01,0xFC,0x00,0x84,0x01,0x00,0x01,0x00,0x01,0x04,0x00,0xFC,0x00,0x04},/*"n",78*/
{0x00,0x00,0x00,0xF8,0x01,0x04,0x01,0x04,0x01,0x04,0x01,0x04,0x00,0xF8,0x00,0x00},/*"o",79*/
{0x01,0x01,0x01,0xFF,0x00,0x85,0x01,0x04,0x01,0x04,0x00,0x88,0x00,0x70,0x00,0x00},/*"p",80*/
{0x00,0x00,0x00,0x70,0x00,0x88,0x01,0x04,0x01,0x04,0x01,0x05,0x01,0xFF,0x00,0x01},/*"q",81*/
{0x01,0x04,0x01,0x04,0x01,0xFC,0x00,0x84,0x01,0x04,0x01,0x00,0x01,0x80,0x00,0x00},/*"r",82*/
{0x00,0x00,0x00,0xCC,0x01,0x24,0x01,0x24,0x01,0x24,0x01,0x24,0x01,0x98,0x00,0x00},/*"s",83*/
{0x00,0x00,0x01,0x00,0x01,0x00,0x07,0xF8,0x01,0x04,0x01,0x04,0x00,0x00,0x00,0x00},/*"t",84*/
{0x01,0x00,0x01,0xF8,0x00,0x04,0x00,0x04,0x00,0x04,0x01,0x08,0x01,0xFC,0x00,0x04},/*"u",85*/
{0x01,0x00,0x01,0x80,0x01,0x70,0x00,0x0C,0x00,0x10,0x01,0x60,0x01,0x80,0x01,0x00},/*"v",86*/
{0x01,0xF0,0x01,0x0C,0x00,0x30,0x01,0xC0,0x00,0x30,0x01,0x0C,0x01,0xF0,0x01,0x00},/*"w",87*/
{0x00,0x00,0x01,0x04,0x01,0x8C,0x00,0x74,0x01,0x70,0x01,0x8C,0x01,0x04,0x00,0x00},/*"x",88*/
{0x01,0x01,0x01,0x81,0x01,0x71,0x00,0x0E,0x00,0x18,0x01,0x60,0x01,0x80,0x01,0x00},/*"y",89*/
{0x00,0x00,0x01,0x84,0x01,0x0C,0x01,0x34,0x01,0x44,0x01,0x84,0x01,0x0C,0x00,0x00},/*"z",90*/
{0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x00,0x3E,0xFC,0x40,0x02,0x40,0x02},/*"{",91*/
{0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xFF,0xFF,0x00,0x00,0x00,0x00,0x00,0x00},/*"|",92*/
{0x00,0x00,0x40,0x02,0x40,0x02,0x3E,0xFC,0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00},/*"}",93*/
{0x00,0x00,0x60,0x00,0x80,0x00,0x80,0x00,0x40,0x00,0x40,0x00,0x20,0x00,0x20,0x00},/*"~",94*/
};
#endif
-
mcu
+關注
關注
146文章
17797瀏覽量
359498 -
RGB
+關注
關注
4文章
803瀏覽量
59525 -
TFT
+關注
關注
10文章
388瀏覽量
112117
發布評論請先 登錄
2.8寸屏下載程序后按復位瞬間屏亮了下,后面就黑了
TFTLCD顯示實驗寫入程序后屏幕閃一下就不亮了是怎么回事?
「正點原子STM32Mini板資料連載」第十六章 TFTLCD 顯示實驗
TFTLCD顯示實驗的寄存器歷程出現錯誤
「正點原子NANO STM32開發板資料連載第二十五章 TFTLCD 顯示實驗
如何用stm32f101CBT6控制顯示LCD?
「ALIENTEK 探索者 STM32F407 開發板資料連載」第十八章 TFTLCD 顯示實驗
開發板的顯示屏怎么設置一開機就顯示?
ALIENTEK_MINISTM32_實驗10_TFT_LCD顯示
進行TFT LCD顯示實驗GUI移植完成和4.3電容屏的詳細資料合集

STM32入門學習筆記之TFTLCD顯示實驗1

評論