您的位置 首页 嵌入式

STM8单片机对LCD模块的驱动

STM8单片机对LCD模块的驱动-STM8L152XX系列带有片上段式LCD驱动程序,这为低成本应用和高密度系统设计提供了保证,利用片上LCD驱动模块,可以有效的控制系统整体功耗,简化系统结构,从整体来说可靠性得到提高。

STM8L152XX系列带有片上段式LCD驱动程序,这为低成本运用和高密度体系规划供给了确保,运用片上LCD驱动模块,能够有用的操控体系全体功耗,简化体系结构,从全体来说可靠性得到进步。

此处不介绍LCD驱动模块的原理以及驱动时序,请参阅STM8原版英文阐明文档,已描绘的很具体,以下介绍其寄存器的装备办法以及编程办法。

时钟,体系时钟相同用来发生LCD驱动时钟,经过时钟模块装备:

CLK_PCKENR2|=S3; //LCD 使能LCD模块时钟

CLK_CRTCR=S7|S6|S5|S1; //RTC&LCD-》FCLK/128 留意RTC和LCD是一起一路时钟

以上装备依据实践时钟进行调整,我在此处选用FCLK=HSI=16MHZ,所以LCDclk=16M/128=125KHZ

我的LCD为六个数字的段式LCD,1/3偏压办法,4根COM线,12根COM线,这两个参数请读者自己查找自己的LCD材料找到,关于驱动LCD来说这两个参数最重要,以下为寄存器装备:

LCD_CR1=S5|S2|S1;//1/3偏压1/4占空比

LCD_CR2=S6|S4|S0;//3.3V

LCD_FRQ=5《《4;//FCK=125000/2^5*16=128000/512=244Frame=244/4=61HZ

LCD_PM0=0xFF;

LCD_PM1=0x0F;

LCD_CR3|=S6;

首先由偏压办法决议了驱动到LCD段码上的电压品种,占空比(规范并非如此翻译)Duty值决议扫过每根COM线的时序份额,因为我将VLCD与VCC接在一起了,所以挑选外部电源参阅3.3V,若挑选内部,则能够进一步挑选最高输出电压巨细,实测发现选大些对比度可进步一些。LCD_FRQ用于装备扫描更新频率,具体核算不想说,文档里都有。终究是装备那些接在LCD上的COM线和SEG线为LCD驱动复用有用形式,不然仍能够作为IO口运用,终究敞开LCD驱动模块扫描。

装备完以上寄存器之后,LCD模块已开端作业,它是经过从LCD_RAM0-LCD_RAM12这一组寄存器来操控显现内容的,这时向LCD_RAM0-LCD_RAM12写入数据会发现有段码显现在LCD上,作为运用层,需求找到这种联系。

查手里这块LCD材料列出段码表如下所示:

/*—————————————————–

SEG:01234567891011

1DX22DX33DX14D4P5D5P6D6P

1E1C2E2C3E3C4E4C5E5C6E6C

1G1B2G2B3G3B4G4B5G5B6G6B

1F1A2F2A3F3A4F4A5F5A6F6A

CODE:AFBGCEPD

—————————————————–*/

所以我把一个字节最高位至最低位从A段到D段按如上CODE次序进行摆放,并得到段表码如下:

constuint8LCD_CodeTable[]={0xED,0x28,0xB5,0xB9,0x78,0xD9,0xDD,0xA8,0xFD,0xF9,0xFC,0x5D,0x15,0x3D,0xD5,0xD4,0x5C,0x10,0xC5,0xA9,0x00};这些段码表别离对应于以下字符:0,1,2,3,4,5,6,7,8,9,A,b,c,d,E,F,h,-,[,],[注,终究一个为空格]为编程便利,我对字符进行编码:A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U[顺次和上面的字符相对应]为六个字符界说显现内容缓冲区:uint8LCD_DisplayBuffer[6];voidLCD_SetSegValue(void)

{

uint16T,SEG[4];

uint8i,j,Code[6];

for(i=0;i《6;i++){

Code[5-i]=LCD_CodeTable[LCD_DisplayBuffer[i]&0x7F];

if(LCD_DisplayBuffer[i]&0x80)Code[5-i]|=0x02;

}

for(i=0;i《4;i++){

for(T=0,j=0;j《6;j++){

T《《=2;

T|=(Code[j]&0x03);

Code[j]》》=2;

}

SEG[i]=T;

}

LCD_RAM0=(uint8)(SEG[0]);//COM0-》B[7:0]

LCD_RAM1=(uint8)(SEG[0]》》8);//COM0-》B[11:8]

LCD_RAM3=(uint8)(SEG[1]《《4);//COM1-》B[3:0]-》H

LCD_RAM4=(uint8)(SEG[1]》》4);//COM1-》B[11:4]

LCD_RAM7=(uint8)(SEG[2]);//COM2-》B[7:0]

LCD_RAM8=(uint8)(SEG[2]》》8);//COM2-》B[11:8]

LCD_RAM10=(uint8)(SEG[3]《《4);//COM3-》B[3:0]-》H

LCD_RAM11=(uint8)(SEG[3]》》4);//CoM3-》B[11:4]

}

以上这段程序将LCD_DisplayBuffer[]中的六个字符解码后写入LCD模块的显现缓冲区中,终究显现成相应字符,这其顶用每个字符的最高位代表是否含有小数点位,若为高则点亮适当的小数点,不然封闭。至于LCD_RAM的更新和拆分办法,此外不再描绘,文档中已适当具体。

环绕以上改写程序,可得到如下常用办法:

//清显现

voidLCD_Clear(uint8Index)

{

uint8i;

if(Index==0xFF)for(i=0;i《6;i++)LCD_DisplayBuffer[i]=‘U’-‘A’;

elseLCD_DisplayBuffer[Index]=‘U’-‘A’;

LCD_SetSegValue();

}

//写显现缓冲区点

voidLCD_ShowSpecial(uint8Saddr,uint8Char)

{

if(Char》0)LCD_DisplayBuffer[Saddr]|=0x80;

elseLCD_DisplayBuffer[Saddr]&=0x7F;

}

//显现字符

voidLCD_ShowChar(uint8Saddr,uint8Char)

{

LCD_DisplayBuffer[Saddr]&=0x80;

LCD_DisplayBuffer[Saddr]|=Char;

LCD_SetSegValue();

}

//显现字符串

voidLCD_ShowString(uint8Saddr,void*Text)

{

uint8T,P,*Str;

Str=(uint8*)Text;

while(*Str》0){

T=*Str++;

P=LCD_DisplayBuffer[Saddr];

LCD_DisplayBuffer[Saddr++]=(P&0x80)|(T-‘A’);

}

LCD_SetSegValue();

}

//显现数字

voidLCD_ShowNumber(uint8Saddr,uint16Number,uint8Length)

{

uint8P;

Saddr+=Length-1;

while(Length–){

P=LCD_DisplayBuffer[Saddr];

LCD_DisplayBuffer[Saddr]=(P&0x80)|(Number%10);

Saddr–;Number/=10;

}

LCD_SetSegValue();

}

由以上函数库,能够便利的显现出如LCD_ShowString(0,“BCDEF”)(显现“12345“),LCD_ShowNumber(0,1244,4)(显现”1244“),等等。合作一些简略的数据结构,便可得到一个相对复杂点的菜单操作界面。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qianrushi/346337.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部