段码LCD液晶屏应该怎么驱动?

段码LCD液晶屏应该怎么驱动?,第1张

大家平常在生活之中见到最多的可能就是段码液晶屏了,它有着普通数码管的特征,又有着点阵液晶屏的特征,已经固定的图形,既省成本而且又好看,那么,我们今天来一起试一试!

首先,大家都不要以为使用单片机来驱动,就以为是断码屏直流驱动的了,其实呢,段码屏它是交流驱动的,什么是交流驱动呢?例如矩形波、正弦波等等。大家可能会经常的使用驱动芯片来玩,例如HT1621等等,但是有一些段式屏的IO口是比较少的,或者说是IO口充足的情况之下,也懒得在再去写控制器的驱动了。但是,IO的模拟驱动,段式液晶是有一个前提条件的,就是IO必须要是三态,

为什么?下面我们就一起细细的道来:

第一步:段码液晶屏最重要的参数:占空比、工作电压、偏压比。这三个参数都是非常重要的,都必须要满足。

第二步:驱动的方式:我们根据 LCD 的驱动原理可以知道,LCD的像素点上面只能够加上 AC的电压,LCD显示器的对比度则是由 COM脚上的电压值减去 SEG 脚上的电压值来决定,当这个电压差在大于 LCD 饱和电压时就能够打开像素点,小于 LCD 阈值电压时就能关闭像素点了,LCD 型的MCU 已经由内建的 LCD 驱动电路自动产生出LCD驱动信号了,因此只需要 I/O 口能仿真输出该驱动的信号,就能够完成 LCD 的驱动了。

段码液晶屏主要是有两种引脚,COM和SEG,和数码管比较像,但是,压差必须要是交替变化的,例:第一时刻是正向的3V,那么第二时刻就必须要是反向的3V,注意一点,如果你给段码液晶屏通直流电,那么不用多久这个屏幕就会报废,所以千万要注意。下面我们就来考虑如何模拟COM口的波形,我们以1/4D,1/2B为例子:

段码LCD屏的驱动方法

只要模拟出以上的波形,你的液晶屏就已经成功了一大半。

void display_sub(u8 y) //lcd display subroutine

{

switch(y) //4*com,VDD and -VDD LCD display,so 8 timebase interrupt one sacn period

{

case 1:

{com1_output_high()break}

case 2:

{com1_output_low()break}

case 3:

{com2_output_high()break}

case 4:

{com2_output_low()break}

case 5:

{com3_output_high()break}

case 6:

{com3_output_low()break}

case 7:

{com4_output_high()break}

case 8:

{com4_output_low()break}

default:

{LCDPluseStep=0

get_display_code(AD_Value,KeyScanRetVal)

break}

}

}

复制代码

如上图代码所示,定时到2ms,让4个COM交替的输出波形就可以了。

文章转载于LCD液晶屏:http://www.hzjingxian.com,转载请注明出处

同时我们还要注意,在COM的输出较高的时候,如果要屏幕亮,那么SEG就要输出低,那么在COM输出低的时候,SEG就要输出高了,保证COM和SEG的压差大于1/2B工作电压就可以正常显示了

下面我们看其中一个com口输出时的函数

static void seg1_output(void) //seg1 output subroutine

{

if(1 == (LCDPluseStep%2)) //com_pulse is odd,com output high (VDD)

{

if(0 == (DisplayCode1&0x10))

{SEG1=1}

else

{SEG1=0}

}

else //com_pulse is even,com output low (VSS)

{

if(0 == (DisplayCode1&0x10))

{SEG1=0}

else

{SEG1=1}

}

}

复制代码

必须时刻让SEG电平跟COM的电平成反向,那么驱动段式液晶就不会有多大的难度了

段码液晶屏:http://www.hzjingxian.com

文章原创于http://www.hzjingxian.com/zixun/xydt/822.html,转载请注明出处

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

*程序名称:带汉字库的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=0x80break//第一行首地址

case 1:row=0x90break//第二行首地址

case 2:row=0x88break//第三行首地址

case 3:row=0x98break//第四行首地址

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=0i<32i++)

//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=0j<32j++)

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=0i<ki++,y++)//上半屏行数

{

Write12864Command(0x80|y)//写行地址(垂直地址)

Write12864Command(0x80|x)//写列地址(水平地址)

for(j=0j<px/8j++)

Write12864Data(pp[i*px/8+j])//写图片数据

}

y=0//下半屏起始行,接上半屏继续写数据

for(i<pyi++,y++)//下半屏剩下的行数

{

Write12864Command(0x80|y)//写行地址(垂直地址)

Write12864Command(0x80|(8+x))//写列地址(水平地址)

for(j=0j<px/8j++)

Write12864Data(pp[i*px/8+j])//写图片数据

}

}

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

{

for(i=0i<pyi++,y++)//行数

{

Write12864Command(0x80|(y-32))//写行地址(垂直地址)

Write12864Command(0x80|(8+x))//写列地址(水平地址)

for(j=0j<px/8j++)

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

#include<reg52.h>

#include <math.h>

void lcd_init(void)

void clr_lcd(void)

void send_com(unsigned char cmd)

void send_data(unsigned char dat)

void chek_busy(void)

void set_xy(unsigned char xpos,unsigned char ypos)

void print(unsigned char x,unsigned char y,char* str)

void printstr(unsigned char xpos,unsigned char ypos,unsigned char str[],unsigned char k)

unsigned char code buf[4] ={0xbb,0xb6,0xd3,0xad}//欢迎

#define DATA P2

#define CONTROL P0

#define E7 //并行的使能信号sbit E = P0^7

#define RW 6 //并行的读写信号 sbit RW = P0^6

#define RS 5 //并行的指令数据选择信号 sbit RS = P0^5

#define PSB 4 //并/串行接口选择 sbit PSB = P0^4

#define RST 3 //复位 低电平有效 sbit RST = P0^3

#define SETB(x,y) (x|=(1<<y))

#define CLRB(x,y) (x&=(~(1<<y)))

#define CHKB(x,y) (x&(1<<y))

/********************测忙碌**********************/

//测忙碌子程序

//RS=0,RW=1,E=H,D0-D7=状态字

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

void chek_busy(void)

{ unsigned char temp1//状态信息(判断是否忙)

CLRB(CONTROL,RS) // RS = 0

SETB(CONTROL,RW) // RW = 1

SETB(CONTROL,E) // E = 1

do{temp1 = DATADATA=0xFF} while(temp1&0x80)

SETB(CONTROL,E) // E = 1

DATA=0xFF

}

/********************写命令**********************/

//写命令子程序

//

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

void send_com(unsigned char cmd)/*写命令*/

{

chek_busy()

CLRB(CONTROL,RS)//RS = 0

CLRB(CONTROL,RW)//RW = 0

DATA = cmd

SETB(CONTROL,E)//E = 1

CLRB(CONTROL,E)//E = 0

}

/********************写数据**********************/

//写数据子程序

//

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

void send_data(unsigned char dat)

{

chek_busy()

SETB(CONTROL,RS)//RS = 1

CLRB(CONTROL,RW)//RW = 0

DATA = dat

SETB(CONTROL,E)//E = 1

CLRB(CONTROL,E)//E = 0

}

/********************初始化**********************/

//复位、通讯方式选择

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

void lcd_init(void)

{

SETB(CONTROL,RST)//复位RST=1

SETB(CONTROL,PSB) //通讯方式为并口PSB = 1

//send_com(0x34)//34H--扩充指令 *** 作

send_com(0x30)//功能设置,一次送8位数据,基本指令集

send_com(0x0C)//0000,1100 整体显示,游标off,游标位置off

send_com(0x01)//0000,0001 清DDRAM

send_com(0x02)//0000,0010 DDRAM地址归位

send_com(0x80)//1000,0000 设定DDRAM 7位地址000,0000到地址计数器AC

}

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

// 设置显示位置xpos(1~16),tpos(1~4)

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

void set_xy(unsigned char xpos,unsigned char ypos)

{

switch(ypos)

{

case 1:

send_com(0X80|xpos)break

case 2:

send_com(0X90|xpos)break

case 3:

send_com(0X88|xpos)break

case 4:

send_com(0X98|xpos)break

default:break

}

}

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

// 在指定位置显示字符串

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

void print(unsigned char x,unsigned char y,char* str)

{

unsigned char lcd_temp

set_xy(x,y)

lcd_temp=*str

while(lcd_temp != 0x00)

{

send_data(lcd_temp)

lcd_temp=*(++str)

}

}

/********************写字符串******************/

//写字符串子程序

//xpos1取0~7共八列,ypos1取0~3共四行。

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

void printstr(unsigned char xpos,unsigned char ypos,unsigned char str[],unsigned char k)

{ unsigned char n

switch (ypos)

{ case 1: xpos |= 0x80break//第一行

case 2: xpos |= 0x90break//第二行

case 3: xpos |= 0x88break//第三行

case 4: xpos |= 0x98break//第四行

default: break

}

send_com(xpos) //此处的Xpos已转换为LCM的显示寄存器实际地址

for(n=0n <kn++)

{

send_data(str[n])//显示汉字时注意码值,连续两个码表示一个汉字

}

}

/********************清屏************************/

//清屏

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

void clr_lcd(void)

{

send_com(0x01)

//send_com(0x34)

//send_com(0x30)

}

/**************主函数***********************/

void main ()

{

lcd_init()//设定液晶工作方式

printstr(1,1,buf,4)

print(5,1,"光临")

print(0,3," SEEGU百度空间")

while(1) { }

}

//-----------------------------------------------------------------下面这个是不带字库的,以前使用的液晶就是用这个驱动小改的

128x64液晶KS0108驱动程序(C51)

/*------------------------------------------------------------------------------------------

[文件名] 12864.c

[功能] 128X64驱动程序

[版本] 2.0

[作者] 鞠春阳

[最后修改时间] 2003年5月12日

[版权所有] www.mcuzb.com

[资料] 请到www.mcuzb.com下载

===========================================================================================*/

#include "absacc.h"

#include "intrins.h"

//自定义库 在"C:\comp51\UserLib\"文件夹中

#include ".\inc\ASCII816.h" //标准ASCII库

#include ".\inc\HZTable.h" //汉字点阵库(自做)

#include ".\inc\Menu.h" //菜单库(自做)

// LCD128*64 数据线

#define LCD12864DataPort P1

// LCD128*64 I/O 信号管脚

sbit di =P3^1// 数据\指令 选择

sbit rw =P3^3// 读\写 选择

sbit en =P3^2// 读\写使能

sbit cs1 =P3^4// 片选1,低有效(前64列)

sbit cs2 =P3^5// 片选2,低有效(后64列)

sbit reset=P0^7// 复位

/*----------------------------------------------------------------------------------------------------*/

/* ****函数列表****

//开关显示

void SetOnOff(unsigned char onoff)

//选择屏幕

//screen: 0-全屏,1-左屏,2-右

void SelectScreen(unsigned char screen)

//清屏

//screen: 0-全屏,1-左屏,2-右

void ClearScreen(unsigned char screen)

//显示8*8点阵

//旋转90度:字模被竖着切分

//lin:行(0-7), column: 列(0-15)

//address : 字模区首地址

void Show88(unsigned char lin,unsigned char column,unsigned int address)

//显示8*16字符

//旋转90度:字模被竖着切分

//lin:行(0-3), column: 列(0-15)

//character:字符代码(标准ASCII码)

void ShowChar(unsigned char lin,unsigned char column,unsigned char character)

//显示8*16字符串

//!!!只能显示在一行上即: 串长+column <=15

//旋转90度:字模被竖着切分

//lin:行(0-3), column: 列(0-15)

//address : 字模区首地址

void ShowString(unsigned char lin,unsigned char column, unsigned char *string)

//显示一个汉字

//旋转90度:字模被竖着切分

//lin:行(0-3), column: 列(0-15)

//hzcode: 汉字代码(自定义的)

void ShowHZ(unsigned char lin,unsigned char column,unsigned int hzcode)

//显示图片

//旋转90度 :字模被竖着切分

//startline :开始行

//startcolumn:开始列

//linechar :图片行点除8(图片以8*8点阵为单位)

//columnchar :图片列点除8(图片以8*8点阵为单位)

//address : 字模区首地址

void ShowPicture(unsigned char startline,unsigned char startcolumn,unsigned char linechar,unsigned char columnchar,unsigned int address)

//!!问题大户

//显示一行汉字

//lin:行

//lineheadaddr: 此行汉字代码区首地址

void ShowLine(unsigned char lin,unsigned int lineheadaddr)

//显示一屏汉字

//pageheadaddr:此屏汉字代码地址区首地址

void ShowPage(unsigned int pageheadaddr)

//反显一个8*8字块

//lin:行(0-3), column: 列(0-7)

void ReverseShow88(unsigned char lin,unsigned char column)

//反显一个字符

//lin:行(0-4), column: 列(0-15)

void ReverseShowChar(unsigned char lin,unsigned char column)

//反显一个汉字

//lin:行(0-3), column: 列(0-7)

ReverseShowHZ(unsigned char lin,unsigned char column)

//反显一行汉字

//lin:行

ReverseShow(unsigned char lin)

//初始化LCD

void InitLCD()

****函数列表结束**** */

/*----------------------------------------------------------------------------------------------------*/

/*--基本函数源程序------------------------------------------------------------------------------------*/

//延时

Lcd12864delay()

{

unsigned int i=500

while(i--) {}

}

/*----------------------------------------------------------------------------------------------------*/

//状态检查

void CheckState()

{

unsigned char dat

di=0

rw=1

do{

LCD12864DataPort=0xff

en=1dat=LCD12864DataPorten=0

dat=0x90 &dat//仅当第4,7位为0时才可 *** 作

}while(!(dat==0x00))

}

/*----------------------------------------------------------------------------------------------------*/

//写显示数据

//dat:显示数据

void WriteByte(unsigned char dat)

{

CheckState()

di=1rw=0

LCD12864DataPort=dat

en=1en=0

}

/*-----------------------------------------------------------------------------------------------------*/

//向LCD发送命令

//command :命令

SendCommandToLCD(unsigned char command)

{

CheckState()

rw=0

LCD12864DataPort=command

en=1en=0

}

/*----------------------------------------------------------------------------------------------------*/

//设定行地址(页)--X 0-7

void SetLine(unsigned char line)

{

line=line &0x07// 0<=line<=7

line=line 0xb8//1011 1xxx

SendCommandToLCD(line)

}

//设定列地址--Y 0-63

void SetColumn(unsigned char column)

{

column=column &0x3f// 0=<column<=63

column=column 0x40//01xx xxxx

SendCommandToLCD(column)

}

//设定显示开始行--XX

void SetStartLine(unsigned char startline) //0--63

{

startline=startline &0x07

startline=startline 0xc0//1100 0000

SendCommandToLCD(startline)

}

//开关显示

void SetOnOff(unsigned char onoff)

{

onoff=0x3e onoff//0011 111x

SendCommandToLCD(onoff)

}

/*---------------------------------------------------------------------------------------------------*/

//选择屏幕

//screen: 0-全屏,1-左屏,2-右屏

void SelectScreen(unsigned char screen)

{ //北京显示器:负有效 cs1: 0--右cs2: 0--左

switch(screen)

{ case 0: cs1=0//全屏

_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()

cs2=0

_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()

break

case 1: cs1=1//左屏

_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()

cs2=0

_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()

break

case 2: cs1=0//右屏

_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()

cs2=1

_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()

break

}

}

/*---------------------------------------------------------------------------------------------------*/

//清屏

//screen: 0-全屏,1-左屏,2-右

void ClearScreen(unsigned char screen)

{ unsigned char i,j

SelectScreen(screen)

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

{ SetLine(i)

for(j=0j<64j++)

{

WriteByte(0x00)

}

}

}

/*--------------------------------------------------------------------------------------------------*/

//显示8*8点阵

//旋转90度:字模被竖着切分

//lin:行(0-7), column: 列(0-15)

//address : 字模区首地址

void Show88(unsigned char lin,unsigned char column,unsigned int address)

{ unsigned char i

if(column>16) {return}

if(column<8) SelectScreen(1)//如果列数<8(0,1,2,3,4,5,6,7)则写在第一屏上

else {

SelectScreen(2)//否则 (8,9,10,11,12,13,14,15)写在第二屏上

column=column &0x07//防止越界

}

SetLine(lin)

SetColumn(column<<3)

for(i=0i<8i++) WriteByte( CBYTE[address+i] )

}

/*------------------------------------------------------------------------------------------------*/

//显示8*16字符

//旋转90度:字模被竖着切分

//lin:行(0-3), column: 列(0-15)

//character:字符代码(标准ASCII码)

void ShowChar(unsigned char lin,unsigned char column,unsigned char character)

{ lin=lin<<1

Show88(lin ,column,ASCII816[character-0x20] )

Show88(lin+1,column,ASCII816[character-0x20]+8 )

}

/*-----------------------------------------------------------------------------------------------*/

/*

//显示8*16字符串

//!!!只能显示在一行上即: 串长+column <=15

//旋转90度:字模被竖着切分

//lin:行(0-3), column: 列(0-15)

//address : 字模区首地址

void ShowString(unsigned char lin,unsigned char column, unsigned char *string)

{ unsigned char ch

unsigned char i=0

while(*string!=''\0'')

{

ch=*string

if(i+column >15) break//(只能显示在一行上即: 串长+column <=15)

ShowChar(lin,i+column,ch)

string++i++

}

}

*/

/*----------------------------------------------------------------------------------------------*/

//显示一个汉字

//旋转90度:字模被竖着切分

//lin:行(0-3), column: 列(0-7)

//hzcode: 汉字代码(自定义的)

//uchar code HZtable

void ShowHZ(unsigned char lin,unsigned char column,unsigned int hzcode)

{

lin=lin<<1//lin*2

Show88(lin,column,HZTable[hzcode])

Show88(lin,column+1,HZTable[hzcode]+8)

Show88(lin+1,column,HZTable[hzcode]+16)

Show88(lin+1,column+1,HZTable[hzcode]+24)

}

/*----------------------------------------------------------------------------------------------*/

//显示图片

//旋转90度 :字模被竖着切分

//startline :开始行

//startcolumn:开始列

//linechar :图片行点除8(图片以8*8点阵为单位)

//columnchar :图片列点除8(图片以8*8点阵为单位)

//address : 字模区首地址

void ShowPicture(unsigned char startline,unsigned char startcolumn,unsigned char linechar,unsigned char columnchar,unsigned int address)

{ unsigned char i,j

for(i=0i<columnchari++)

for(j=0j<linecharj++)

Show88(startline+i , startcolumn+j , address+(i*linechar+j)*8 )

}

/*----------------------------------------------------------------------------------------------*/

//显示一行字符串(汉字,字母混排,一行16字节)

//lin:行

//lineheadaddr: 此行汉字代码区首地址

void ShowLine(unsigned char lin,unsigned char linehead[])

{ unsigned char i

unsigned char byte

unsigned int hzcode

for( i=0i<16)

{ byte=linehead[i]

if(byte <0x80) //字母

{

if(i>15) return//!!编译器有问题,须强制退出

ShowChar(lin, i , byte)

i=i+1

}

else // byte >= 0x80(汉字)

{

if(i>15) return//!!编译器有问题,须强制退出

byte=byte &0x7f//最高位置0,即:减去0x8000

hzcode=(unsigned int)byte<<8//?? //高8位

hzcode=hzcode+linehead[i+1]//加低8位,组合成整型数地址

ShowHZ( lin,i,hzcode)

i=i+2

}

}

}

/*----------------------------------------------------------------------------------------------------*/

//显示一屏汉字

//pageheadaddr:此屏汉字代码地址区首地址

void ShowPage(unsigned char pagehead[][16])

{ unsigned char i

for(i=0i<4i++) ShowLine(i,pagehead[i])//1行8个汉字,16字节

}

/*----------------------------------------------------------------------------------------------------*/

//读显示数据

unsigned char ReadByte()

{

unsigned char dat

CheckState()

di=1rw=1

LCD12864DataPort=0xff

en=1dat=LCD12864DataPorten=0

return(dat)

}

/*----------------------------------------------------------------------------------------------------*/

//反显一个8*8字块

//lin:行(0-3), column: 列(0-7)

void ReverseShow88(unsigned char lin,unsigned char column)

{ unsigned char i

unsigned char tab[8]

if(column<8) SelectScreen(1)//如果列数<4(0,1,2,3),则写在第一屏上

else SelectScreen(2)//否则 (4,5,6,7), 写在第二屏上

//读上部8列

column=column<<3//每个方块8*8大小

SetLine(lin)

SetColumn(column)

tab[0]=ReadByte()//空读!!!!! //?

for(i=0i<8i++) tab[i]=~ReadByte()

//写回

SetLine(lin)

SetColumn(column)

for(i=0i<8i++) WriteByte(tab[i])

}

/*----------------------------------------------------------------------------------------------------*/

/*----------------------------------------------------------------------------------------------------*/

//反显一个字符

//lin:行(0-4), column: 列(0-15)

void ReverseShowChar(unsigned char lin,unsigned char column)

{ lin=lin<<1

ReverseShow88(lin ,column)

ReverseShow88(lin+1,column)

}

/*----------------------------------------------------------------------------------------------------*/

//反显一个汉字

//lin:行(0-3), column: 列(0-7)

ReverseShowHZ(unsigned char lin,unsigned char column)

{

lin=lin<<1

column=column<<1

ReverseShow88(lin ,column )

ReverseShow88(lin ,column+1)

ReverseShow88(lin+1,column )

ReverseShow88(lin+1,column+1)

}

/*----------------------------------------------------------------------------------------------------*/

//反显一行汉字

//lin:行

ReverseShow(unsigned char lin)

{ unsigned char i

for(i=0i<8i++) ReverseShowHZ(lin,i)

}

/*----------------------------------------------------------------------------------------------------*/

void InitLCD() //初始化LCD

{ unsigned char i=250//延时

while(i--)

//reset=0//复位

//reset=1

SelectScreen(0)

SetOnOff(0)//关显示

ClearScreen(1)//清屏

ClearScreen(2)

SelectScreen(0)

SetOnOff(1)//开显示

SelectScreen(0)

SetStartLine(0)//开始行:0

}

/*----------------------------------------------------------------------------------------------------*/

void Reset() //液晶复位

{

//reset 低复位 _ -

reset=0

_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()

reset=1

//全屏

cs1=0

_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()

cs2=0

_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()_nop_()

SendCommandToLCD(0x3F)

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7808815.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-10
下一篇 2023-04-10

发表评论

登录后才能评论

评论列表(0条)

保存