plc在液晶屏直接显示数字

plc在液晶屏直接显示数字,第1张

百度知道

plc如何在显示屏显示字母

乔Qwo

TA获得超过235个赞

首先安装组态软件wincc与plc通讯,再把组态的数据通过pc串口和dvi口传送给led显示屏,如plc中计数器是c0,在显示器上设置一个数值输入单元地址数据寄存器d10,并设置一个输入保存按钮m10瞬间型,在显示器上设置好要修改的数值后按输入保存按钮m10,在plc程序中写入m10同时movd10c0即可显示字母。

PLC是一种存储程序的控制器,用户根据某一对象的具体控制要求,编制好控制程序后,用编程器将程序输入到PLC(或用计算机下载到PLC)的用户程序存储器中寄存。PLC的控制功能就是通过运行用户程序来实现。

工作方式输入扫描:PLC在执行程序之前,首先扫描输入端子,按顺序将所有输入信号读入寄存器-输入状态的输入映像寄存器中,这个过程为扫描。PLC在运行程序时,所需的输入信号不是取输入端子上的信息,而是取输入映像寄存器中的信息。而且采样结果不会在本工作周期内改变,只有到下一个扫描阶段才会改变。程序执行:PLC完成扫描后,按顺序从0号地址开始的程序进行逐条扫描执行。结果是保存在输出映像寄存器中。输出刷新:在执行完用户所有程序后,PLC上将输出映像寄存器中的内容送到锁存器中进行输出,驱动用户设备,扫描时间取决与输出模块的数量。

①问,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

}

#include<reg52.h>

#define uchar unsigned char

#define uint unsigned int

sbit dula=P2^6

sbit wela=P2^7

sbit lcden=P3^4

sbit lcdrs=P3^5

sbit key1=P3^0

sbit key2=P3^1

sbit key3=P3^2

//sbit key4=P3^3

sbit key=P3^7

void display()

void delayms(uint z)

void keysscan()

void init()

void write_com(uchar com)

void write_data(uchar date)

uchar num,num1,num2num3,num4

uchar sshi,sge,fshi,fge,mshi,mge

uint temp=0

void init() //初始化

{

dula=0

wela=0

TMOD=0x01

TH0=(65536-45872)/256

TH1=(65536-45872)%256

EA=1

ET0=1

TR0=1

lcden=0

write_com(0x38)

write_com(0x0c)

write_com(0x06)

write_com(0x01)

}

void write_com(uchar com) //写指令

{

lcdrs=0

P0=com

delayms(5)

lcden=1

delayms(5)

lcden=0

}

void write_data(uchar date)//写数据

{

lcdrs=1

P0=date

delayms(5)

lcden=1

delayms(5)

lcden=0

}

void delayms(uint z)//延时

{

uint i,j

for(i=zi>0i--)

for(j=110j>0j--)

}

void display()//液晶屏显示

{

write_com(0x80)

write_data(sshi+48)

delayms(1)

write_com(0x80+0x01)

write_data(sge+48)

delayms(1)

write_com(0x80+0x02)

write_data(':')

delayms(1)

write_com(0x80+0x03)

write_data(fshi+48)

delayms(1)

write_com(0x80+0x04)

write_data(fge+48)

delayms(1)

write_com(0x80+0x05)

write_data(':')

delayms(1)

write_com(0x80+0x06)

write_data(mshi+48)

delayms(1)

write_com(0x80+0x07)

write_data(mge+48)

delayms(1)

}

void keysscan()

{

key=0

if(key1==0)

{

delayms(5)

if(key1==0)

{

while(!key1)

temp++

TR0=0

write_com(0x0f)

}

}

switch(temp)

{

case 1:

if(key2==0)

{

delayms(5)

if(key2==0)

{

while(!key2)

num1++

if(num1==60)num1=0

}

}

if(key3==0)

{

delayms(5)

if(key3==0)

{

while(!key3)

num1--

if(num1==-1)num1=0

}

}

break

case 2:

{

if(key2==0)

{

delayms(5)

if(key2==0)

{

while(!key2)

num2++

if(num2==60)num2=0

}

}

if(key3==0)

{

delayms(5)

if(key3==0)

{

while(!key3)

num2--

if(num2==-1)num2=0

}

}

}

break

case 3:

{ if(key2==0)

{

delayms(5)

if(key2==0)

{

while(!key2)

num3++

if(num3==60)num3=0

}

}

if(key3==0)

{

delayms(5)

if(key3==0)

{

while(!key3)

num3--

if(num3==-1)num3=0

}

}

}

break

case 4:

{

temp=0

TR0=1

write_com(0x08)

}

}

}

void T0_time()interrupt 1 //时钟0中断

{

num++

TH0=(65536-45872)/256

TH1=(65536-45872)%256

if(num==20)

{

num=0

num1++

if(num1==60)

{

num1=0

num2++

}

mshi=num1/10

mge=num1%10

if(num2==60)

{

num2=0

num3++

}

fshi=num2/10

fge=num2%10

if(num3==24)

{

num3=0

// num4++

}

sshi=num3/10

sge=num3%10

//if(num4)

display()

}

}

void main()

{

init()

while(1)

{

keysscan()

}

}


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

原文地址:https://54852.com/yw/11177570.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存