通过MSComm控件进行WINCC串口通讯总结_第1页
通过MSComm控件进行WINCC串口通讯总结_第2页
通过MSComm控件进行WINCC串口通讯总结_第3页
通过MSComm控件进行WINCC串口通讯总结_第4页
通过MSComm控件进行WINCC串口通讯总结_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

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

文档简介

通过MSComm控件进行WINCC串口通讯总结目的:通过MSComm控件实现WINCC串口通讯(C脚本和VB脚本两种方式)

测试环境:操作系统win7

WINCC版本:V7.2

帮助工具:串口调试工具

ASPD虚拟串口工具

测试WINCC组态画面:

测试试验过程画面:

1、通过VB实现串口通讯

画面对象“打开画面”VB大事脚本:

SubOnOpen()

DimobjMSComm,tagConnection

SetobjMSComm=hmiRuntime.Screens("串口通讯VB版").ScreenItems("COM")

SettagConnection=HMIRuntime.Tags("tagConnection1")

IfobjMSComm.PortOpen=FalseThen

'Assigncomportnumber

objMSComm.Commport=4

'Values:9600Baud,N-NoParity,8-Databit,1-Stopbit

objMSComm.Settings="9600,N,8,1"

objMSComm.RThreshold=1

objMSComm.SThreshold=0

objMSComm.InBufferCount=0

objMSComm.InputLen=0

objMSComm.PortOpen=True

tagConnection.Write(True)

HMIRuntime.Trace("Portopen."vbCrLf)

Else

HMIRuntime.Trace("Portisalreadyopened."vbCrLf)

EndIf

EndSub

MSComm控件OnComm对象大事:

SubOnOpen()

DimobjMSComm,tagConnection

SetobjMSComm=HMIRuntime.Screens("串口通讯VB版").ScreenItems("COM")

SettagConnection=HMIRuntime.Tags("tagConnection1")

IfobjMSComm.PortOpen=FalseThen

'Assigncomportnumber

objMSComm.Commport=4

'Values:9600Baud,N-NoParity,8-Databit,1-Stopbit

objMSComm.Settings="9600,N,8,1"

objMSComm.RThreshold=1

objMSComm.SThreshold=0

objMSComm.InBufferCount=0

objMSComm.InputLen=0

objMSComm.PortOpen=True

tagConnection.Write(True)

HMIRuntime.Trace("Portopen."vbCrLf)

Else

HMIRuntime.Trace("Portisalreadyopened."vbCrLf)

EndIf

EndSub

“SEND按钮”鼠标左键按下大事:

SubOnLButtonDown(ByValItem,ByValFlags,ByValx,ByValy)

DimobjMSComm

DimstrTemp,buffer

HMIRuntime.Trace("Communication!"vbCrLf)

SetobjMsComm=HMIRuntime.Screens("串口通讯VB版").ScreenItems("COM")

Setbuffer=HMIRuntime.Tags("Buffer1")

strTemp=buffer.Read

IfobjMSComm.PortOpen=TrueThen

IfstrTemp""then

objMSComm.Output=strTemp

EndIf

EndIf

EndSub

2、通过C脚本实现串口通讯

画面对象“打开画面”C大事脚本:

#include"apdefap.h"

voidOnOpenPicture(char*lpszPictureName,char*lpszObjectName,char*lpszPropertyName)

{

#defineGetObjectGetObject

__object*pdl=NULL;

__object*pic=NULL;

__object*obj=NULL;

inti,j;

pdl=__object_create("PDLRuntime");

if(pdl)

{

printf("portopengetpdlok");

}

pic=pdl-GetPicture("串口通讯C版");

if(pic)

{

printf("portopengetpicok");

}

obj=pic-GetObject("COM");

if(obj)

{

printf("portopengetobjok");

}

if(obj-PortOpen==0)

{

obj-Commport=3;

obj-Settings="9600,N,8,1";

obj-RThreshold=1;

obj-SThreshold=0;

obj-InBufferCount=0;

obj-InputLen=0;

obj-PortOpen=1;

}

__object_delete(obj);

__object_delete(pic);

__object_delete(pdl);

}

MSComm控件OnComm对象大事:

#include"apdefap.h"

voidOnComm(char*lpszPictureName,char*lpszObjectName)

{

#defineGetObjectGetObject

__object*pdl=NULL;

__object*pic=NULL;

__object*obj=NULL;

char*data="";

pdl=__object_create("PDLRuntime");

if(pdl)

{

printf("portopengetpdlok");

}

pic=pdl-GetPicture("串口通讯C版");

if(pic)

{

printf("portopengetpicok");

}

obj=pic-GetObject("COM");

if(obj)

{

printf("portopengetobjok");

}

SetTagChar("BufferTemp",obj-Input);

printf("BufferTemp:%s",GetTagChar("BufferTemp"));

if(strcmp(GetTagChar("BufferTemp"),""))

{

SetTagChar("Buffer1",GetTagChar("BufferTemp"));

}

__object_delete(obj);

__object_delete(pic);

__object_delete(pdl);

}

“SEND按钮”鼠标左键按下大事:

#include"apdefap.h"

voidOnLButtonDown(char*lpszPictureName,char*lpszObjectName,char*lpszPropertyName,UINTnFlags,intx,inty)

{

#defineGetObjectGetObject

__object*pdl=NULL;

__object*pic=NULL;

__object*obj=NULL;

char*data="";

pdl=__object_create("PDLRuntime");

if(pdl)

{

printf("portopengetpdlok");

}

pic=pdl-GetPicture("串口通讯C版");

if(pic)

{

printf("portopengetpicok");

}

obj=pic-GetObject("COM");

if(obj)

{

printf("

温馨提示

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

评论

0/150

提交评论