12864使用串口通信,驱动程序怎么写

12864使用串口通信,驱动程序怎么写,第1张

这个问题有两种回答:

1,你问的不对。你其实想问的是,怎么使用串口,修改12864屏幕上的内容。这个网上有很多程序。随便看一下就好。

2,你沉迷于技术了。模拟本身提供的是八位的输出,你偏偏要自己用UART串口去驱动。这就好比:是要用到PWM的时候,明明单片机内部已经有了集成的模块。配置定时器就可以输出完美的PWM。可你觉得,这样太简单了。于是,你用两个定时器去实现:一个定时,一个控制输出频率。

效果不好还不错,而且浪费资源。

再举个极端的例子,你想实现一个很简单的for循环,使用高级的语言(就C语言来说,一下就好),

但是,你偏偏要用二进制0,1来写。

你觉得,这样才牛B,你才是比较厉害的人。

--------------------------------

喜欢请点赞,不喜欢,另说

绝对好用的串口程序

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的地址计数器归零

}*/

我有51的程序,可供参考。

#include "lcd12864.h"

#include "ziku.h"

#include <string.h>

static void delay(uint j)//延时

{

uchar i

for(j!=0j--)

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

}

void busy(void)

{

uchar i

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

_nop_()

}

void wdata(uchar wdata)

{

busy() //忙提示

LCD_RW=0

LCD_DI=1

P0=wdata

LCD_EN=0

LCD_EN=1

LCD_EN=0

}

void wcode(uchar wcode)

{

busy()

LCD_RW=0

LCD_DI=0

P0=wcode

LCD_EN=0

LCD_EN=1

LCD_EN=0

}

void subinit()

{

delay(10)

wcode(0xc0)//设置显示初始行

}

//设置显示位置

void setxy(uchar x,uchar y)

{

if ((y>=0)&(y<=63))

{

LCD_CSA=0

LCD_CSB=1

}

else //if (y<=127)

{

LCD_CSA=1

LCD_CSB=0

}

wcode(0x40|(y%64))

wcode(0xb8|x)

P0=0xff

}

void wdram(uchar x,uchar y,uchar dd)

{

setxy(x,y)

wdata(dd)

P0=0xff

LCD_CSA=1

LCD_CSB=1

}

//复位.

void Lcd_RST(void)

{

//rst=0

LCD_REST=0

delay(50)

LCD_REST=1

Lcd_Clear(0,7,0,128)

wcode(0x3f)//开显示

}

//LCD初始化

void Lcd_Init(void)

{

LCD_POR=0

Lcd_RST()

LCD_CSA=0

LCD_CSB=1

wcode(0x3e)subinit()

LCD_CSA=1

LCD_CSB=0

wcode(0x3e)subinit()

Lcd_Clear(0,7,0,128)

LCD_CSA=0

LCD_CSB=1

wcode(0x3f)//开显示

LCD_CSA=1

LCD_CSB=0

wcode(0x3f)//开显示

}

void Lcd_On(void)

{

LCD_CSA=0

LCD_CSB=1

wcode(0x3f)//开显示

LCD_CSA=1

LCD_CSB=0

wcode(0x3f)//开显示

}

//LCD 清显示屏

void Lcd_Clear(uchar StartLine,uchar StopLine,uchar StartRow,uchar StopRow)

{

uchar x,y

for(x=StartLinex<StopLine+1x++)

{

for(y=StartRowy<StopRowy++)

{

wdram(x,y,0)

}

}

}

//显示一个汉字

void Lcd_DispOneChar(uchar x,uchar y,uchar * hz,uchar disp_mode,uchar Width)

{

uchar i

for(i=0i<Widthi++)

{

if(disp_mode==WHITE)

{

wdram(x,y+i,*(hz+i))

wdram(x+1,y+i,*(hz+Width+i))

}

else

{

wdram(x,y+i,0xff-*(hz+i))

wdram(x+1,y+i,0xff-*(hz+Width+i))

}

}

if(Width==12)

{

for(i=12i<14i++)

{

if(disp_mode==WHITE)

{

wdram(x,y+i,0)

wdram(x+1,y+i,0)

}

else

{

wdram(x,y+i,0xff)

wdram(x+1,y+i,0xff)

}

}

for(i=1i<4i++)

{

if(disp_mode==WHITE)

{

wdram(x,y-i,0)

wdram(x+1,y-i,0)

}

else

{

wdram(x,y-i,0xff)

wdram(x+1,y-i,0xff)

}

}

}

}

void Lcd_Disp_String(uchar x,uchar y,char *pString,uchar disp_mode)

{

uchar i,j

uchar LineDispCode[16]

//strlen(),为字符串长度测量。

memset(LineDispCode,0,16) //清零数组

strcpy(LineDispCode,pString) //字符串之间的相互复制。

for(i=0i<strlen(pString)i++)

{

LineDispCode[i]=*(pString+i)

}

i=0

while(LineDispCode[i]!=0)

{

if(LineDispCode[i]>=0xA0)

{

//显示的是汉字

for(j=0j<ZIMO_NUMj++)

{

if(GB_12[j].Index[0]==LineDispCode[i] &&

GB_12[j].Index[1]==LineDispCode[i+1])

{

//显示的是汉字

Lcd_DispOneChar(x,y,GB_12[j].Msk,disp_mode,12)

y+=16

break

}

}

i+=2

}

else

{

//显示的是ASCII编码

for(j=0j<ASC_NUMj++)

{

if(ASC_12[j].Index==LineDispCode[i])

{

//显示的是汉字

Lcd_DispOneChar(x,y,ASC_12[j].Msk,disp_mode,8)

y+=8

break

}

}

i++

}

if(i>=16)

{

break

}

}

}

//显示数字.

void Lcd_Disp_OneNum(uchar x,uchar y,uchar num,uchar disp_mode)

{

switch(num)

{

case 0:{Lcd_Disp_String(x,y,"0",disp_mode)}break

case 1:{Lcd_Disp_String(x,y,"1",disp_mode)}break

case 2:{Lcd_Disp_String(x,y,"2",disp_mode)}break

case 3:{Lcd_Disp_String(x,y,"3",disp_mode)}break

case 4:{Lcd_Disp_String(x,y,"4",disp_mode)}break

case 5:{Lcd_Disp_String(x,y,"5",disp_mode)}break

case 6:{Lcd_Disp_String(x,y,"6",disp_mode)}break

case 7:{Lcd_Disp_String(x,y,"7",disp_mode)}break

case 8:{Lcd_Disp_String(x,y,"8",disp_mode)}break

case 9:{Lcd_Disp_String(x,y,"9",disp_mode)}break

default: break

}

}

//显示二位数。

void Disp_2num(uchar x,uchar y,uchar num,uchar disp_mode)

{

uchar ch[2]

ch[0]=num%10

ch[1]=num/10

Lcd_Disp_OneNum(x,y,ch[1],disp_mode)

Lcd_Disp_OneNum(x,y+8,ch[0],disp_mode)

}

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

//显示三位数。

void Disp_3num(uchar x,uchar y,uint num,uchar disp_mode)

{

uchar ch[2]

ch[0]=num/100

ch[1]=num%100

if(ch[0])

Lcd_Disp_OneNum(x,y, ch[0],disp_mode)

else

Lcd_Disp_String(x,y," ",disp_mode)

Disp_2num(x,y+8, ch[1],disp_mode)

}

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

//显示四位数。

void Disp_4num(uchar x,uchar y,uint num,uchar disp_mode)

{

uchar ch[4],tmp

tmp=num/100

ch[0]=tmp/10

ch[1]=tmp%10

tmp=num%100

ch[2]=tmp/10

ch[3]=tmp%10

Lcd_Disp_OneNum(x,y,ch[0],disp_mode)

Lcd_Disp_OneNum(x,y+8,ch[1],disp_mode)

Lcd_Disp_OneNum(x,y+16,ch[2],disp_mode)

Lcd_Disp_OneNum(x,y+24,ch[3],disp_mode)

}

void Lcd_DispIco2(uchar x,uchar y,uchar *pIco)//显示老肯图标

{

uchar i,j

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

{

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

{

wdram(x+i,y+j,*pIco)

pIco++

}

}

}

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

//显示多位数。 disp_mode&0x10==1时,进行即每位都显示,否则大于0的位置不显示。

void Disp_NumGB16(uchar x,uchar y,ulong Data,uchar num,uchar disp_mode)

{

uchar idata ch=0,i,tmp

for(i=0i<numi++)

{

tmp=Data%10

Data/=10

if((disp_mode&0x10)||tmp>0||Data>0||num<=2)

Lcd_Disp_OneNum(x,y+(num-i-1)*8,tmp,disp_mode%10)

else

Lcd_Disp_String(x,y+(num-i-1)*8," ",disp_mode%10)

}

}


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存