導航:首頁 > 操作系統 > lcd12864與單片機連接

lcd12864與單片機連接

發布時間:2024-07-26 07:36:55

㈠ LCD 12864怎樣和單片機連接

液晶顯示技術是近代電子技術的一種高新技術產物。液晶顯示器具有厚度薄、適於大規模集成電路直接驅動、易於實現全彩色顯示的特點,液晶顯示的原理是利用液晶的物理特性,通過電壓對其顯示區域進控制,有電壓區域顯示黑色,這樣就可以顯示出圖形。

CD 12864液晶屏工作電壓+3.0V~+5.5V,邏輯電平與單片機兼容,能夠直接與單片機的IO口連接,12864液晶屏的介面方式有並行4位、並行8位、串列2線和串列3線,以適應不同的應用場合。

串列分為三線和四線的.合並沒有多大的區別,只是用一條數據線一條時鍾線一個選擇線就行了.其它一樣,輸出控制量dat了,而使用I2C控制就不同了,確定總模擬線數據傳輸介面、模擬時鍾介面,匯流排啟動、匯流排應答、匯流排停止、匯流排發送單位元組、匯流排發送數據等等許多模擬時序的問題。

(1)lcd12864與單片機連接擴展閱讀:

TFT 生產技術最為核心的部分是光刻工藝,它既是決定產品品質的重要環節,也是影響產品成本的關鍵部分,而在光刻工藝中,最受人們關注的就是掩模版,其質量在很大程度上決定了TFT- LCD 的品質,而其使用數量的減少可有效削減設備投資、縮短生產周期。

隨著 TFT 結構的變化和生產工藝的改進,其製造過程中使用掩模版的數量也在相應地減少。

由此可見,TFT 生產工藝從早期的 8掩模版或 7掩模版光刻工藝發展到普遍採用的5掩模版或 4掩模版光刻工藝,大大地縮減了 TFT- LCD 生產周期和生產成本。

4掩模版光刻工藝已成為業界主流。為了不斷降低生產成本,人們一直在努力探索如何進一步減少光刻工藝流程中掩模版的使用數量。

近年來,一些韓國企業在 3掩模版光刻工藝的開發上取得了突破性進展,並已宣告實現量產,但由於 3掩模版工藝技術難度大、良品率也較低,還在進一步的發展和完善中。

從長遠的發展來看,如果 Inkjet(噴墨)列印技術取得突破,實現無掩模製造才是人們追求的終極目標。

㈡ 怎麼把16腳的LCD12864接到單片機5529的最小系統板上,相應的引腳怎麼接,最好能給段程序

不用那麼多線,直接用串口來控制,並口方式用杜邦線很麻煩。

LCD_CS配置為輸出,3V3電平支持,我用的是Cortex-M0的核,3V3電平完全沒問題。

LCD_CLC也是輸出模式,LCD_DAT也是輸出模式,LCD_RST也是,都配置為上拉電阻模式。

12864的15腳一定要接GND,要不然沒法識別信號電平。

另外不知道你的開發板有沒有5V電源的頭,沒有都換成3.3V也可以,不過屏幕背光看起來很暗。

程序你可以參考:我這個是帶字型檔的12864

WR 代表LCD_DAT

RST 代表LCD_RST

E代表LCD_CLC

RS代表LCD_CS

#include "CPU.h"



void En_Wirte( unsigned char Row , unsigned char Array , const unsigned char *Point); //顯示固定字元

void HZ_Wirte( unsigned char Row , unsigned char Array , unsigned char *Point); //顯示變數字元

void LCD_12864_Pic( unsigned char const *a ); //顯示圖片函數 (a的長度一定要大於64*16) //顯示圖片

void LCD12864_Clear(void); //清屏


unsigned char Display_Buffer[16] ;

/*

****************************************************************************

公 司 :

部 門 : 工程技術部

姓 名 : Gordon Yang

函 數 : int main (void)

功 能 : 主函數

輸 入 :

輸 出 :

|||| 配 套 函 數 ||||

函 數 : 無 ①②③

注 釋 : Noraml_Mode 開機運行的普通模式

Designer_Mode 按上按鈕運行的功能發送模式

Programmer_Mode 按下按鈕程序員調試模式

****************************************************************************

*/


/********************************************************************

* 名稱 : delay()

* 功能 : 延時,延時時間為 100us * t。這是通過軟體延時,有一定誤差。

* 輸入 : t

* 輸出 : 無

***********************************************************************/

static void delay(unsigned int t)

{

unsigned int i,j;

for(i=0; i<t; i++)

for(j=0; j<20; j++);

}


/********************************************************************

* 名稱 : sendbyte()

* 功能 : 按照液晶的串口通信協議,發送數據

* 輸入 : zdata

* 輸出 : 無

***********************************************************************/

void sendbyte(unsigned char zdata)

{

unsigned int i;

for(i=0; i<8; i++)

{

if((zdata << i) & 0x80)

{

WR_H ;

}

else

{

WR_L ;

}

delay(2);

E_L ;

delay(2);

E_H ;

delay(2);

}

}


/********************************************************************

* 名稱 : write_com()

* 功能 : 寫串口指令

* 輸入 : cmdcode

* 輸出 : 無

***********************************************************************/

void write_com(unsigned char cmdcode)

{

RS_H ;

sendbyte(0xf8);

sendbyte(cmdcode & 0xf0);

sendbyte((cmdcode << 4) & 0xf0);

delay(20);

}


/********************************************************************

* 名稱 : write_data()

* 功能 : 寫串口指令

* 輸入 : cmdcode

* 輸出 : 無

***********************************************************************/

void write_data(unsigned char Dispdata)

{

RS_H ;

sendbyte(0xfa);

sendbyte(Dispdata & 0xf0);

sendbyte((Dispdata << 4) & 0xf0);

delay(20);

}


/********************************************************************

* 名稱 : lcdinit()

* 功能 : 初始化函數

* 輸入 : cmdcode

* 輸出 : 無

***********************************************************************/

void lcdinit( void )

{

RST_L ;

delay(1000);

RST_H ;

delay(2000);

write_com(0x30);

delay(50);

write_com(0x0c);

delay(50);

LCD12864_Clear();

delay(50);

}


/********************************************************************

* 名稱 : hzkdis()

* 功能 : 顯示字元串

* 輸入 : *s

* 輸出 : 無

***********************************************************************/

void hzkdis(unsigned char *s)

{

while(*s > 0)

{

write_data(*s);

s++;

delay(20);

}

}

/********************************************************************

* 名稱 : HZ_Wirte()

* 功能 : 顯示漢字的函數

* 輸入 : 無

* 輸出 : 無

***********************************************************************/

void HZ_Wirte( unsigned char Row , unsigned char Array , unsigned char *Point)

{

unsigned char Buffer_Array , Buffer_Row , Buffer_Counter ;

Buffer_Array = Array ;

Buffer_Row = Row ;

if( Buffer_Row >= 3 ) Buffer_Row = 3 ;

if( Buffer_Array >= 7) Buffer_Array = 7 ;

write_com(0x03);

delay(50);

switch( Buffer_Row )

{

case(0):

{

write_com( 0x80 + Buffer_Array );

}break;

case(1):

{

write_com( 0x90 + Buffer_Array );

}break;

case(2):

{

write_com( 0x88 + Buffer_Array );

}break;

case(3):

{

write_com( 0x98 + Buffer_Array );

}break;

default:

{

;

}break;

}

Buffer_Array = Buffer_Array * 2 ;

for( Buffer_Counter = 16 - Buffer_Array ; Buffer_Counter > 0 ; Buffer_Counter-- )

{

write_data( *Point );

Point++;

}

}

/********************************************************************

* 名稱 : En_Wirte()

* 功能 : 顯示英文和數字的函數

* 輸入 : 無

* 輸出 : 無

***********************************************************************/

void En_Wirte( unsigned char Row , unsigned char Array , const unsigned char *Point)

{

unsigned char Buffer_Array , Buffer_Row , Buffer_Counter ;

Buffer_Array = Array ;

Buffer_Row = Row ;

if( Buffer_Row >= 3 ) Buffer_Row = 3 ;

if( Buffer_Array >= 15) Buffer_Array = 15 ;

write_com(0x03);

delay(50);

switch( Buffer_Row )

{

case(0):

{

write_com( 0x80 + Buffer_Array );

}break;

case(1):

{

write_com( 0x90 + Buffer_Array );

}break;

case(2):

{

write_com( 0x88 + Buffer_Array );

}break;

case(3):

{

write_com( 0x98 + Buffer_Array );

}break;

default:

{

;

}break;

}

for( Buffer_Counter = 16 - Buffer_Array ; Buffer_Counter > 0 ; Buffer_Counter-- )

{

write_data( *Point );

Point++;

}

}


/*LCD12864 清屏*/

void LCD12864_Clear(void)

{

write_com(0x01); //清屏指令

delay(1000); //延時1.6ms

}


void LCD_12864_Pic( unsigned char const *a ) //顯示圖片函數 (a的長度一定要大於64*16)

{

unsigned char i,j,k,temp;

write_com(0x34);//擴充指令

write_com(0x36);//繪圖顯示開

delay(1); //對於1T單片機來說這條延時很關鍵 普通單片機可以不加這條

for(i=0;i<2;i++)

{

if(i==0) //畫上半屏

temp=0;

else

temp=8; //畫下半屏

for(j=0;j<32;j++)

{

write_com((0x80+j)); //設置垂直地址(以位為單位,對應的行號)

write_com((0x80+temp));//設置水平地址(以位元組單位,對應的列號)指針可自增

for(k=0;k<16;k++)

{

write_data(*a++);

}

}

}

write_com(0x30);//基本指令

}


/***********************************************************

函數名: drawPoint

函數說明:畫點

傳入參數:打點位置(x0,y0);color=1,點亮;color=0,擦除

傳出參數:無

返回值: 無

**********************************************************/

void drawPoint(unsigned char x,unsigned char y,unsigned char color)

{

unsigned char row,collum,cbite;

unsigned char tempH = 0 ,tempL = 0 ;

write_com(0x34);//擴充指令

write_com(0x36);//繪圖顯示開

collum = x>>4;

cbite = x&0x0f;

if( color > 1 ) color = 1 ;

if(y<32)

{

row = y ;

}

else

{

row = y - 32 ;

collum += 8 ;

}

write_com(0x80+row);

write_com(0x80+collum);

if (color)

{

if(cbite<8)

{

tempH|=(1<<(7-cbite));

}

else

{

tempL|=(1<<(15-cbite));

}

}

else

{

if(cbite<8)

{

tempH&=~(1<<(7-cbite));

}

else

{

tempL&=~(1<<(15-cbite));

}

}

write_data(tempH);

write_data(tempL);

write_com(0x30);

}

㈢ 51單片機最小系統板上怎麼連接12864屏幕啊。。有些插孔沒有註明

最小系統板上,都留出單片機的全部引腳了,可以隨便接到任一個引腳。而LCD12864與單片機的連接是可以隨便接的。只要能知道是單片機的哪個l/O腳,與LCD的什麼腳連接了就行的,程序中就能用sbit 定義引腳了。

㈣ 關於單片機液晶屏LCD12864的程序

/*****************************************************************

*程序名稱:帶漢字型檔的12864液晶顯示模塊驅動

*程序功能:顯示字元 、漢字和圖片

*開發工具:Kile

* MCU型號:AT89S52-24PU

*時鍾頻率:11.0592MHZ

*程序作者:yuan

*版權說明:yuan

*****************************************************************/
#include<reg52.h>
#include "lcd.h"
#include "util.h"

sbit E=P1^5;//脈沖使能
sbit RW=P1^6;//讀寫選擇
sbit RS=P1^7;//數據命令選擇
sbit rst=P3^6;//12864復位

// 延時ms函數:

// 12864檢查狀態函數:
void Check12864State(void)
{

P0=0xff;
E=0;//讀狀態前三控制線的狀態
RS=0;
RW=1;
E=1;//拉高,讀狀態
while((P0&0x80)==0x80);//等待空閑
E=0;//寫命令後三控制線的狀態
RS=1;
RW=0;

}

// 12864寫命令函數:
void Write12864Command( unsigned char com)
{

Check12864State();//檢查狀態
P0=com;//賦值
E=0;//寫命令前三控制線的狀態
RS=0;
RW=0;
E=1;//拉高,寫命令
E=0;//寫命令後三控制線的狀態
RS=1;
RW=1;

}

//12864寫數據函數:
void Write12864Data( unsigned char dat)
{

Check12864State();//檢查狀態
P0=dat;//賦值
E=0;//寫數據前三控制線的狀態
RS=1;
RW=0;
E=1;//拉高,寫數據
E=0;//寫數據後三控制線的狀態
RS=0;
RW=1;

}

//在指定的位置顯示字元串(漢字和ASCII碼字元)函數:
void LCD12864DisplayString( unsigned char y,unsigned char x, unsigned char *pstr)
//y-行數值0-3,x-列數值0-7,pstr-字元串指針
//12864可以顯示32個漢字(四行每行8個),一個地址對應一個漢字
//可以顯示64個ASCII碼字元(四行每行16個),一個地址對應兩個字元
//為了實現自動換行功能,這個函數比較繁瑣
{

unsigned char row,n=0;
Write12864Command(0x30);//基本指令
Write12864Command(0x06);//地址計數器自動加以,游標右移
switch(y)//根據行號選擇行地址
{

case 0:row=0x80;break;//第一行首地址
case 1:row=0x90;break;//第二行首地址
case 2:row=0x88;break;//第三行首地址
case 3:row=0x98;break;//第四行首地址
default:;

}

Write12864Command(row+x);//寫地址
while(*pstr!='\0')
{

Write12864Data(*pstr);//寫字元
pstr++;
n++;//計數
if((n+x*2)==16)//如果一行寫完 ,繼續寫第二行
{
if(y==0) Write12864Command(0x90);//寫下一行地址
else if(y==1) Write12864Command(0x88);//寫下一行地址
else if(y==2) Write12864Command(0x98);//寫下一行地址
else ;

}
else if((n+x*2)==32)//如果第二行寫完 ,繼續寫第三行
{

if(y==0) Write12864Command(0x88);//寫下一行地址
else if(y==1) Write12864Command(0x98);//寫下一行地址
else ;
}

else if((n+x*2)==48)//如果第三行寫完 ,繼續寫第四行
{
if(y==0) Write12864Command(0x98);//寫下一行地址
else ;
}
else ;
}

}

//圖片模式清屏函數:
void Clear12864Screen()
{

unsigned char i,j;
Write12864Command(0x34);//功能設定:8位控制方式,使用擴充指令
Write12864Command(0x36);//使用擴充指令,繪圖顯示控制
for(i=0;i<32;i++)

//ST7920可控制256*32點陣(32行256列),而12864液晶實際的行地址只有0-31行,

//12864液晶的32-63行的行是0-31行地址從第128列劃分一半出來的,所以分為上下兩半屏,

//也就是說第0行和第32行同屬一行,行地址相同;第1行和第33行同屬一行,以此類推

{

Write12864Command(0x80|i);//寫行地址(垂直地址)
Write12864Command(0x80);//寫列地址(水平地址)
for(j=0;j<32;j++)
Write12864Data(0x00);//清屏

}

}

//在任意位置顯示任意大小的圖片函數:

void LCD12864DisplayPictrue(unsigned char y,unsigned char x,

unsigned char px,unsigned char py, unsigned char *pp)

//y-起始行(數值0-63),x-起始列(16位寬,數值0-7),

//px-圖片寬度,py-圖片高度,pp-指針指向圖片數組

//因為上下屏的地址不連續,要在任意位置顯示完整的圖像,處理起來比較繁瑣

{

unsigned char i,j,k;
Clear12864Screen();//清屏
if(y<32)//如果起始行在上半屏
{

k=32-y;//算出上半屏的行數
for(i=0;i<k;i++,y++)//上半屏行數
{
Write12864Command(0x80|y);//寫行地址(垂直地址)
Write12864Command(0x80|x);//寫列地址(水平地址)
for(j=0;j<px/8;j++)
Write12864Data(pp[i*px/8+j]);//寫圖片數據

}

y=0;//下半屏起始行,接上半屏繼續寫數據
for(;i<py;i++,y++)//下半屏剩下的行數
{

Write12864Command(0x80|y);//寫行地址(垂直地址)
Write12864Command(0x80|(8+x));//寫列地址(水平地址)
for(j=0;j<px/8;j++)
Write12864Data(pp[i*px/8+j]);//寫圖片數據

}

}

else //如果起始行在下半屏

{

for(i=0;i<py;i++,y++)//行數
{
Write12864Command(0x80|(y-32));//寫行地址(垂直地址)
Write12864Command(0x80|(8+x));//寫列地址(水平地址)
for(j=0;j<px/8;j++)
Write12864Data(pp[i*px/8+j]);//寫圖片數據

}

}

}

void Clear12864Text()
{
Write12864Command(0x34);//清屏
DelayMs(5);
Write12864Command(0x30);//清屏
DelayMs(5);
Write12864Command(0x01);//清屏
DelayMs(5);
}

//12864初始化函數:
void Initialize12864()
{

rst=0;//復位12864
DelayMs(30);
rst=1;
DelayMs(20);
Write12864Command(0x30);//功能設定:8位控制方式,使用基本指令
Write12864Command(0x08);//顯示關
Write12864Command(0x01);//清屏
Write12864Command(0x06);//地址計數器加一、游標右移
Write12864Command(0x0c);//顯示開

}

帶字型檔的驅動

㈤ lcd12864的rs rw en與單片機p0腳相連的時候,要外接上拉電阻嗎

理論上單片機IO口輸出能力不足都要加上拉電阻的,好像我記得51的P0口沒有輸出高電平的能力,需要輸出高電平只能加上拉電阻

閱讀全文

與lcd12864與單片機連接相關的資料

熱點內容
手機抖音app怎麼掃描 瀏覽:107
sde命令 瀏覽:572
紅石pdf 瀏覽:290
榮耀精選app是什麼 瀏覽:240
電腦文件夾九宮格 瀏覽:926
在哪個app上可以訂車票 瀏覽:929
命令語法不正確什麼意思 瀏覽:492
命令調同 瀏覽:908
安卓12最遲要等到什麼時候 瀏覽:74
編譯原理大題及答案 瀏覽:526
androidjava語言開發 瀏覽:451
數獨演算法java 瀏覽:473
手機怎麼復制解壓後的文件 瀏覽:656
gbk轉字元串java 瀏覽:342
遼寧集群伺服器雲空間 瀏覽:30
車載蘋果系統怎麼與安卓系統連接 瀏覽:85
國科方案攝像頭用的什麼APP 瀏覽:300
用30秒壓縮拼圖 瀏覽:175
咸魚app什麼開發的 瀏覽:869
ipad怎麼解壓有密碼的壓縮包 瀏覽:856