AT89S51單片機(jī)驅(qū)動(dòng)3.5寸TFT模塊的設(shè)計(jì)
掃描二維碼
隨時(shí)隨地手機(jī)看文章
前市場(chǎng)流行的3.5寸屏基本上都是只內(nèi)置了驅(qū)動(dòng)器,而不帶控制器,這樣給用戶的使用造成了一些難度。基本上很多朋友在用彩屏?xí)r選擇一些帶LCD控制器的ARM7或ARM9去開發(fā),對(duì)于不會(huì)ARM開發(fā)的朋友來說,只使用普通MCU,這樣可以選擇的3.5寸TFT模塊,就很難找到了。
本文就是基于市場(chǎng)上一款比較使用的3.5寸TFT模塊編寫的,用戶只需要幫該TFT模塊當(dāng)作普通的單色液晶的開發(fā)思路來使用,就可以很容易去編程。
一、 硬件選擇
1、 MCU:AT89S51
2、 開發(fā)編譯環(huán)境:KeilC51
3、 3.5寸TFT模塊型號(hào):MzT35C1
二、 TFT模塊基本性能:
1、基本參數(shù)
模塊結(jié)構(gòu): 內(nèi)置控制器
屏幕大?。?3.5英寸
屏幕分辯率:320*240
屏幕顏色數(shù):65536色(16位真彩色)
工作電壓: 3.3V/5V可選
總線結(jié)構(gòu):Intel8080
總線寬度: 8Bit
背光形式: LED;可指令控制,0-127可調(diào)
連接方式: 排針插座
觸摸屏:標(biāo)準(zhǔn)配置不帶觸摸屏;模組留有觸摸屏芯片焊盤和觸摸屏接口
2、接口引腳說明
接口引腳
說明
VCC
模塊供電電源輸入(一般無特殊要求為5V)
D0~D7
8位數(shù)據(jù)總線
CS
片選(低電平有效)
RST
Reset復(fù)位(低電平復(fù)位)
A0
控制寄存器/數(shù)據(jù)寄存器選擇(低電平選擇控制寄存器)
WE
寫信號(hào)(低電平有效)
RD
讀信號(hào)(低電平有效)
GND
接地
S_CS
預(yù)留有ADS7846的片選
S_SCK
預(yù)留有ADS7846的SPI時(shí)鐘輸入
S_SDO
預(yù)留有ADS7846的SPI數(shù)據(jù)輸出
S_SDI
預(yù)留有ADS7846的SPI數(shù)據(jù)輸入
S_INT
預(yù)留有ADS7846的INT信號(hào)
S_BUSY
預(yù)留有ADS7846的BUSY信號(hào)
3、操作時(shí)序(8位并行Intel 8080總線)
MzT35C1模塊支持intel8080總線,總線的最高速度可達(dá)20MHz(當(dāng)然總線的速度能否達(dá)到最高接口速度,還與用戶的總線布線、線長(zhǎng)等有關(guān)),也就是說,如果控制MCU速度足夠快的話,是可以支持視頻的顯示的。
注意:MzT35C1模塊的總線接口是8位的,也就意味著對(duì)顯存的數(shù)據(jù)操作時(shí),需要連續(xù)進(jìn)行兩次操作方可完成,先傳高字節(jié)再傳低字節(jié);但對(duì)于寄存器的操作(寫入寄存器地址,即A0為低時(shí)的寫入操作)8位的操作方可。
三、MzT35C1與51硬件接口連接圖
本例程使用GPIO來模擬總線時(shí)序。上圖的模塊供電為5V的模塊,而模塊的端口電平為3.3V的,所以在所有的51端口與模塊間的連接串入了一個(gè)100歐的電阻,有關(guān)MCS51的其它電路不在圖中畫出,請(qǐng)用戶具體參考其它的開發(fā)板文檔進(jìn)行了解。而圖中的MzT35C1模塊的相關(guān)引腳請(qǐng)以實(shí)物為準(zhǔn),圖中僅示意對(duì)應(yīng)的名稱的端口,請(qǐng)用戶在參考使用時(shí)注意。
三、 底層驅(qū)動(dòng)代碼編寫方法
1、 端口配置
#i nclude “REG52.h”
#i nclude “intrins.h” //包含此頭文件可直接操作內(nèi)核的寄存器以及一些定義好的宏
#define LCD_CTRl_GPIO() //無定義
#define LCD_Ctrl_Out() LCD_CS_SET();LCD_RD_SET();LCD_RW_SET();
#define LCD_Ctrl_Set(n) //無定義
#define LCD_Ctrl_Clr(n) //無定義
sbit LCD_CS = P2^6;
#define LCD_CS_SET() LCD_CS = 1
#define LCD_CS_CLR() LCD_CS = 0
sbit LCD_RE = P3^5;
#define LCD_RE_SET() LCD_RE = 1
#define LCD_RE_CLR() LCD_RE = 0
sbit LCD_A0 = P2^5;
#define LCD_A0_SET() LCD_A0 = 1
#define LCD_A0_CLR() LCD_A0 = 0
sbit LCD_RW = P3^6;
#define LCD_RW_SET() LCD_RW = 1
#define LCD_RW_CLR() LCD_RW = 0
sbit LCD_RD = P3^7;
#define LCD_RD_SET() LCD_RD = 1
#define LCD_RD_CLR() LCD_RD = 0
#define LCD_Data_GPIO() //51的端口是雙向的,無需特意規(guī)定方向,故無定義
#define LCD_Data_Out() //51的端口是雙向的,無需特意規(guī)定方向,故無定義
#define LCD_Data_In() P0 = 0xff //51的端口要讀數(shù)據(jù)前需要先輸出0xff
#define LCD_Data_BUS_Clr() //無定義
#define LCD_Data_BUS_Set(n) P0 = n
#define LCD_Data_Read() P0
2、寫數(shù)據(jù)和指令操作
//==============================================
// 函數(shù): void LCD_DataWrite(unsigned int Data)
// 描述: 寫一個(gè)字(16bit)的顯示數(shù)據(jù)至LCD中的顯示緩沖RAM當(dāng)中
// 參數(shù): Data 寫入的數(shù)據(jù)
//=============================================
#defineLCD_DataWrite(n) LCD_A0_SET();LCD_CS_CLR();LCD_Data_BUS_Clr();LCD_Data_BUS_Set((unsigned char)(n》》8));
LCD_RW_CLR();LCD_RW_SET();LCD_Data_BUS_Clr();LCD_Data_BUS_Set((unsigned char)n);LCD_RW_CLR(); LCD_RW_SET();LCD_CS_SET()
//=====================================================
// 函數(shù): void LCD_RegWrite(unsigned char Addr,unsigned int Command)
// 描述: 寫一個(gè)字節(jié)的數(shù)據(jù)至LCD中的控制寄存器當(dāng)中
// 參數(shù): Addr 要寫入的寄存器的地址,低八位有效(byte)
// Command 寫入的數(shù)據(jù)
//=====================================================
#define LCD_RegWrite(n)
LCD_A0_CLR();LCD_CS_CLR();LCD_Data_BUS_Clr();LCD_Data_BUS_Set(n);
LCD_RW_CLR();LCD_RW_SET();LCD_CS_SET()
2、 讀數(shù)據(jù)操作
//=============================================
// 函數(shù): LCDBYTE LCD_DataRead(void)
// 描述: 從LCD中的顯示緩沖RAM當(dāng)中讀一個(gè)字節(jié)的顯示數(shù)據(jù)
// 參數(shù): 無
// 返回: 讀出的數(shù)據(jù),
// 備注: Mz 通用版LCD驅(qū)動(dòng)程序 標(biāo)準(zhǔn)子函數(shù)
//===========================================
LCDBYTE LCD_DataRead(void)
{
LCDBYTE Read_Data;
LCD_Data_In();
LCD_A0_SET();
LCD_CS_CLR();
LCD_RD_CLR();
LCD_RD_SET();
LCD_RD_CLR();
LCD_RD_SET(); //前面的操作是要完成一次完整的空讀操作后方能讀取到數(shù)據(jù)
//如果用戶需要連續(xù)讀取顯存,側(cè)僅需要在第一次讀數(shù)據(jù)時(shí)作一
//次空讀操作即可
LCD_RD_CLR();
Read_Data = LCD_Data_Read();
Read_Data = Read_Data《《8;
LCD_RD_SET();
LCD_RD_CLR();
Read_Data |= LCD_Data_Read();
LCD_RD_SET();
LCD_CS_SET();
LCD_Data_Out();
return Read_Data;
}
3、 初始化TFT操作
void LCD_Init(void)
{
// FLASH *Init_String;
//LCD驅(qū)動(dòng)所使用到的端口的初始化
LCD_PortInit();
//根據(jù)LCD顯示的配置,設(shè)置LCD的數(shù)據(jù)地址指針自動(dòng)增加特性
//end
LCD_RE_CLR();
TImeDelay(5);
LCD_RE_SET();
LCD_RegWrite(0x03);
LCD_DataWrite((1《《7)| (0x60《《0)); //設(shè)置背光控制使能、背光亮度等級(jí)為60(0~127)
LCD_RegWrite(0x04); //寫系統(tǒng)寄存器
// LCD_DataWrite((0《《7)| //當(dāng)前顯示頁(yè)
// (0《《6) | //當(dāng)前讀寫頁(yè)設(shè)置
// (1《《0)); //顯示開關(guān)
LCD_DataWrite(MzT35_Ctrl_Reg);
/* Init_String = IniTIal_Tab;
while(Init_String!=0xffff)
{
LCD_RegWrite(0x05);LCD_DataWrite(*Init_String++);
LCD_RegWrite(0x06);LCD_DataWrite(*Init_String++);
}*/
LCD_Fill(LCD_INITIAL_COLOR);
}