求Adurino 1602LCD的程序

求Adurino 1602LCD的程序,第1张

您好,//以下几条指令是在CE使能端产生一个正脉冲,使LCD响应指令digitalWrite(Enable,LOW) //先强制为低电平

delayMicroseconds(1)//延时1微秒digitalWrite(Enable,HIGH) //然后跳到高delayMicroseconds(1)//延时1微秒digitalWrite(Enable,LOW) //再回到低电平delayMicroseconds(1)//再延时一下}

//LCD数据写入函数void LcdDataWrite(int value) {int i = 0digitalWrite(DI, HIGH)digitalWrite(RW, LOW) //RW端搏手并允许接收数据for (i=DB[0]i <= DB[7]i++) { //意思同上一个函数 digitalWrite(i,value &01) value >>= 1}digitalWrite(Enable,LOW) //意思同上一个函数delayMicroseconds(1)digitalWrite(Enable,HIGH)delayMicroseconds(1)digitalWrite(Enable,LOW)delayMicroseconds(1)}

void setup (void) {int i = 0for (i=Enablei <薯埋= DIi++) { //设置端口状态 pinMode(i,OUTPUT)}

//以下是LCD开机初始化的指令,多次执行0x38是确保初始化的成功率delay(100)LcdCommandWrite(0x38) // 8线2行的LCD用0x38 delay(64) LcdCommandWrite(0x38) delay(50) LcdCommandWrite(0x38) delay(20) LcdCommandWrite(0x06) //设定输入方式,增量不移位delay(20) LcdCommandWrite(0x0E) //忘了delay(20) LcdCommandWrite(0x01) //忘了

delay(100) LcdCommandWrite(0x80)//开显示,光标不闪delay(20) }

提醒一下: 一般CE使能端在1602中, 大部分是在脉冲的下降沿基迹生效。

①问,RS,RW,E 的设置为 读状态时序 的过程,读出来的数据(数据口P1) 的最高位 刚好即为 液晶的 忙碌 标志位。

②问,writecontrol(unsigned condata) 函数 是个 写指令 函数;

③问,空 *** 作 是为了让数据稳定后,才使能 液晶接收数据;

④问,写指令有时间 间隔要求,太频繁的读写会丢码,所以要加延时,三条38指令,是因为安全起见,上电后马上初始化会出现液晶电源不稳而丢码;

⑤问,液晶显示 只在 更新数据 的时候刷新一次即可,液晶会维持内容,无需重复刷新。

⑥附送,③和④问,都是驱动太恶心而造成的结果,好的驱动程序不需如此 *** 作。液晶的时序要求为ns级,单片机的指令周期普遍为us级,根本不需过多累赘。

#include"reg52.h" //包含52头文件

#include"SMC1602A.h" //包含SMC1602A宏定义文件

#define BusyReadCount 10 //读忙标志等待次数

#define SMC1602_Data P0 //定义 数据接口

//sbit SMC1602_VO=P2^4 //定义 VO对比度接口

sbit SMC1602_RW=P2^5 //定义 R/W接口25

sbit SMC1602_RS=P2^6 //定义 RS接口26

sbit SMC1602_E=P2^7 //定义 E接口27

#define SMC1602_En SMC1602_E=1 //使能

#define SMC1602_Dis SMC1602_E=0 //禁止

uchar SMC1602_Read(bit read_type) //1602液晶屏读函数

{

uchar read_data

SMC1602_Dis //禁止使能

SMC1602_RW=ReadOperate //读 *** 作

SMC1602_RS=read_type //读类型:0状态,1数据

SMC1602_En //开启使能

read_data=SMC1602_Data //存储结果

SMC1602_Dis //禁止使能

return read_data //返回结果

}

void SMC1602_WriteByte(bit write_type,uchar write_data) //1602液晶屏读函数

{

uchar i=BusyReadCount

for(ii--) //延时 *** 作,为写 *** 作预留回复时间

while((SMC1602_Read(CommOperate)&BusyState) &&(++i<=BusyReadCount)) //读取忙标志(BusyReadCount次),若均忙中,则不再读取忙标志,直接执行写 *** 作

//while(SMC1602_Read(CommOperate)&BusyState) if(++i>BusyReadCount) return //读取忙标志,若BusyReadCount次均忙中,则不进行写 *** 作

//while(SMC1602_Read(CommOperate)&BusyState) //禅铅等待空闲(死等)

SMC1602_Dis //禁止使能

SMC1602_RW=WriteOperate //写 *** 作

SMC1602_RS=write_type //写类型:0指令,1数据

SMC1602_Data=write_data //写 *** 作,将 *** 作数送的数据口

SMC1602_En //开启使能

SMC1602_Dis //禁止使能

}

void SMC1602_WriteCGRAM(uchar *write_buf,uchar start_loca,uchar word_num,uchar start_addr) //SMC1602写CGRAM函数,用于自定义字符

{

uchar i,j

write_buf+=start_loca //指向"需写入数据数组"的起始位置

SMC1602_WriteByte(CommOperate,CGRAMAddr|start_addr<<3) //写CGRAM *** 作,并将CGRAM起始地址设为 start_addr

for(j=0j<word_numj++) //自定义字符数量

for(i=0i<8i++) SMC1602_WriteByte(DataOperate,*write_buf++) //写入贺衫好一个自定义字符塌春8个字节数据

}

void SMC1602_Init() //1602液晶屏初始化函数

{

uint i

SMC1602_WriteByte(CommOperate,DisplayMode) //显示模式设置:16×2显示,5×7点阵,8位数据接口

SMC1602_WriteByte(CommOperate,ScreenMode|ScreenOn) //光标模式设置:开启整体显示,开启光标显示,开启光标闪烁

SMC1602_WriteByte(CommOperate,InputMode) //输入方式设置:关闭整屏移动,开启光标正移动(+1)

SMC1602_WriteByte(CommOperate,CleanLCD) //清屏,复位光标

SMC1602_WriteByte(CommOperate,FirstCol) //定位第一行

for(i=150ii--) //等待电源稳定,否则写CGRAM数据(自定义字符)时容易丢失,uint执行周期长,用uchar将会缩短时间,不足以稳定LCD

}

//1602 四线制驱动程序,根据需要自己改端口定陵猛义和延时

#define LINE1 0

#define LINE2 1

#define LINE1_HEAD 0x80

#define LINE2_HEAD 0xC0

#define CLEARSCREEN LCD_en_com(0x01)LCD_delay(30)

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

//change this part at different board

sbit DB7=P2^7

sbit DB6=P2^6

sbit DB5=P2^5

sbit DB4=P2^4

sbit LCD1602_RS=P2^1 //data command select 1 data 0 command pin 4

sbit LCD1602_RW=P2^2 //read write select 1 read 0 write pin 5

sbit LCD1602_EN=P2^3 /尺渣桥/LCD enable signal pin 6

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

void LCD_delay(unsigned int n)

{

unsigned int i=0,j=0

for (i=ni>0i--)

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

}

void LCD_en_com(unsigned char command)

{

DB7=(command>>7)%2

DB6=(command>>6)%2

DB5=(command>>5)%2

DB4=(command>>4)%2

LCD1602_RS = 0 //RS 0

LCD1602_RW = 0 //RW 0

LCD1602_EN = 1 //EN --\|/__ Write command

LCD_delay(2)

LCD1602_EN = 0

DB7=(command>>3)%2

DB6=(command>>2)%2

DB5=(command>>1)%2

DB4=(command>>0)%2

LCD1602_RS = 0 //RS 0

LCD1602_RW = 0 //RW 0

LCD1602_EN = 1 //EN --\|/__ Write command

LCD_delay(2)

LCD1602_EN = 0

}

void LCD_en_dat(unsigned char command)

{

DB7=(command>>7)%2

DB6=(command>>6)%2

DB5=(command>>5)%2

DB4=(command>>4)%2

LCD1602_RS = 1 /梁神/RS 1

LCD1602_RW = 0 //RW 0

LCD1602_EN = 1 //EN --\|/__ Write data

LCD_delay(2)

LCD1602_EN = 0

DB7=(command>>3)%2

DB6=(command>>2)%2

DB5=(command>>1)%2

DB4=(command>>0)%2

LCD1602_RS = 1 //RS 1

LCD1602_RW = 0 //RW 0

LCD1602_EN = 1 //EN --\|/__ Write data

LCD_delay(2)

LCD1602_EN = 0

}

void LCD_set_xy(unsigned char x,unsigned char y)

{

unsigned char address

if(y == LINE1)

address = LINE1_HEAD + x

else

address = LINE2_HEAD + x

LCD_delay(10)

LCD_en_com(address)

}

void LCD_write_string(unsigned char x,unsigned char y,unsigned char *s)

{

LCD_set_xy(x,y)

while(*s)

{

LCD_en_dat(*s)

s++

}

}

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

void InitTimer0(void)//200us

{

TMOD = 0x01

TH0 = 0x0FE

TL0 = 0x70

EA = 1

ET0 = 1

TR0 = 1

}

unsigned char LCD_ContCount=0

sbit LCDCONT=P2^0

void Timer0Interrupt(void) interrupt 1

{

TH0 = 0x0FE

TL0 = 0x70

if(LCD_ContCount<LCD_CONTRAST){LCDCONT=0}

else{LCDCONT=1}

LCD_ContCount++

if(LCD_ContCount==100){LCD_ContCount=0}

}

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

void LCD_init(void)

{

LCD_delay(50)

LCD_en_com(0x33)//原来1602初始化成4位数据线之前必需先初始化成8位(此时命令发送方式是8位格式,但数据线只需接4位)

LCD_delay(10)

LCD_en_com(0x32)//然后再改到4位线宽,这样初始化才稳定

LCD_delay(10)

LCD_en_com(0x28)//四线模式设置

LCD_delay(10)

LCD_en_com(0x0c)//显示开--对应开关显示控制指令

LCD_delay(10)

CLEARSCREEN

InitTimer0()

}

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

至于AD,用片上自带的AD就行,没有具体的电路,只能帮你这些了。

另:楼上说用ADC0834的,STC12C5A60S2已经有AD了啊


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存