登录
首页 PLC论坛 海为Haiwell
回帖 发帖
正文

主题:VB与海为PLC通讯——海为通讯控件使用介绍

点击:1780 回复:3

在做自动化工程项目时常常需要用上位机对PLC进行监控,如果是大的工程项目可以使用组态软件来完成,但对中小项目为了节约成本,可以采用自己写上位机程序来完成对PLC的监控。
海为提供了一个海为PLC的通讯控件,通过这个控件实现上位机与海为PLC之间的通讯十分方便,它封装了Modbus通讯协议和HaiwellBus协议,以点的形式实现对海为PLC的数据访问,对每个点可以定义它的名称/数据类型/小数长度/点注释等,不必去了解Modbus通讯协议和HaiwellBus协议的具体内容,只要有上位机编程经验就可以完成。
海为PLC的通讯控件和例子源程序可以到海为网站(http://www.haiwell.com/download.asp)的“下载中心”下载。
下面以VB为例介绍该控件的使用,新建一个VB工程,添加2个窗口如下图:

附件
附件

窗口1的程序如下:
Option Explicit
'启动跑马灯按钮
Private Sub Command1_Click()
   '启动跑马灯,M0置1,点序号30
   HWPLCComm1.HWPLCs(1).SetPointValue 30, 1
End Sub
'停止跑马灯按钮
Private Sub Command2_Click()
   '停止跑马灯,M1置1,点序号31
   HWPLCComm1.HWPLCs(1).SetPointValue 31, 1
End Sub
'启动采样按钮
Private Sub Command3_Click()
' HWPLCComm1是海为PLC通讯控件名称,Timer1是画面刷新定时器
   HWPLCComm1.Run Not HWPLCComm1.RunFlag
   Timer1.Enabled = HWPLCComm1.RunFlag
   
   If HWPLCComm1.RunFlag Then
       Command3.Caption = "停止采样"
       Shape2.FillColor = vbGreen ‘采样指示灯绿色
   Else
       Command3.Caption = "启动采样"
       Shape2.FillColor = vbWhite ‘采样指示灯红色
   End If
End Sub
'窗口1装载
Private Sub Form_Load()
   Dim i As Long
   '添加1台PLC,PLC地址为1,名称为“1号PLC”
   HWPLCComm1.HWPLCs.AddPLC 1, "1号PLC"
   
   '在“1号PLC”下增加采样点
   For i = 0 To 15
       HWPLCComm1.HWPLCs(1).AddPoint "y" & i '增加采样点Y0-Y15
Next i
'在“1号PLC”下增加其他离散的采样点
   HWPLCComm1.HWPLCs(1).AddPoint "sv0", , "当前扫描时间 单位0.1ms"
   HWPLCComm1.HWPLCs(1).AddPoint "sv1", , "最小扫描时间 单位0.1ms"
   HWPLCComm1.HWPLCs(1).AddPoint "sv2", , "最大扫描时间 单位0.1ms"
   HWPLCComm1.HWPLCs(1).AddPoint "sv12", "Year", "年"
   HWPLCComm1.HWPLCs(1).AddPoint "sv13", "Month", "月"
   HWPLCComm1.HWPLCs(1).AddPoint "sv14", "Day", "日"
   HWPLCComm1.HWPLCs(1).AddPoint "sv15", "Hour", "时"
   HWPLCComm1.HWPLCs(1).AddPoint "sv16", "Minute", "分"
   HWPLCComm1.HWPLCs(1).AddPoint "sv17", "Second", "秒"
   HWPLCComm1.HWPLCs(1).AddPoint "sv18", "Week", "星期"
   HWPLCComm1.HWPLCs(1).AddPoint "sm3", , "10ms时钟脉冲"
   HWPLCComm1.HWPLCs(1).AddPoint "sm4", , "100ms时钟脉冲"
   HWPLCComm1.HWPLCs(1).AddPoint "sm5", , "1s时钟脉冲"
   HWPLCComm1.HWPLCs(1).AddPoint "m0", "Start", "跑马灯启动"
   HWPLCComm1.HWPLCs(1).AddPoint "m1", "Stop", "跑马灯停止"
   HWPLCComm1.HWPLCs(1).AddPoint "v0"
   HWPLCComm1.HWPLCs(1).AddPoint "v2"
   HWPLCComm1.HWPLCs(1).AddPoint "v100", , "实数例子", [REAL ] '实数类型为5
   HWPLCComm1.HWPLCs(1).AddPoint "ccv50", , "32位计数器"
   HWPLCComm1.HWPLCs(1).AddPoint "ccv100", , "16位计数器"
   
   '将点加到Listview中显示, Y0-Y15 16个点不加入,用指示灯来显示状态
   Dim Newitem As ListItem
   For i = 17 To HWPLCComm1.HWPLCs(1).PointCount
       Set Newitem = ListView1.ListItems.Add(, , i)
       Newitem.SubItems(1) = HWPLCComm1.HWPLCs(1).iPoints(i).PointAddress
       Newitem.SubItems(2) = HWPLCComm1.HWPLCs(1).iPoints(i).PointName
       Newitem.SubItems(4) = HWPLCComm1.HWPLCs(1).iPoints(i).PointNote
   Next i
'将PLC地址和名称用标签显示
   Label3(0) = HWPLCComm1.HWPLCs(1).PLCAddress
   Label3(1) = HWPLCComm1.HWPLCs(1).PLCName
   
'将16只指示灯的标签以点名称显示(Y0~Y15)
   For i = 1 To 16
       Label1(i - 1) = HWPLCComm1.HWPLCs(1).iPoints(i).PointName
   Next i
End Sub
'双击列表中的点打开窗口2,对该点的值进行修改
Private Sub ListView1_DblClick()
   Dim i As Long
   If Not ListView1.SelectedItem Is Nothing Then
       i = ListView1.SelectedItem.Index + 16
       Form2.vPointIndex = i
       Form2.Caption = "写入值 " & HWPLCComm1.HWPLCs(1).iPoints(i).PointName
       Form2.Label1.Caption = "写入值 " & HWPLCComm1.HWPLCs(1).iPoints(i).PointName & ":"
       Form2.Text1 = HWPLCComm1.HWPLCs(1).iPoints(i).PointValue
       Form2.Show 1
   End If
End Sub
' Timer1是画面刷新定时器
Private Sub Timer1_Timer()
   '刷新值
   Dim i As Long
   '刷新Y0-Y15值
   For i = 1 To 16
       If HWPLCComm1.HWPLCs(1).iPoints(i).PointValue = 1 Then
           Shape1(i - 1).FillColor = vbRed '值=1,为真
       Else
           Shape1(i - 1).FillColor = vbWhite '值=0,为假
       End If
   Next i
   '刷新其他点值
   For i = 17 To HWPLCComm1.HWPLCs(1).PointCount
       ListView1.ListItems(i - 16).SubItems(3) = HWPLCComm1.HWPLCs(1).iPoints(i).PointValue
   Next i
End Sub
窗口2的程序如下:
Option Explicit
Public vPointIndex As Long '公共变量,存储被双击点的序号
'确定按钮
Private Sub Command1_Click()
   If Text1.Text = "" Then Exit Sub
'按确定,则写入点的值
   Form1.HWPLCComm1.HWPLCs(1).SetPointValue vPointIndex, Text1.Text
   Unload Me
End Sub
'取消按钮
Private Sub Command2_Click()
   Unload Me
End Sub
Private Sub Text1_GotFocus()
   Text1.SelStart = 0
   Text1.SelLength = Len(Text1)
End Sub
Private Sub Text1_KeyPress(KeyAscii As Integer)
   If KeyAscii = 13 Then
       Command1_Click
   End If
End Sub
运行结果如下图:
附件
10-10-14 14:11
现在都用serialport控件了,mscomm在visual studio中用不了(可以添加海为的PLC控件,但初始化时就不行,控件属性也不能设置),能不能把这个PLC控制升级一下,用serialport控件实现一下,应该不会很麻烦,但如果我们自己写一个,会很麻烦~~表情
10-10-20 09:38
2楼
该帖内容不符合相关规定!
11-06-06 13:26
海为PLC的通讯控件
12-07-02 14:04

工控新闻

更多新闻资讯