12864的图形输入啊,这个我前段时间写贪吃蛇的时候研究过。一句话,就是液晶工作于扩充指令集(图形显示)的时候,往图形缓冲GDRAM里写数据,然后开显示即可。我这儿有个自己已经写现成的液晶驱动,但是没有时间去优化,能实现点级点亮与熄灭以及横竖直线的画线,但是任意直线的算法我没有写,因为本身做贪吃蛇不需要那个功能。你要的话我可以给你看看。
阁下说的pic16f877a单片机的12864液晶串行显示驱动程序!
你用的屏应该是12864带中文字库,控制芯片是ST7920的屏,那你就可以用模块内置自带的中文字库,只要根据ST7920中文字型码表里提出你想的内容就可以了,你可以在网下一个"ST7920中文字型码表",网上有很多,里面都是12864液晶串行接口的汉字库,你从里面调出来用就可以!
参考资料(不包含自调字库)
/-------------------------------------
ST7920串行驱动程序
--------------------------------------/
#ifndef ST7920_H
#define ST7920_H
/--------------------------------/
//#include<reg52h>
/--------------------------------/
#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"ST7920h"
/------------------------------
函数名: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=page0;break;
case 1:x=page1;break;
case 2:x=page2;break;
case 3:x=page3;break;
}
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=0;i<512;i+=16)
{
LCM_wrcmd(0x80+i/16);
LCM_wrcmd(0x80);
for(j=0;j<16;j++)
{
LCM_wrdat(0x00);
}
}
for(i=0;i<512;i+=16)
{
LCM_wrcmd(0x80+i/16);
LCM_wrcmd(0x88);
for(j=0;j<16;j++)
{
LCM_wrdat(0x00);
}
}
}
/----------------------------
输入一幅12864的图像
----------------------------/
void LCM_12864map(uchar p)
{
uint i,j;
LCM_extinit();
LCM_mapclr();
for(i=0;i<512;i+=16)
{
LCM_wrcmd(0x80+i/16);
LCM_wrcmd(0x80);
delay(1);
for(j=0;j<16;j++)
{
LCM_wrdat(p[j+i]);
}
LCM_wrcmd(0x80+i/16);
LCM_wrcmd(0x88);
delay(1);
for(j=0;j<16;j++)
{
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=0;i<256;i+=8)
{
LCM_wrcmd(0x80+i/8);
LCM_wrcmd(0x80+x);
delay(1);
for(j=0;j<8;j++)
{
LCM_wrdat(p[j+i]);
}
LCM_wrcmd(0x80+i/8);
LCM_wrcmd(0x88+x);
delay(1);
for(j=0;j<8;j++)
{
LCM_wrdat(p[256+j+i]);
}
}
LCM_wrcmd(mapdison);
delay(16);
}
/----------------------------
自定义图形文字3232
----------------------------/
void LCM_3232word(uchar x,uchar p)
{
uint i,j;
for(i=0;i<128;i+=4)
{
LCM_wrcmd(0x80+i/4);
LCM_wrcmd(0x80+x);
delay(1);
for(j=0;j<4;j++)
{
LCM_wrdat(p[j+i]);
}
}
LCM_wrcmd(mapdison);
delay(16);
}
以下是串行方式的驱动
#include"ST7920_sh"
/------------------------------
函数名: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=0;i<8;i++)
{
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=page0;break;
case 1:x=page1;break;
case 2:x=page2;break;
case 3:x=page3;break;
}
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++);
}
}
希望能对你有帮助,祝你开发成功!
引脚号 引脚名称 方向 功能说明
1 VSS - 模块的电源地
2 VDD - 模块的电源正端
3 V0 - LCD驱动电压输入端
4 RS(CS) H/L 并行的指令/数据选择信号;串行的片选信号
5 R/W(SID) H/L 并行的读/写选择信号;串行的数据口
6 E(CLK) H/L 并行的使能信号;串行的同步时钟
7 DB0 H/L 数据0
8 DB1 H/L 数据1
9 DB2 H/L 数据2
10 DB3 H/L 数据3
11 DB4 H/L 数据4
12 DB5 H/L 数据5
13 DB6 H/L 数据6
14 DB7 H/L 数据7
15 PSB H/L 并/串行接口选择:H-并行;L-串行
16 NC 空脚
17 /RET H/L 复位 低电平有效
18 NC 空脚
19 LED_A (LED+5V) 背光源正极(加int?)
20 LED_K (LED-OV) 背光源负极
以上就是关于求无字库12864液晶显示图像的51单片机程序,C语言版的全部的内容,包括:求无字库12864液晶显示图像的51单片机程序,C语言版的、如何在12864(带子库)编写显示变化数字的子程序中文显示程序已会。、51单片机128*64液晶C程序等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)