计算机与PLC地通讯格式和实现方法_第1页
计算机与PLC地通讯格式和实现方法_第2页
计算机与PLC地通讯格式和实现方法_第3页
计算机与PLC地通讯格式和实现方法_第4页
计算机与PLC地通讯格式和实现方法_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1引言可编程序控制器(PLC)都有一个编程口。以日本三菱公司生产的PLC为例(包括FX系列和A系列),其编程口为RS-422格式,根据PLC型号不同又分为8针座编程口和25针座编程口。对于后者,可直接将SC—08编程电缆将PLC的编程口和微型计算机的RS—232口连接起来;对于后者,则还需要一根转换电缆将PLC的8针座编程口和25针编程电缆相连。无论何种情况,一旦将PLC用户程序由微型计算机编程环境传到PLC用户程序区,其编程口大多就没有被再利用。其实,这是一种浪费。也就是说,可利用此编程口实现微型计算机和PLC的数据通讯,将PLC的工作状态纳入微型计算机管理之下。2编程口操作命令类型与通讯端口初始化串行通讯是计算机与其它机器之间进行通讯的一种常用方法,在WINDOWS操作系统中提供了实现各种串行通讯的API函数。通过SC—08编程电缆或FX232AW模块,可将微型计算机的串行通讯口RS—232和PLC的编程口连接起来,这样微型计算机就可对PLC的RAM区数据进行读、写操作。由PLC本身所具有的特性,可对PLC进行以下四种类型的操作:(1)位元件或字元件状态读操作(CMD0);(2)位元件或字元件状态写操作(CMD1);(3)位元件强制ON操作(CMD7);(4)位元件强制OFF操作(CMD8)。另外,在进行上述四类操作以前,首先要对端口进行初始化操作,即设定通讯协议(包括设置通讯波特率、数据位数、数据停止位及奇偶校验)。在WINDOWS的SDK中定义了一个结构DCB,该结构详细地说明了如何对通讯端口进行控制,所以通讯端口的初始化也是围绕着对这个结构的正确设置为中心进行的。用VC++语言实现端口初始化如下:BOOLCSerial::Open(intnPort){//nPort为微型计算机串行通讯口端口号。nport=1为端口1;nPort=2为端口2。charszPort\\[15\\];DCBdob;m_hIDComDev=CreateFile(szPort,GENERIC_READ│GENERIC_WRITE,O,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL│FILE_FLAG_OVERLAPPED,NULL);dcb.DCB1ength=sizeof(DCB);GetCommState(m_hIDComDev,&dcb);//取得通讯资源当前设置dcb.BaudRate=9600;//设定波特率为9600dcb.ByteSize=7;//7数据位dcb.Parity=2;//偶校验dcb.StopBits=0;//设定1个停止位if(SetCommState(m_hIDComDev,&dcb)return(TRUE);elsereturn(FALSE);//设置端口,若设置成功则返回TRUE,否则返回FALSE}需要说明的是CSerial是一个用于串行通讯的类,它包含了进行串行通讯的所需的函数。除上述端口初始化成员函数Open外,还包括另两个重要成员函数:一个是endData,把数据从一个缓冲区发送到串行端口。另一个是ReadData,从端口的接收缓冲区中读入数据。其次,在每进行一次上述四类操作中的一种操作以前,还要进行握手联络。对PLC发请求讯号ENQ(代码为OX05),然后读PLC的响应讯号。如果读到的响应讯号为ACK(代码为OX06),则表示PLC已准备就绪,等待接收通讯数据。握手联络VC++语言示PLC已准备就绪,等待接收通讯数据。握手联络VC++语言实现为:BOOLCNTJD1g::ReadFromPLC(char*Read_charchar*Read_address,intRead_bytes){CSerialSerial;//用于串行通讯的类charread_BUFFER;if(Serial.Open(2)//初始化串行口通讯口COM2{Serial.SendData(&ENQ_request,1);//发送联络讯号Sleep(1000);//等待1秒钟Serial.ReadData(&read_BUFFER,1);//读取PLC响应讯号if(read_BUFFER==ACK){如果PLC响应讯号等于ACK,则进行上述四种操作:}}Serial.Close()://操作完毕后,关闭通讯口}3编程口命令操作(1)位元件或字元件状态读操作操作对象元件:PLC内部的X、Y、M、S、T、C、D元件;命令格式:说明:①为读命令起始标志STX,代码为OX02;②为位元件或字元件状态读命令CMDO,命令代码为OX30;③为读位元件或字元件的4位起始地址,高位先发,低位后发,且是以ASCII码的形式发送;④为一次读取位元件或字元件的个数,最多一次可读取OXff个字节的元件,以ASCII码的形式发送;⑤为停止位标志ETX,代码为OX03;⑥为2位和校验,和累计为②、③、④项代码,取其和最低两位转化成ASCII码,高位先发,低位后发。在发送完上述命令格式代码后,就可直接读取PLC响应的信息。响应信息格式如下VC++语言实现:BOOLCNTJDlg::ReadFromPLC(char*Read_charchar*Read_address,intRead_bytes){charsenddatasum_CHECK\\[2\\];charreaddatasum_CHECK\\[2\\];chartotal_DATABYTES\\[2\\];charreaddatasum_check\\[2\\];intreaddata_sum;intdatasum_check=0;inti;Serial.SendData(&STX_start,1);/向PLC发送“开始”标志代码Serial.SendData(&CMDO_read,1);//发送“读”命令代码datasum_check+=CMDO_read;for(i=0;i<4;i++){Serial.SendData(&Read_address\\[i\\],1);//发送起始元件地址的ASCII代码datasum_check+=Read_address\\[i\\];}ChangetoASCII(totalDATABYTES,Read_bytes);//将字节数转化成ASCII代码for(i=0;i<2;i++){Serial.SendData(&total_DATABYTES\\[i\\],1);//发送元件字节数的ASCII代码)datasum_check+total_DATABYTES\\[i\\];}Serial.SendData(&ETX_end,1);//发送“结束”标志代码senddatasum_CHECK+ETX_end;Change_to_ASCII(senddatasum_CHECK,senddatasum_CHECK);//将“和”转化成ASCII码for(i=0;i<2;i++)Serial.SendData(&senddatasum_CHECK\\[i\\],1);Sleep(1000);//等待PLC响应Serial.ReadData(&read_BUFFER,1);if(read_BUFFER==STX_start){readdata_sum=0;for(i=0;i<2*Read_bytes;i++){Serial.ReadData(&Read_char\\[i\\],1);//读Read_bytes个字节readdata_sum+Read_char\\[i\\];}Serial.ReadData(&read_BUFFER,1);if(read_BUFFER==ETX_end){Serial.ReadData(readdatasum_CHECK,2);//读入的“和”的低2位ASCII码Readdata_sum+=ETX_end;}Change_to_ASCII(readdatasum_check,readdata_sum);//将计算得到的“和”转化成ASCII码if(*readdatasum_CHECK==*readdatasum_check)//“和”校验{AfxMessageBox(“数据读出成功!”)returnTRUE;}else{AfxMessageBox(“校验错误”)returnFALSE.}}(2)位元件或字元件状态写操作操作对象元件:同3(1);命令格式:说明:①为写命令起始标志STX,代码为OX02;②为位元件或字元件状态写命令CMD1,命令代码为OX31;③为写位元件或字元件的4位起始地址,高位先发,低位后发,且是以ASCII码的形式发送;④为一次写入位元件或字元件的个数,以ASCII码的形式发送;⑤为待写到PLCRAM区的数据DATA,以ASCII码形式发送;⑥为停止位标志ETX,代码为OX03;⑦为2位和校验,和累计为②、③、④项代码,取其和最低两位转化成ASCII码,高位先发,低位后发。VC++语言实现:BOOLCNTJDlg::WritePLC(char*data_ADDRESS,char*Write_ASC,intbytesnumber){chartotal_BYTES\\[2\\];charsenddatasum_CHECK\\[2\\];charread_BUFFER;charread_finishBUFFER;intdatasum_check=0;inti=0;Serial.SendData(&STX_start,1);//向PLC发送“开始”标志代码datasum_check=0;Serial.SendData(&CMD1_write,1);//发送“写”命令代码datasum_check+CMD1_write;for(i=0;i<4;i++){Serial.SendData(&data_ADDRESS\\[i\\],1);//发送起始元件地址的ASCII码datasum_check+=data_ADDRESS\\[i\\];Change_to_ASCII(total_DATABYTES,bytesnumber);//将字节数转化成ASCII码for(i=0;i<2;i++){Serial.SendData(&total_BYTES\\,1);//发送元件字节数的ASCII代码datasum_check+=total_BYTES\\[i\\];}for{i=0;i{Serial.SendData(&Write_ASC\\[i\\],1);//发送要写入的数据的ASCII码datasum_check+=Write_ASC\\[i\\];}Serial.SendData(&ETX_end,1);//发送“结束”标志代码datasum_check+=ETX_end;Change_to_ASCII(senddatasum_CHECK,datasum_check);//将“和”转化成ASCII码Serial.SendData(&senddatasum_CHECK,2);Sleep(1000);Serial.ReadData(&read_finishBUFFER,1);if(read_finishBUFFER==ACK_reply){AfxMessageBox(“数据写入OK”)returnTRUE;}else{AfxMessageBox(“数据写入失败”)returnFALSE。}(3)位元件强制ON操作操作对象:X、Y、M、S、T、C元件;命令格式:说明:①为强制OFF命令起始标志STX,代码为OX02;②为强制OFF命令CMD8,命令代码为OX38H;③为强制OFF位元件4位起始地址,高位先发,低位后发,以ASCII码形式发送;④为停止位标志ETX,代码为OX03;⑤为2位和校验,和累计为②、③、④项代码,取其和最低两位转化成ASCII码,高位先发,低位后发。VC++语言实现:voidNTJDlg::ForceOffOperation(char*OFF_Address){inti;charSum_Check\\[2\\];charread_buffer;intSum=0;Serial.SendData(&STX_start,1);//向PLC发送“开始”标志代码Serial.SendData(&CMD8_ForceOFF,1);//发送“OFF”命令代码Sum=CMD8_ForceOFF;for(i=0;i<4;i++){Serial.SendData(&OFF_Address

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论