12864怎么让某一行的反白

12864怎么让某一行的反白,第1张

绝对好用的串口程序

sbit SID=P2^1//12864数据

sbit SCLK=P2^2//12864时钟

init()

{

write(0,0x30) //8 位介面,基本指令

write(0,0x0c) //显示打开,光标关,反白关

write(0,0x01) //清屏,将DDRAM的地址计数器归零

delaynms(10)

write(0,0x80)for(i=0i<16i++) write(1,datas11[i])

write(0,0x90)for(i=0i<16i++) write(1,datas2[i])

write(0,0x88)for(i=0i<16i++) write(1,datas3[i])

write(0,0x98)for(i=0i<16i++) write(1,datas4[i])

}

/**********************12864*************************/

void delaynms(unsigned int di) //延时

{

unsigned int da,db

for(da=0da<dida++)

for(db=0db<10db++)

}

void sendbyte(unsigned char bbyte) //发送一个字节

{

unsigned char i

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

{

SID=bbyte&0x80//取出最高位

SCLK=1

SCLK=0

bbyte<<=1//左移

}

}

void write(bit start, unsigned char ddata) //写指令或数据

{

unsigned char start_data,Hdata,Ldata

if(start==0) start_data=0xf8 //写指令

else start_data=0xfa //写数据

Hdata=ddata&0xf0 //取高四位

Ldata=(ddata<<4)&0xf0 //取低四位

sendbyte(start_data) //发送起始信号

delaynms(5)//延时是必须的

sendbyte(Hdata) //发送高四位

delaynms(1) //延时是必须的

sendbyte(Ldata) //发送低四位

delaynms(1) //延时是必须的

}

/*void lcdinit(void) //初始化LCD

{

delaynms(10)//启动等待,等LCM讲入工作状态

//PSB=0//串口驱动模式

// RESET=0delaynms(1)RESET=1// 复位LCD

// CS=1

write(0,0x30) //8 位介面,基本指令集

write(0,0x0c) //显示打开,光标关,反白关

write(0,0x01) //清屏,将DDRAM的地址计数器归零

}*/

阁下说的pic16f877a单片机的12864液晶串行显示驱动程序!

你用的屏应该是12864带中文字库,控制芯片是ST7920的屏,那你就可以用模块内置自带的中文字库,只要根据ST7920中文字型码表里提出你想的内容就可以了,你可以在网下一个"ST7920中文字型码表",网上有很多,里面都是12864液晶串行接口的汉字库,你从里面调出来用就可以!

参考资料(不包含自调字库)

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

ST7920串行驱动程序

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

#ifndef ST7920_H

#define ST7920_H

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

//#include<reg52.h>

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

#define uchar unsigned char

#define uint unsigned int

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

下面是ST7920的内部指令宏定义

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

#define bascmd 0x30 /*使用基本指令集*/

#define clear 0x01 /*清屏*/

#define turn 0x02 /*地址归位*/

#define entset 0x06 /*游标右移,DDRAM地址计数器AC+1*/

#define gor 0x1c /*整屏右移*/

#define gol 0x18 /*整屏左移*/

#define dison 0x0c /*显示开,关光标*/

#define cgrama 0x40 /*cgram基地止*/

#define ddrama 0x80 /* 设定DDRAM 地址,第一行80H~87H,第二行90H~97H */

#define page0 0x80

#define page1 0x90

#define page2 0x88

#define page3 0x98

#define extcmd 0x34 /*使用扩展指令集*/

#define reverse 0x04 /*反白显示*/

#define mapdison 0x36/*扩充指令图形显示开*/

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

硬件接口

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

#define LCM_DATA P0 /* P0口,作为数据总线 */

sbit LCM_RS = P1^7 /* 数据(H)/指令(L) */

sbit LCM_RW = P1^6/* 读(H)/写(L) */

sbit LCM_EN = P1^5/* 使能-写(H->L)/读(H) */

sbit LCM_PSB = P1^4/* 8位或4位串口 */

sbit LCM_BF = LCM_DATA^7 /* LCD模块内部忙标志 */

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

void delay(uint t)

void Ldelay(uint t1)

void LCM_busy()

void LCM_wrcmd(uchar cmd)

void LCM_wrdat(uchar dat)

void LCM_add(uchar x,uchar y)

void LCM_basinit()

void LCM_wrpagestr(uchar add,uchar* dis,uchar num)

void LCM_mapclr()

void LCM_extinit()

void LCM_12864map(uchar code *dis)

void LCM_6464map(uchar x,uchar *p)

void LCM_3232word(uchar x,uchar *p)

#endif

以下是并行方式的驱动:

#include"ST7920.h"

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

函数名:void delay(uint t)

延时t个5倍指令周期,1个指令周期约为1us

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

void delay(uint t)

{

while(t--)

{

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

}

}

void Ldelay(uint t1)

{

while(t1--)

delay(1000)

}

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

读忙函数,等待液晶处于就绪态

LCM_busy=1时为忙

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

void LCM_busy()

{

LCM_RS = 0

LCM_RW = 1

LCM_EN = 1

while(LCM_BF)

LCM_EN = 0

}

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

向LCM写指令

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

void LCM_wrcmd(uchar cmd)

{

LCM_busy()

LCM_RS = 0

LCM_RW = 0

LCM_DATA = cmd

LCM_EN = 1

delay(1)

LCM_EN = 0

}

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

向LCM写数据

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

void LCM_wrdat(uchar dat)

{

LCM_busy()

LCM_RS = 1

LCM_RW = 0

LCM_DATA = dat

LCM_EN = 1

delay(1)

LCM_EN = 0

}

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

写地址函数,基本指令集,文字

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

void LCM_add(uchar x,uchar y)

{

switch(x)

{

case 0:x=page0break

case 1:x=page1break

case 2:x=page2break

case 3:x=page3break

}

LCM_wrcmd(x+y)

// delay(8)

}

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

LCM初始化函数,基本指令集

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

void LCM_basinit()

{

LCM_PSB = 1

LCM_wrcmd(bascmd)

delay(80)

LCM_wrcmd(entset)

delay(80)

LCM_wrcmd(dison)

delay(80)

LCM_wrcmd(clear)

delay(1000)

}

void LCM_extinit()

{

LCM_wrcmd(0x34)

delay(80)

LCM_wrcmd(0x02)

delay(80)

}

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

向某一行写字符串

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

void LCM_wrpagestr(uchar add,uchar* dis,uchar num)

{

LCM_wrcmd(add)

while(num--)

{

LCM_wrdat(*dis++)

}

}

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

图形清屏函数

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

void LCM_mapclr()

{

uint i,j

LCM_extinit()

for(i=0i<512i+=16)

{

LCM_wrcmd(0x80+i/16)

LCM_wrcmd(0x80)

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

{

LCM_wrdat(0x00)

}

}

for(i=0i<512i+=16)

{

LCM_wrcmd(0x80+i/16)

LCM_wrcmd(0x88)

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

{

LCM_wrdat(0x00)

}

}

}

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

输入一幅128*64的图像

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

void LCM_12864map(uchar *p)

{

uint i,j

LCM_extinit()

LCM_mapclr()

for(i=0i<512i+=16)

{

LCM_wrcmd(0x80+i/16)

LCM_wrcmd(0x80)

delay(1)

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

{

LCM_wrdat(p[j+i])

}

LCM_wrcmd(0x80+i/16)

LCM_wrcmd(0x88)

delay(1)

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

{

LCM_wrdat(p[512+j+i])

}

}

LCM_wrcmd(mapdison)

delay(16)

}

void LCM_6464map(uchar x,uchar *p)

{

uint i,j

LCM_extinit()

LCM_mapclr()

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

{

LCM_wrcmd(0x80+i/8)

LCM_wrcmd(0x80+x)

delay(1)

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

{

LCM_wrdat(p[j+i])

}

LCM_wrcmd(0x80+i/8)

LCM_wrcmd(0x88+x)

delay(1)

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

{

LCM_wrdat(p[256+j+i])

}

}

LCM_wrcmd(mapdison)

delay(16)

}

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

自定义图形文字32*32

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

void LCM_3232word(uchar x,uchar *p)

{

uint i,j

for(i=0i<128i+=4)

{

LCM_wrcmd(0x80+i/4)

LCM_wrcmd(0x80+x)

delay(1)

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

{

LCM_wrdat(p[j+i])

}

}

LCM_wrcmd(mapdison)

delay(16)

}

以下是串行方式的驱动

#include"ST7920_s.h"

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

函数名:void delay(uint t)

延时t个5倍指令周期,1个指令周期约为1us

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

void delay(uint t)

{

while(t--)

{

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

}

}

void Ldelay(uint t1)

{

while(t1--)

delay(1000)

}

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

读忙函数,等待液晶处于就绪态

LCM_busy=1时为忙

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

/*void LCM_busy()

{

LCM_RS = 0

LCM_RW = 1

LCM_EN = 1

while(LCM_BF)

LCM_EN = 0

}

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

向LCM写1byte

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

void LCM_wrbyte(uchar DATA)

{

uchar i

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

{

LCM_SID=DATA&0x80//取出最高位

LCM_CLK=1

// _nop_()

LCM_CLK=0

// _nop_()

DATA<<=1//左移

}

}

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

start=0向LCM写指令

start=1向LCM写数据

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

void LCM_wrcord(bit start, uchar DATA) //写指令或数据

{

uchar start_data,Hdata,Ldata

if(start==0) start_data=0xf8//写指令

else start_data=0xfa //写数据

Hdata=DATA&0xf0 //取高四位

Ldata=(DATA<<4)&0xf0 //取低四位

LCM_wrbyte(start_data) //发送起始信号

delay(3)//延时是必须的

LCM_wrbyte(Hdata) //发送高四位

delay(1) //延时是必须的

LCM_wrbyte(Ldata) //发送低四位

delay(1) //延时是必须的

}

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

写地址函数,基本指令集,文字

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

void LCM_add(uchar x,uchar y)

{

switch(x)

{

case 0:x=page0break

case 1:x=page1break

case 2:x=page2break

case 3:x=page3break

}

LCM_wrcord(0,x+y)

}

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

LCM初始化函数,基本指令集

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

void LCM_basinit()

{

LCM_PSB = 0//串口驱动模式

LCM_CS=1

LCM_wrcord(0,bascmd) //8 位介面,基本指令集

LCM_wrcord(0,dison) //显示打开,光标关,反白关

LCM_wrcord(0,clear) //清屏,将DDRAM的地址计数器归零

}

void LCM_extinit()

{

LCM_wrcord(0,0x34)

LCM_wrcord(0,0x02)

}

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

向某一行写字符串

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

void LCM_wrpagestr(uchar add,uchar* dis,uchar num)

{

LCM_wrcord(0,add)

while(num--)

{

LCM_wrcord(1,*dis++)

}

}

希望能对你有帮助,祝你开发成功!


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存