Login
升级VIP 登录 注册 安全退出
当前位置: 首页 > word文档 > 其他文档 > WinCC-Vbs中文手册

WinCC-Vbs中文手册

收藏

本作品内容为WinCC-Vbs中文手册,格式为 doc ,大小 28395 KB ,页数为 20页

WinCC-Vbs中文手册


("可以使用VBSWinCC对所有图形编辑器对象进行访问,以使图形运行环境动态化。根据变量或周期性(例如闪烁)情况,可在执行操作(例如在按钮上单击鼠标)时使图形对象动态化。以下示例说明如何在鼠标单击后更改图形对象。步骤在以下示例中,每次单击鼠标时运行系统中圆的半径都会设置为20:DimobjCircleSetobjCircle=ScreenItems(Circle1)objCircle.Radius=202.实例:定义对象的颜图形对象的颜色通过RGB值(红/绿/蓝)定义。可以设置或读出图形对象的颜色值。步骤以下示例将“ScreenWindow1”的填充颜色定义为蓝色:DimobjScreenSetobjScreen=HMIRuntime.Screens(ScreenWindow1)objScreen.FillStyle=131075objScreen.FillColor=RGB(0,0,255)3.例:如何组态语言切换1/18可使用VBS切换WinCC的运行系统语言。最常用的是包含相应语言代码的按钮,这些按钮位于项目的起始页上。在VBS中通过使用国家代码(例如,1031表示德语-默认,1033表示英语-美国等)指定运行系统语言。有关所有国家代码的汇总,请参见标题为“区域方案ID(LCID)图”的主题下的VBScript基本知识。步骤:使用按钮上的“Mouseclick”事件创建VBS动作,输入以下动作代码将运行系统语言切换为德语:HMIRuntime.Language=1031可以使用VBS终止WinCC运行系统,例如,通过鼠标单击,依靠变量值或其它事件(例如,启动运行系统时密码的多次错误输入)。要执行的操作以下示例会终止WinCC运行系统:HMIRuntime.Stop5.实例:全局组态画面更改简介VBS可用于启动全局画面更改,因而会在分布式系统的客户机上显示服务器中的画面。为此,服务器的服务器前缀必须位于目标画面之前。要执行的操作为按钮组态以下画面更改代码,例如:HMIRuntime.BaseScreenName=Serverprefix::Newscreen2/186.实例:通过属性组态画面更改简介如果在组态中使用分区画面(例如,在用户界面的基本画面标题和操作栏中和用于实际画面显示的嵌入画面窗口中),应使用画面窗口的属性组态画面更改。为了显示其它画面,必须更改“ScreenName”画面窗口的属性。必须在同一画面中对动作和画面窗口进行组态。要执行的操作在以下示例中,执行动作时“ScreenWindow”画面窗口中会显示“test.pdl”画面:DimobjScrWindowSetobjScrWindow=ScreenItems(ScreenWindow)objScrWindow.ScreenName=est7.实例:通过Trace组态诊断输出简介在动作中调用的过程的跟踪。Trace指令以“HMIRuntime.Trace()”形式输入。GSC诊断显示来自C和VBS的跟踪输出。要执行的操作以下示例将文本写入诊断窗口中:HMIRuntime.TraceCustomizederrormessage3/188.实例:写入变量值可以用VBS将变量值写入PLC中,例如通过在按钮上单击鼠标来指定设定值,或设置内部变量值,以触发其它动作。下面涉及和介绍了多种写入变型。1)简单写入在以下示例中,将值写入“Tag1”变量内:HMIRuntime.Tags(Tag1).Write6这是最简单的写入形式,因为不会生成任何对象引用。2)通过对象引用写入在以下示例中,将创建变量对象的本地副本并将值写入“Tag1”内:DimobjTagSetobjTag=HMIRuntime.Tags(Tag1)objTag.Write73)通过利用引用,可以在写入之前使用变量对象。可以读取变量值,进行计算,并再次写入:DimobjTagSetobjTag=HMIRuntime.Tags(Tag1)objTag.ReadobjTag.Value=objTag.Value+1objTag.Write此类写入通过将附加的可选参数指定为值1来实现:4/18DimobjTagSetobjTag=HMIRuntime.Tags(Tag1)objTag.Value=8objTag.Write,1说明请注意,这种调用比标准调用使用的时间要长。除此之外,持续时间还取决于通道和AS。这类写入遵从C脚本中的SetTagXXXWait()调用5)通过状态处理写入为了确保成功写入值,必须在写入过程之后执行错误检查或确定变量状态。为此,执行写入操作后需检查“LastError”属性。测试成功(即成功放置任务)后,即检查变量状态。对于写入任务,过程的当前状态尚不确定。要确定该状态,必须读取变量。读取过程之后“质量代码”属性中指定的值会提供变量状态指示,如有必要,还会涉及发生故障的AS连接。在以下示例中,将写入“Tag1”变量。如果写入期间出现错误,全局脚本诊断窗口中会显示错误值和错误描述。最后,检查质量代码。如果质量代码不是OK(0x80),便在诊断窗口中显示该代码DimobjTagSetobjTag=HMIRuntime.Tags(Tag1)objTag.Write9If0<>objTag.LastErrorThen5/18HMIRuntime.TraceError:&objTag.LastError&vbCrLf&ErrorDescription:&objTag.ErrorDescription&vbCrLfElseobjTag.ReadIf&H80<>objTag.QualityCodeThenHMIRuntime.TraceQualityCode:0x&Hex(objTag.QualityCode)&vbCrLfEndIfEndIf写入变量后,由于不知道哪一质量代码在过程中用于管理变量,因此局部变量对象的QualityCode属性会设置为“BAD已不能用”。9.实例:如何读取变量值简介可以用VBS读取变量值并对其执行进一步的处理。这样便可以执行诸如通过在按钮上单击鼠标来获取系统状态信息或执行计算的操作。下面涉及和介绍了多种读取变型。1)简单读取在以下示例中,将读取“Tag1”的值并在全局脚本诊断窗口中显示该值:HMIRuntime.TraceValue:&HMIRuntime.Tags(Tag1).Read&vbCrLf6/18这是最简单的读取形式,因为不会生成任何对象引用。2)通过对象引用读取在以下示例中,将生成变量对象的本地副本,读取该变量值并在全局脚本诊断窗口中显示该值:DimobjTagSetobjTag=HMIRuntime.Tags(Tag1)HMIRuntime.TraceValue:&objTag.Read&vbCrLf通过利用引用可以使用变量对象。可以读取变量值,进行计算,并再次写入:DimobjTagSetobjTag=HMIRuntime.Tags(Tag1)objTag.ReadobjTag.Value=objTag.Value+1objTag.Write使用Read方法将已读取的过程变量添加到图像,从该刻起这些变量会通过AS周期性请求。如果该变量已存在于图像中,则会返回其中包含的值。对于关闭画面,变量动作会再次结束。说明如果全局脚本动作中请求变量,则在进入WinCC运行系统的整个过程中,该变量保持已注册状态3)直接读取7/18如果将读取过程的可选参数设置为1,则不会周期性地登录变量,而是通过AS单次请求该值。DimobjTagSetobjTag=HMIRuntime.Tags(Tag1)HMIRuntime.TraceValue:&objTag.Read(1)&vbCrLf说明请注意,这种调用比标准调用使用的时间要长。除此之外,持续时间还取决于通道和AS。在执行周期性C动作的情况下,必须避免该类调用,因为这是引起性能问题的主要原因。该类读取过程相当于C脚本中的GetTagXXXWait()调用。4)通过状态处理读取为了确保值有效,应在读取之后进行检查。这通过控制质量代码来执行。在以下示例中,将读取“myWord”变量,然后检查QualityCode。如果质量代码未对应OK(0x80),则在全局脚本诊断窗口中显示LastError、ErrorDescription和QualityCode属性。DimobjTagSetobjTag=HMIRuntime.Tags(Tag1)objTag.ReadIf&H80<>objTag.QualityCodeThenHMIRuntime.TraceError:8/18&objTag.LastError&vbCrLf&ErrorDescription:&objTag.ErrorDescription&vbCrLf&QualityCode:0x&Hex(objTag.QualityCode)&vbCrLfElseHMIRuntime.TraceValue:&objTag.Value&vbCrLfEndIf说明如果读取期间出现错误,则QualityCode会设置为BADNON-SPECIFIC。因此,只需在VBS可实现对所有图形编辑器画面对象的属性的访问。运行期间可以读出各个属性以便进行修改或更改。以下示例说明了各种访问形式。1)属性的简单设置在以下示例中,画面中包含的“Rectangle1”对象的背景颜色被设置为红色ScreenItems(Rectangle1).BackColor=RGB(255,0,0)这是最简单的写入形式,因为不会生成任何对象引用说明如果不通过对象引用完成操作,则智能感知中只提供标准属性。本示例中使用的表达式形式仅适用于图形编辑器。对于全局脚本中的模拟动作,应使用HMIRuntime对象访问相应对象2)通过对象引用设置属性9/18对象的引用,并使用“Rectangle1”在以下示例中,将创建对画面中所包含将背景设置为红色:VBS标准函数RGB()DimobjRectangleSetobjRectangle=ScreenItems(Rectangle1)objRectangle.BackColor=RGB(255,0,0)必须更改多个对象属性时,引用非常有用。使用智能感知时,该过程即会列出所有对象属性。说明本示例中使用的表达式形式仅适用于图形编辑器。对于全局脚本中的模拟动作,应使用HMIRuntime对象访问相应对象3)通过画面窗口设置属性VBS提供两种可行的画面超越访问方法:图形编辑器中的对象使用“ScreenItems”通过画面窗口的Screen通过基本画面通过画面窗口引用使用“HMIRuntime.Screens”“Rectangle”类型对象的画面。SubOnLButtonUp(ByValItem,ByValFlags,ByValx,ByValy)DimobjRectangleSetobjRectangle=ScreenItems(ScreenWindow1).Screen.ScreenItems(Rectangle1)objRectangle.BackColor=RGB(255,0,0)EndSub4)通过基本画面引用10/18可通过HMIRuntime.Screens引用具有待修改对象的画面。该画面相对于基本画面的规范通过以下访问代码进行定义:[.][:]....[:]在以下示例中,将创建对“Rectangle1”画面中包含的“Screen2”对象的引用,并将背景颜色设置为红色。这种情况下,画面“Screen2”位于“Screen1”中。“Screen1”显示在基本画面“BaseScreen”中。DimobjRectangleSetobjRectangle=HMIRuntime.Screens(BaseScreen.ScreenWindow1:Screen1.ScreenWindow1:Screen2).ScreenItems(Rectangle1)objRectangle.BackColor=RGB(255,0,0)无需指定画面名称。可以通过画面窗口名称唯一地访问某一画面。因此,只需指定画面窗口的名称,如下示例所示:DimobjRectangleSetobjRectangle=HMIRuntime.Screens(ScreenWindow1.ScreenWindow2).ScreenItems(Rectangle1)objRectangle.BackColor=RGB(255,0,0)这种访问类型可实现在不同画面中访问画面窗口中的对象。就画面模块技术而言,这是特别有趣的一点。基于属性的动作不仅能由事件触发或周期性触发,而且能直接通过动作使属性动态化。11/18在以下示例中,通过返回值使对象的背景颜色动态化。例如,传送的值可能来自PLC中事件的评估,并用于运行状态的图形显示:FunctionBackColor_Trigger(ByValItem)BackColor_Trigger=RGB(125,0,0)EndFunction说明动作的对象属性动态化,则只有在相对如果通过脚本的返回值使具有VBS于上次运行的脚本对象属性值发生更改时才会写入该值。如果该值已在另一位置发生更改则无效。脚本)的返回值来更改脚本或VBS因此,通过从另一位置(例如,其它CVBS动作生成的动态属性是非法的。由如果不遵守这一点,则结果可能是错误的值。2)实例:组态数据库连接通过VBS简介数据库链接。ODBC驱动器组态Access以下示例说明如何通过的变量值写入Access数据库中。将示例1WinCC变量中。从数据库读取值并将其写入WinCC2示例这些示例不包含任何处理故障。1.通过WINCC_DATA表和ID在其中作为自动值的的列(ID,TagValue)来创建Access数据库。2.设置名称为“SampleDSN”的ODBC数据源,引用以上Access数据库。3.编程。12/183)示例1DimobjConnectionDimstrConnectionStringDimlngValuestrConnectionString=Provider=MSDASQL;DSN=SampleDSN;UID=;PWD=;lngValue=HMIRuntime.Tags(Tag1).ReadstrSQL=INSERTINTOWINCC_DATA(TagValue)VALUES(&lngValue&);SetobjConnection=CreateObject(ADODB.Connection)objConnection.ConnectionString=strConnectionStringobjConnection.OpenSetobjCommand=CreateObject(ADODB.Command)WithobjCommand.ActiveConnection=objConnection.CommandText=strSQLEndWithobjCommand.ExecuteSetobjCommand=NothingobjConnection.CloseSetobjConnection=Nothing13/184)步骤、示例21.创建名称为dbValue的WinCC变量。2.使用WINCC_DATA表和ID,TagValue列创建Access数据库:ID,创建TagValue(ID作用自动值)。3.设置名称为“SampleDSN”的ODBC数据源,引用以上Access数据库。4.编程。DimobjConnectionDimobjCommandDimobjRecordsetDimstrConnectionStringDimlngValueDimlngCountstrConnectionString=Provider=MSDASQL;DSN=SampleDSN;UID=;PWD=;strSQL=selectTagValuefromWINCC_DATAwhereID=1SetobjConnection=CreateObject(ADODB.Connection)objConnection.ConnectionString=strConnectionStringobjConnection.OpenSetobjRecordset=CreateObject(ADODB.Recordset)SetobjCommand=CreateObject(ADO14/18DB.Command)objCommand.ActiveConnection=objConnectionobjCommand.CommandText=strSQLSetobjRecordset=objCommand.ExecutelngCount=objRecordset.Fields.CountIf(lngCount>0)ThenobjRecordset.movefirstlngValue=objRecordset.Fields(0).ValueHMIRuntime.Tags(dbValue).WritelngValueElseHMIRuntime.TraceSelectionreturnednofields&vbNewLineEndIfSetobjCommand=NothingobjConnection.CloseSetobjRecordset=NothingSetobjConnection=Nothing启用与ODBC数据源的连接。相应的语法为:[Provider=MSDASQL;]{DSN=nameFileDSN=filename};[DATABASE=database;]UID=user;PWD=password其它MicrosoftOLEDB提供程序(例如MSJet、MSSQLServer)可以不使用DSN运行。相应的语法为:15/18[Provider=provider;]DRIVER=driver;SERVER=server;DATABASE=database;UID=user;PWD=password5)实例:使用MS自动化接口简介以下三个示例说明了如何使用MS自动化接口。1)示例1:MSExcel本示例中将输入域的输出值写入Excel表中。DimobjExcelAppSetobjExcelApp=CreateObject(Excel.Application)objExcelApp.Visible=True'ExcelExample.xlsistocreatebeforeexecutingthisprocedure.'ReplacewiththerealpathofthefileExcelExample.xls.objExcelApp.Workbooks.Open\\ExcelExample.xlsobjExcelApp.Cells(4,3).Value=ScreenItems(IOField1).OutputValueobjExcelApp.ActiveWorkbook.SaveobjExcelApp.Workbooks.CloseobjExcelApp.QuitSetobjExcelApp=Nothing2)示例2:MSAccessSetobjAccessApp=CreateObject(Access.Application)objAccessApp.Visible=True16/18'DbSample.mdbandRPT_WINCC_DATAhavetocreatebeforeexecuting'thisprocedure.'ReplacewiththerealpathofthedatabaseDbSample.mdb.objAccessApp.OpenCurrentDatabase\\DbSample.mdb,FalseobjAccessApp.DoCmd.OpenReportRPT_WINCC_DATA,2objAccessApp.CloseCurrentDatabaseSetobjAccessApp=Nothing本示例将打开MSIE。DimobjIEobjIE.Navigatehttp:DoLoopWhileobjIE.BusyobjIE.Resizable=TrueobjIE.Width=500objIE.Height=500objIE.Left=0objI17/18E.Top=0objIE.Visible=True6)实例:启动外部应用程序简介DimobjWshShellSetobjWshShell=CreateObject(Wscript.Shell)objWshShell.RunNotepadExample.txt,118/18",)


  • 编号:1700753494
  • 分类:其他文档
  • 软件: wps,office word
  • 大小:20页
  • 格式:docx
  • 风格:商务
  • PPT页数:28395 KB
  • 标签:

广告位推荐

相关其他文档更多>