2 Commits

Author SHA1 Message Date
Emmanuele Sassi fa0bdaba59 Num funzionante 2021-11-03 18:51:05 +01:00
Emmanuele Sassi 95d5baebc9 Correzione primo commit 2021-09-29 11:39:12 +02:00
15 changed files with 1488 additions and 419 deletions
+9 -1
View File
@@ -102,7 +102,15 @@ Public Class Axis
End Property
Friend Sub SetValue(value As Double)
m_dValue = value
Select Case Type
Case AxisTypes.LINEAR
m_dValue = value / 1000
Case AxisTypes.ROTATIONAL
m_dValue = value / 10000
Case Else
m_dValue = value
End Select
NotifyPropertyChanged(NameOf(dValue))
End Sub
+243
View File
@@ -0,0 +1,243 @@
Imports System
Imports System.Collections.Generic
Imports System.Linq
Imports System.Runtime.Remoting.Channels
Imports System.Runtime.Remoting.Channels.Ipc
Imports System.Security.Permissions
Imports System.Text
Imports System.Threading.Tasks
Imports System.Windows
Imports ISOCNC.Remoting
Class Comm
' creo classe di gestione variabili
Private m_RWVariableManager As RWVariableManager
Friend ReadOnly Property RWVariableManager As RWVariableManager
Get
Return m_RWVariableManager
End Get
End Property
Private m_MachManaging As MachManaging
Friend ReadOnly Property MachManaging As MachManaging
Get
Return m_MachManaging
End Get
End Property
Private _axesVal As Double() = New Double(23) {}
Private _cmdActive As Integer = 0
Private m_opState As ISOCNC.Remoting.MachineOperatingState = ISOCNC.Remoting.MachineOperatingState.Unspecified
Public ReadOnly Property opState As ISOCNC.Remoting.MachineOperatingState
Get
Return m_opState
End Get
End Property
Private _remObject As ISOCNC.Remoting_Server
Public ReadOnly Property remObject As ISOCNC.Remoting_Server
Get
Return _remObject
End Get
End Property
Private serverURI As String = "ipc://localhost:9090/IRemoteObject.rem"
Private m_eventProxy As ISOCNC.Remoting.EventProxyManager
Friend ReadOnly Property eventProxy As ISOCNC.Remoting.EventProxyManager
Get
Return m_eventProxy
End Get
End Property
Private _rpc As Integer
Private _prgCount As Integer
Private _prgAtIndex As String
Private _prgList As String()
Private _prgListUpdated As Boolean
Private _errCycle As String
Private _iso As String
Private _message As String
Private _errSystem As String
Private m_Proxy_CommandExecutedEventHandler As New CommandExecutedEventHandler(AddressOf RemoteObject_CommandExecuted)
Private m_Proxy_ServerErrorEventHandler As New ServerErrorEventHandler(AddressOf RemoteObject_ServerError)
Private m_Proxy_AxesCoordinatesUpdateEventHandler As New AxesCoordinatesUpdateEventHandler(AddressOf RemoteObject_AxisCoordinatesUpdate)
Private m_Proxy_OpStateUpdateEventHandler As New OpStateUpdateEventHandler(AddressOf RemoteObject_OpStateUpdate)
Private m_Proxy_AlarmNotificationEventHandler As New AlarmNotificationEventHandler(AddressOf RemoteObject_AlarmNotification)
Private m_Proxy_ListInfoEventHandler As New ListInfoEventHandler(AddressOf RemoteObject_ListInfoResponse)
Private m_Proxy_RPCUpdateEventHandler As New RPCUpdateEventHandler(AddressOf RemoteObject_RPCUpdate)
Private m_Proxy_VariableCommandExecutedEventHandler As New VariableCommandExecutedEventHandler(AddressOf RemoteObject_VariableCommandExecuted)
Private m_Proxy_TickUpdateEventHandler As New TickUpdateEventHandler(AddressOf RemoteObject_TickUpdate)
Private m_Rem_CommandExecutedEventHandler As CommandExecutedEventHandler
Private m_Rem_ServerErrorEventHandler As ServerErrorEventHandler
Private m_Rem_AxesCoordinatesUpdateEventHandler As AxesCoordinatesUpdateEventHandler
Private m_Rem_OpStateUpdateEventHandler As OpStateUpdateEventHandler
Private m_Rem_AlarmNotificationEventHandler As AlarmNotificationEventHandler
Private m_Rem_ListInfoEventHandler As ListInfoEventHandler
Private m_Rem_RPCUpdateEventHandler As RPCUpdateEventHandler
Private m_Rem_VariableCommandExecutedEventHandler As VariableCommandExecutedEventHandler
<SecurityPermission(SecurityAction.Demand)>
Public Sub New(Machmanaging As MachManaging)
m_MachManaging = Machmanaging
Dim properties As System.Collections.Hashtable = New System.Collections.Hashtable()
properties("name") = "remotingClient"
properties("priority") = "20"
properties("portName") = "67"
Dim clientProv As BinaryClientFormatterSinkProvider = New BinaryClientFormatterSinkProvider()
Dim serverProv As BinaryServerFormatterSinkProvider = New BinaryServerFormatterSinkProvider()
serverProv.TypeFilterLevel = System.Runtime.Serialization.Formatters.TypeFilterLevel.Full
Dim channel As IpcChannel = New IpcChannel(properties, clientProv, serverProv)
System.Runtime.Remoting.Channels.ChannelServices.RegisterChannel(channel, False)
Dim remoteType As System.Runtime.Remoting.WellKnownClientTypeEntry = New System.Runtime.Remoting.WellKnownClientTypeEntry(GetType(ISOCNC.Remoting_Server), serverURI)
System.Runtime.Remoting.RemotingConfiguration.RegisterWellKnownClientType(remoteType)
Dim objectUri As String
Dim messageSink As System.Runtime.Remoting.Messaging.IMessageSink = channel.CreateMessageSink("ipc://localhost:9090/IRemoteObject.rem", Nothing, objectUri)
Console.WriteLine("The URI of the message sink is {0}.", objectUri)
If messageSink IsNot Nothing Then
Console.WriteLine("The type of the message sink is {0}.", messageSink.[GetType]().ToString())
End If
m_eventProxy = New ISOCNC.Remoting.EventProxyManager()
AddHandler m_eventProxy.CommandExecuted, m_Proxy_CommandExecutedEventHandler
AddHandler m_eventProxy.ServerError, m_Proxy_ServerErrorEventHandler
AddHandler m_eventProxy.AxisCoordinatesUpdate, m_Proxy_AxesCoordinatesUpdateEventHandler
AddHandler m_eventProxy.OpStateUpdate, m_Proxy_OpStateUpdateEventHandler
AddHandler m_eventProxy.AlarmNotification, m_Proxy_AlarmNotificationEventHandler
AddHandler m_eventProxy.ListInfoResponse, m_Proxy_ListInfoEventHandler
AddHandler m_eventProxy.RPCUpdate, m_Proxy_RPCUpdateEventHandler
AddHandler m_eventProxy.VariableCommandExecuted, m_Proxy_VariableCommandExecutedEventHandler
AddHandler m_eventProxy.TickUpdate, m_Proxy_TickUpdateEventHandler
_remObject = CType(Activator.GetObject(GetType(ISOCNC.Remoting_Server), serverURI), ISOCNC.Remoting_Server)
Try
m_Rem_CommandExecutedEventHandler = New CommandExecutedEventHandler(AddressOf m_eventProxy.LocallyHandleCommandExecuted)
m_Rem_ServerErrorEventHandler = New ServerErrorEventHandler(AddressOf m_eventProxy.LocallyHandleServerError)
m_Rem_AxesCoordinatesUpdateEventHandler = New AxesCoordinatesUpdateEventHandler(AddressOf m_eventProxy.LocallyHandleAxisCoordinatesUpdate)
m_Rem_OpStateUpdateEventHandler = New OpStateUpdateEventHandler(AddressOf m_eventProxy.LocallyHandleOpStateUpdate)
m_Rem_AlarmNotificationEventHandler = New AlarmNotificationEventHandler(AddressOf m_eventProxy.LocallyHandleAlarmNotification)
m_Rem_ListInfoEventHandler = New ListInfoEventHandler(AddressOf m_eventProxy.LocallyHandleListInfo)
m_Rem_RPCUpdateEventHandler = New RPCUpdateEventHandler(AddressOf m_eventProxy.LocallyHandleRPCUpdate)
m_Rem_VariableCommandExecutedEventHandler = New VariableCommandExecutedEventHandler(AddressOf m_eventProxy.LocallyHandleVariableCommandExecuted)
AddHandler _remObject.CommandExecuted, m_Rem_CommandExecutedEventHandler
AddHandler _remObject.ServerError, m_Rem_ServerErrorEventHandler
AddHandler _remObject.AxisCoordinatesUpdate, m_Rem_AxesCoordinatesUpdateEventHandler
AddHandler _remObject.OpStateUpdate, m_Rem_OpStateUpdateEventHandler
AddHandler _remObject.AlarmNotification, m_Rem_AlarmNotificationEventHandler
AddHandler _remObject.ListInfoResponse, m_Rem_ListInfoEventHandler
AddHandler _remObject.RPCUpdate, m_Rem_RPCUpdateEventHandler
AddHandler _remObject.VariableCommandExecuted, m_Rem_VariableCommandExecutedEventHandler
Catch ex As System.Runtime.Remoting.RemotingException
Dim dR As MessageBoxResult = MessageBox.Show(ex.Message)
End Try
' creo classe che gestisce variabili
m_RWVariableManager = RWVariableManager.CreateRWVariableManager(Me)
End Sub
Friend Sub OnDispose()
RemoveHandler _remObject.CommandExecuted, m_Rem_CommandExecutedEventHandler
RemoveHandler _remObject.ServerError, m_Rem_ServerErrorEventHandler
RemoveHandler _remObject.AxisCoordinatesUpdate, m_Rem_AxesCoordinatesUpdateEventHandler
RemoveHandler _remObject.OpStateUpdate, m_Rem_OpStateUpdateEventHandler
RemoveHandler _remObject.AlarmNotification, m_Rem_AlarmNotificationEventHandler
RemoveHandler _remObject.ListInfoResponse, m_Rem_ListInfoEventHandler
RemoveHandler _remObject.RPCUpdate, m_Rem_RPCUpdateEventHandler
RemoveHandler _remObject.VariableCommandExecuted, m_Rem_VariableCommandExecutedEventHandler
RemoveHandler m_eventProxy.CommandExecuted, m_Proxy_CommandExecutedEventHandler
RemoveHandler m_eventProxy.ServerError, m_Proxy_ServerErrorEventHandler
RemoveHandler m_eventProxy.AxisCoordinatesUpdate, m_Proxy_AxesCoordinatesUpdateEventHandler
RemoveHandler m_eventProxy.OpStateUpdate, m_Proxy_OpStateUpdateEventHandler
RemoveHandler m_eventProxy.AlarmNotification, m_Proxy_AlarmNotificationEventHandler
RemoveHandler m_eventProxy.ListInfoResponse, m_Proxy_ListInfoEventHandler
RemoveHandler m_eventProxy.RPCUpdate, m_Proxy_RPCUpdateEventHandler
RemoveHandler m_eventProxy.VariableCommandExecuted, m_Proxy_VariableCommandExecutedEventHandler
RemoveHandler m_eventProxy.TickUpdate, m_Proxy_TickUpdateEventHandler
End Sub
Private Sub RemoteObject_OpStateUpdate(ByVal newOpState As ISOCNC.Remoting.MachineOperatingState)
' resetto stato pending iniziale
If Map.refMachManaging.StartPending AndAlso newOpState = MachineOperatingState.Pending Then
MachManaging.ResetStartPending()
End If
m_opState = newOpState
m_OpStateCallbackDlg(newOpState)
End Sub
Private Sub RemoteObject_CommandExecuted(ByVal executedCommand As Integer)
Select Case executedCommand
Case CInt(ISOCNC.Remoting.Commands.NoCommand)
Case CInt(ISOCNC.Remoting.Commands.[End])
m_ResultCallbackDlg(CommandTypes.RESET, CommandStates.OK, ResultTypes.RESULT, "")
Case CInt(ISOCNC.Remoting.Commands.[Error])
m_ResultCallbackDlg(CommandTypes.ERROR_, CommandStates.ERROR_, ResultTypes.RESULT, "")
Case CInt(ISOCNC.Remoting.Commands.MDI_End)
Case CInt(ISOCNC.Remoting.Commands.MDI_Start)
Case CInt(ISOCNC.Remoting.Commands.MDI_Stop)
Case CInt(ISOCNC.Remoting.Commands.SetPoint)
m_ResultCallbackDlg(CommandTypes.SETPOINT, CommandStates.OK, ResultTypes.RESULT, "")
Case CInt(ISOCNC.Remoting.Commands.Start)
m_ResultCallbackDlg(CommandTypes.START, CommandStates.OK, ResultTypes.RESULT, "")
Case CInt(ISOCNC.Remoting.Commands.[Step])
m_ResultCallbackDlg(CommandTypes.STEP_, CommandStates.OK, ResultTypes.RESULT, "")
Case CInt(ISOCNC.Remoting.Commands.[Stop])
m_ResultCallbackDlg(CommandTypes.STOP_, CommandStates.OK, ResultTypes.RESULT, "")
Case CInt(ISOCNC.Remoting.Commands.Start_Program_Soft)
m_ResultCallbackDlg(CommandTypes.SOFTSTART, CommandStates.OK, ResultTypes.RESULT, "")
Case Else
End Select
_cmdActive = CInt(executedCommand)
End Sub
Private Sub RemoteObject_ServerError(ByVal sender As Object, ByVal seEA As ISOCNC.Remoting.ServerErrorEventArgs)
m_ResultCallbackDlg(CommandTypes.ERROR_, CommandStates.ERROR_, ResultTypes.RESULT, "Server Error: " & seEA.[Error])
Dim dr As MessageBoxResult = MessageBox.Show("Server Error: " & seEA.[Error])
End Sub
Private Sub RemoteObject_AxisCoordinatesUpdate(ByVal axisValue As Double, ByVal axisIndex As Integer)
m_AxisCoordinatesCallbackDlg(axisValue, axisIndex)
End Sub
Private Sub RemoteObject_RPCUpdate(ByVal newRPC As UInteger)
_rpc = CInt(newRPC)
End Sub
Private Sub RemoteObject_ListInfoResponse(ByVal prgCount As Integer, ByVal prgAtIndex As String, ByVal prgList As String())
If prgCount >= 0 Then
_prgCount = prgCount
End If
If prgAtIndex <> "" Then
_prgAtIndex = prgAtIndex
End If
If prgList IsNot Nothing AndAlso prgList.Length > 0 Then
_prgList = prgList
_prgListUpdated = True
End If
End Sub
Private Sub RemoteObject_AlarmNotification(ByVal alarmOperation As Integer, ByVal alarmType As Integer, ByVal alarmMessage As String, ByVal alarmCode As String, ByVal alarmDateTime As String)
' restituisco errore ad interfaccia
m_AlarmCallbackDlg(alarmOperation, alarmType, alarmMessage, alarmCode, alarmDateTime)
End Sub
Private Sub RemoteObject_VariableCommandExecuted(ByVal executedCommand As Integer, ByVal commandExecutedCorrectly As Boolean, ByVal varName As String, ByVal varValue As String, ByVal varType As Integer)
' riporto valore variabile su array
Select Case executedCommand
Case VariableCommands.Error
Case VariableCommands.NotExecuted
Case VariableCommands.ReadVar
m_RWVariableManager.UpdateVar(commandExecutedCorrectly, varName, varValue, varType)
Case VariableCommands.WriteVar
m_ResultCallbackDlg(CommandTypes.WRITE, If(commandExecutedCorrectly, CommandStates.OK, CommandStates.ERROR_), ResultTypes.RESULT, varName & "=" & varValue)
Case VariableCommands.ReadAxis
Case VariableCommands.ReadAny
End Select
End Sub
Private Sub RemoteObject_TickUpdate(ByVal newTick As ULong)
End Sub
End Class
+715 -124
View File
@@ -1,53 +1,169 @@
Imports EgtUILib
Imports EgtWPFLib5
Public Class NUMFlexiumComm
Enum CNMode As Integer
AUTO = 0
SINGLE_ = 1
MDI = 2
MANUAL = 7
End Enum
Private m_MachManaging As MachManaging
Friend ReadOnly Property MachManaging As MachManaging
Get
Return m_MachManaging
End Get
End Property
Private objDRunTimeSystem As FXServer.DRunTimeSystem
Private objDGroupManager As FXServer.DGroupManager
Private objDGeneralFunction As FXServer.DGeneralFunctions
Private objDMainCncData As FXServer.DMainCncData
Private IsFlexiumPlus As Boolean = False
Private objErrorHandler As FXLog.ErrorHandler
Private objDPlcVariables As FXServer.DPlcVariables
Private objDReadELS As FXServer.DReadELS
Private objDFileTransfer As FXServer.DFileTransfer
Private objDPosition As FXServer.DPosition
Private objDMdiCommand As FXServer.DMdiCommand
Private objDVariables As FXServer.DVariables
Private objDCncMode As FXServer.DCncMode
Private m_IsFlexiumPlus As Boolean = False
Private m_CNCVersion As String = ""
Private _PartProgramNumber As Single
Private _CNCAxisChannelArray As String() = New String() {"Channel 1", "Channel 2"}
Private m_ChannelList As New List(Of String)
' Arraylist for read out the messages
Private _ReadFXMessages As New ArrayList
' lista variabili in lettura
Private Shared m_ReadingVars(19) As CommVar
Private m_BytesTransferedCounter As Integer
Private m_LinearAxisPrecision As Integer
Public Sub New(MachManaging As MachManaging)
m_MachManaging = MachManaging
End Sub
'Private Sub MainForm_Load(ByVal sender As Object, ByVal e As EventArgs)
' _comboCncAxisChannel.Items.AddRange(_CNCAxisChannelArray)
'End Sub
#Region "METHODS"
Private Sub InitFxServer()
Friend Sub InitFxServer()
objDRunTimeSystem = New FXServer.DRunTimeSystem()
objDRunTimeSystem.ServerInitializationFinished += New FXServer.IDRunTimeSystemEvents_ServerInitializationFinishedEventHandler(AddressOf objDRunTimeSystem_ServerInitializationFinished)
objDRunTimeSystem.ServerReinitializationStarted += New FXServer.IDRunTimeSystemEvents_ServerReinitializationStartedEventHandler(AddressOf objDRunTimeSystem_ServerReinitializationStarted)
AddHandler objDRunTimeSystem.ServerInitializationFinished, AddressOf objDRunTimeSystem_ServerInitializationFinished
AddHandler objDRunTimeSystem.ServerReinitializationStarted, AddressOf objDRunTimeSystem_ServerReinitializationStarted
objDRunTimeSystem.Init()
End Sub
Private Sub InitFxObjects()
objDGroupManager = New FXServer.DGroupManager()
objDGroupManager.ErrorHandler += New FXServer.IDGroupManagerEvents_ErrorHandlerEventHandler(AddressOf objDGroupManager_ErrorHandler)
AddHandler objDGroupManager.ErrorHandler, AddressOf objDGroupManager_ErrorHandler
objDGroupManager.CncNumber = 0
objDGroupManager.AxisGroup = 0
objDGeneralFunction = New FXServer.DGeneralFunctions()
objDGeneralFunction.ProgramActivated += New FXServer.IDGeneralFunctionsEvents_ProgramActivatedEventHandler(AddressOf objDGeneralFunction_ProgramActivated)
objDGeneralFunction.OnCncStart += New FXServer.IDGeneralFunctionsEvents_OnCncStartEventHandler(AddressOf objDGeneralFunction_OnCncStart)
objDGeneralFunction.OnCncStop += New FXServer.IDGeneralFunctionsEvents_OnCncStopEventHandler(AddressOf objDGeneralFunction_OnCncStop)
objDGeneralFunction.OnCncReset += New FXServer.IDGeneralFunctionsEvents_OnCncResetEventHandler(AddressOf objDGeneralFunction_OnCncReset)
objDGeneralFunction.CncModeWritten += New FXServer.IDGeneralFunctionsEvents_CncModeWrittenEventHandler(AddressOf objDGeneralFunction_CncModeWritten)
objDGeneralFunction.VariableWritten += New FXServer.IDGeneralFunctionsEvents_VariableWrittenEventHandler(AddressOf objDGeneralFunction_VariableWritten)
objDGeneralFunction.OnSkipLevelWritten += New FXServer.IDGeneralFunctionsEvents_OnSkipLevelWrittenEventHandler(AddressOf objDGeneralFunction_OnSkipLevelWritten)
AddHandler objDGeneralFunction.ProgramActivated, AddressOf objDGeneralFunction_ProgramActivated
AddHandler objDGeneralFunction.OnCncStart, AddressOf objDGeneralFunction_OnCncStart
AddHandler objDGeneralFunction.OnCncStop, AddressOf objDGeneralFunction_OnCncStop
AddHandler objDGeneralFunction.OnCncReset, AddressOf objDGeneralFunction_OnCncReset
AddHandler objDGeneralFunction.CncModeWritten, AddressOf objDGeneralFunction_CncModeWritten
AddHandler objDGeneralFunction.VariableWritten, AddressOf objDGeneralFunction_VariableWritten
objDGeneralFunction.Init(objDGroupManager.Handle)
objDMainCncData = New FXServer.DMainCncData()
objDMainCncData.Init(objDGroupManager.Handle)
m_LinearAxisPrecision = objDMainCncData.GetLinearPrecision()
Dim CncFxIdentifier As String = objDMainCncData.GetCncIdentifier()
EgtOutLog("CncFxIdentifier: " & CncFxIdentifier)
'_txtGetCncIdentification.Invoke(CType(Function()
' _txtGetCncIdentification.Text = CncFxIdentifier
' End Function, MethodInvoker))
If CncFxIdentifier = "Flexium 6" OrElse CncFxIdentifier = "Flexium 8" OrElse CncFxIdentifier = "Flexium 68" Then
IsFlexiumPlus = False
Else
IsFlexiumPlus = True
End If
m_IsFlexiumPlus = Not (CncFxIdentifier = "Flexium 6" OrElse CncFxIdentifier = "Flexium 8" OrElse CncFxIdentifier = "Flexium 68")
m_CNCVersion = objDMainCncData.GetCncVersion()
' Initialize for Channel Change
Dim CncGroupNumber As Integer = objDMainCncData.GetCncGroupNumber()
Dim PlcGroupNumber As Integer = objDMainCncData.GetPlcGroupNumber()
Dim sumChannels As Integer = 0
sumChannels = PlcGroupNumber + CncGroupNumber
For i = 1 To sumChannels
m_ChannelList.Add(i)
Next
' Initialize FXLog Objects
objErrorHandler = New FXLog.ErrorHandler()
AddHandler objErrorHandler.ErrorFromActiveCnc2, AddressOf objErrorHandler_ErrorFromActiveCnc2
AddHandler objErrorHandler.ErrorOnCnc, AddressOf objErrorHandler_ErrorOnCnc
AddHandler objErrorHandler.ErrorOnOtherChannel, AddressOf objErrorHandler_ErrorOnOtherChannel
AddHandler objErrorHandler.Exception, AddressOf objErrorHandler_Exception
'Initialisation config for testing
'Accepting all messages
'Consult the documentation for detailed information
objErrorHandler.AllError = 1
objErrorHandler.ErrorGlobal = 0
objErrorHandler.SetChannel(0, 0)
objErrorHandler.AcceptBootSysMessage(1)
objErrorHandler.AcceptException(0)
objDPlcVariables = New FXServer.DPlcVariables()
'objDPlcVariables.Symbols += New FXServer.IDPlcVariablesEvents_SymbolsEventHandler(AddressOf objDPlcVariables_Symbols)
AddHandler objDPlcVariables.ReadVariablesChanged, AddressOf objDPlcVariables_ReadVariablesChanged
AddHandler objDPlcVariables.VariablesWritten2, AddressOf objDPlcVariables_VariablesWritten2
AddHandler objDPlcVariables.ReadOnceVariablesChanged, AddressOf objDPlcVariables_ReadOnceVariablesChanged
objDPlcVariables.Flag = 3
objDPlcVariables.Init(objDGroupManager.Handle)
' Initialize FXServer class DReadELS
objDReadELS = New FXServer.DReadELS()
AddHandler objDReadELS.ValueChanged, AddressOf objDReadELS_ValueChanged
AddHandler objDReadELS.ValueChanged2, AddressOf objDReadELS_ValueChanged2
' Only for FX Server >= 3.9.0.0
AddHandler objDReadELS.ValueChanged3, AddressOf objDReadELS_ValueChanged3
objDReadELS.Init(objDGroupManager.Handle)
'Initialize FXServer class DFileTransfer
objDFileTransfer = New FXServer.DFileTransfer()
AddHandler objDFileTransfer.Completed, AddressOf objDFileTransfer_Completed
AddHandler objDFileTransfer.TransferStarted, AddressOf objDFileTransfer_TransferStarted
AddHandler objDFileTransfer.Failed, AddressOf objDFileTransfer_Failed
AddHandler objDFileTransfer.BytesTransfered, AddressOf objDFileTransfer_BytesTransfered
objDFileTransfer.Init(objDGroupManager.Handle)
objDPosition = New FXServer.DPosition()
'objDPosition.ValidAxisChanged += New FXServer.IDPositionEvents_ValidAxisChangedEventHandler(AddressOf objDPosition_ValidAxisChanged)
AddHandler objDPosition.PositionChanged, AddressOf objDPosition_PositionChanged
'objDPosition.DeltaChanged += New FXServer.IDPositionEvents_DeltaChangedEventHandler(AddressOf objDPosition_DeltaChanged)
'objDPosition.ReadOnceValidAxisChanged += New FXServer.IDPositionEvents_ReadOnceValidAxisChangedEventHandler(AddressOf objDPosition_ReadOnceValidAxisChanged)
'objDPosition.ReadOncePositionChanged += New FXServer.IDPositionEvents_ReadOncePositionChangedEventHandler(AddressOf objDPosition_ReadOncePositionChanged)
'objDPosition.ReadOnceDeltaChanged += New FXServer.IDPositionEvents_ReadOnceDeltaChangedEventHandler(AddressOf objDPosition_ReadOnceDeltaChanged)
'objDPosition.EndposChanged += New FXServer.IDPositionEvents_EndposChangedEventHandler(AddressOf objDPosition_EndposChanged)
objDPosition.Flag = 0
objDPosition.ModeOP = 0
objDPosition.FastUpdate = 0 ' Disable FastUpdate=0 To show the refresh time by Flag > 0
objDPosition.Init(objDGroupManager.Handle)
'Initialize FXServer class DMdiCommand
objDMdiCommand = New FXServer.DMdiCommand()
AddHandler objDMdiCommand.CommandWritten, AddressOf objDMdiCommand_CommandWritten
objDMdiCommand.Init(objDGroupManager.Handle)
'Initialize FXServer class DVariables
objDVariables = New FXServer.DVariables()
'AddHandler objDVariables.ValueChanged, AddressOf objDVariables_ValueChanged
'AddHandler objDVariables.ValueChanged2, AddressOf objDVariables_ValueChanged2
AddHandler objDVariables.VariableWritten, AddressOf objDVariables_VariableWritten
AddHandler objDVariables.VariableWritten2, AddressOf objDVariables_VariableWritten2
' Init & send the list of requested variables
Dim rc As Short = objDVariables.Init(objDGroupManager.Handle, "E80000", 1)
If (rc <> 0) Then EgtOutLog(" objDVariables.Init() Error : " + rc)
' Initialize FXServer class DCncMode
objDCncMode = New FXServer.DCncMode()
AddHandler objDCncMode.ValueChanged, AddressOf objDCncMode_ValueChanged
objDCncMode.Init(objDGroupManager.Handle)
End Sub
Private Sub CloseFxObjects()
@@ -55,7 +171,21 @@ Public Class NUMFlexiumComm
objDGroupManager = Nothing
System.Runtime.InteropServices.Marshal.ReleaseComObject(objDGeneralFunction)
objDGeneralFunction = Nothing
MessageBox.Show("CloseFxObjects")
System.Runtime.InteropServices.Marshal.ReleaseComObject(objErrorHandler)
objErrorHandler = Nothing
objDReadELS.Close()
objDPlcVariables.Close()
System.Runtime.InteropServices.Marshal.ReleaseComObject(objDReadELS)
objDReadELS = Nothing
System.Runtime.InteropServices.Marshal.ReleaseComObject(objDFileTransfer)
objDFileTransfer = Nothing
System.Runtime.InteropServices.Marshal.ReleaseComObject(objDPosition)
objDPosition = Nothing
System.Runtime.InteropServices.Marshal.ReleaseComObject(objDMdiCommand)
objDMdiCommand = Nothing
System.Runtime.InteropServices.Marshal.ReleaseComObject(objDVariables)
objDVariables = Nothing
End Sub
Private Sub GetGeneralFunctions()
@@ -63,156 +193,259 @@ Public Class NUMFlexiumComm
Select Case _GetConnectState
Case 0
_txtConnectionState.Text = "Not connected"
' Not connected
m_MachManaging.SetConnected(False)
m_ResultCallbackDlg(CommandTypes.CONNECT, CommandStates.NULL, ResultTypes.EXECUTED, "")
Case 1
_txtConnectionState.Text = " Connection error"
' Connection error
m_MachManaging.SetConnected(False)
m_ResultCallbackDlg(CommandTypes.CONNECT, CommandStates.ERROR_, ResultTypes.EXECUTED, "")
Case 2
_txtConnectionState.Text = "Connected"
' Connected
m_MachManaging.SetConnected(True)
m_ResultCallbackDlg(CommandTypes.CONNECT, CommandStates.OK, ResultTypes.EXECUTED, "")
' avvio lettura variabili
'MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ_NUMFLEXIUM))
StartReadList()
StartReadELS()
Case Else
End Select
End Sub
Private Sub _btnRuntimeSystemStart_Click(ByVal sender As Object, ByVal e As EventArgs)
InitFxServer()
End Sub
Private Sub _btnCycleStartCommon_Click(ByVal sender As Object, ByVal e As EventArgs)
Friend Sub Start()
objDGeneralFunction.CncStart()
End Sub
Private Sub _BtnFeedHoldCommon_Click(ByVal sender As Object, ByVal e As EventArgs)
Friend Sub Stop_()
objDGeneralFunction.CncStop()
End Sub
Private Sub _btnCNCResetCommon_Click(ByVal sender As Object, ByVal e As EventArgs)
Friend Sub Reset()
objDGeneralFunction.CncReset()
End Sub
Private Sub _btnCncModeAuto_Click(ByVal sender As Object, ByVal e As EventArgs)
objDGeneralFunction.WriteCncMode(0, 0)
Friend Sub SetMode(value As CNMode)
objDGeneralFunction.WriteCncMode(value, 0)
End Sub
Private Sub _btnCncModeMDI_Click(ByVal sender As Object, ByVal e As EventArgs)
objDGeneralFunction.WriteCncMode(2, 0)
'Private Sub WriteVariable(ByVal sender As Object, ByVal e As EventArgs)
' Dim _E80011FxStd As Int32 = 88888
' Dim _FXReturn As Short = objDGeneralFunction.WriteVariable("E80011", _E80011FxStd)
' If _FXReturn <> 0 Then
' MessageBox.Show("Error from WriteVariable:" & " " & _FXReturn.ToString())
' End If
'End Sub
'Private Sub WriteVariable2(ByVal sender As Object, ByVal e As EventArgs)
' Dim _E80010FxPlus As Double = 51515.6161
' Dim _FXReturn As Short = objDGeneralFunction.WriteVariable2("E80010", _E80010FxPlus)
' If _FXReturn <> 0 Then
' MessageBox.Show("Error from WriteVariable2:" & " " & _FXReturn.ToString())
' End If
'End Sub
Private Sub ChangeChannel(Channel As Short)
objErrorHandler.SetChannel(0, Channel)
End Sub
Private Sub _btnCncModeManual_Click(ByVal sender As Object, ByVal e As EventArgs)
objDGeneralFunction.WriteCncMode(7, 0)
End Sub
Private Sub _btnWriteVariable_Click(ByVal sender As Object, ByVal e As EventArgs)
Dim _E80011FxStd As Int32 = 88888
Dim _FXReturn As Short = objDGeneralFunction.WriteVariable("E80011", _E80011FxStd)
Friend Sub StartReadList()
Dim AddressList() As String = (From CommVar In m_ReadingVars
Where Not IsNothing(CommVar) AndAlso CommVar.nType = EgtCOMMTest.CommVar.Types.PLC
Select CommVar.sAddress).ToArray()
Dim _FXReturn As Short = objDPlcVariables.ReadVariables(AddressList)
If _FXReturn <> 0 Then
MessageBox.Show("Error from WriteVariable:" & " " & _FXReturn.ToString())
EgtOutLog("Error ReadVariables:" & " " & _FXReturn.ToString())
End If
End Sub
Private Sub _btnWriteVariable2_Click(ByVal sender As Object, ByVal e As EventArgs)
Dim _E80010FxPlus As Double = 51515.6161
Dim _FXReturn As Short = objDGeneralFunction.WriteVariable2("E80010", _E80010FxPlus)
Friend Sub CloseReadList()
objDPlcVariables.CloseReadList()
End Sub
Private Sub ReadVariablesOnce(Address As String)
'Dim _ReadSymbolicPlcVariableOnetime As String = "Application.IOCONFIG_GLOBALS.Flexium_NCK.RCNC.General.Mode"
Dim _FXReturn As Int16 = objDPlcVariables.ReadVariablesOnce(10, Address)
If _FXReturn <> 0 Then
MessageBox.Show("Error from WriteVariable2:" & " " & _FXReturn.ToString())
EgtOutLog("Error ReadVariablesOnce:" & " " & _FXReturn.ToString())
End If
End Sub
Friend Sub WritePlcVariables(Address As String, value As String)
'Dim _WriteSymbolicPlcVariable As String = _txtReadWritePlcVariables0.Text
Dim _FXReturn As Int16 = objDPlcVariables.WriteVariables2(11, Address, value)
If _FXReturn <> 0 Then
EgtOutLog("Error WriteVariables2 :" & " " & _FXReturn.ToString())
End If
End Sub
Public Shared Function InitVar(Variable As CommVar) As CommVar
Dim Index As Integer = Array.IndexOf(m_ReadingVars, Nothing)
m_ReadingVars(Index) = Variable
Return m_ReadingVars(Index)
End Function
Friend Sub StartReadELS()
For Index = 0 To m_ReadingVars.Length - 1
If IsNothing(m_ReadingVars(Index)) OrElse m_ReadingVars(Index).nType <> CommVar.Types.CN Then Continue For
Dim rc As Short = objDReadELS.AddParameter(m_ReadingVars(Index).sAddress, Index)
If rc <> 0 Then EgtOutLog(" Error AddParameter2 : " & rc & " on Variable : " & m_ReadingVars(Index).sAddress)
Next
End Sub
Friend Sub CloseReadELS()
objDPlcVariables.CloseReadList()
End Sub
#Region "File transfer"
Friend Sub FileDownload(sFileType As String, sFilePath As String)
Dim _Return_Download As Short
_Return_Download = objDFileTransfer.FileDownload2(10, sFileType, sFilePath, "", 1, 0)
If _Return_Download <> 0 Then
EgtOutLog("Error: File not stored to the job list:" & " " & _Return_Download.ToString())
End If
End Sub
Private Sub FileUpload(sFileType As String, sFilePath As String)
Dim _Return_Upload As Short
_Return_Upload = objDFileTransfer.FileUpload(20, sFileType, sFilePath, "")
If _Return_Upload <> 0 Then
EgtOutLog("Error: File not stored to the job list:" & " " & _Return_Upload.ToString())
End If
End Sub
Friend Sub FileDelete(sFileType As String, sFilePath As String)
Dim _ReturnFileDelete As Short
_ReturnFileDelete = objDFileTransfer.FileDelete(20, sFileType, "")
If _ReturnFileDelete <> 0 Then
EgtOutLog("Error: File not deleted:" & " " & _ReturnFileDelete.ToString())
End If
End Sub
Friend Sub StartTransfer()
Dim _Return_StartTransfer As Short
_Return_StartTransfer = objDFileTransfer.StartTransfer()
If _Return_StartTransfer <> 0 Then
EgtOutLog("Error: Start transfer not executed:" & " " & _Return_StartTransfer.ToString())
Else
m_BytesTransferedCounter = 0
End If
End Sub
#End Region ' File transfer
#Region "MDI"
Friend Sub MDI_Execute(sCommand As String)
Dim _FxReturn As Int16 = objDMdiCommand.ExecuteCommand(sCommand)
If _FxReturn <> 0 Then
EgtOutLog("Error ExecuteCommand :" & " " & _FxReturn.ToString())
End If
End Sub
#End Region ' MDI
#Region "Variables"
Friend Sub WriteNCVariables(Address As String, value As String)
Try
Dim dValue As Double = 0
StringToDouble(value, dValue)
Dim rc As Short = objDVariables.WriteVariables2(2, objDGroupManager.Handle, Address, dValue)
If rc <> 0 Then EgtOutLog(" objDVariables.WriteVariables2() Error : " & rc)
Catch ex As Exception
EgtOutLog(" objDVariables.WriteVariables2() Exception : " & ex.Message)
End Try
End Sub
#End Region ' Variables
#End Region ' METHODS
#Region "EVENTS"
Private Sub objDRunTimeSystem_ServerInitializationFinished()
InitFxObjects()
GetGeneralFunctions()
'If IsFlexiumPlus = True Then
' _txtBlockSkipLevel.Text = "100"
' _txtBlockSkipLevel.Enabled = True
'Else
' _txtBlockSkipLevel.Text = ""
' _txtBlockSkipLevel.Enabled = True
'End If
'_txtServerInitStatus.Invoke(CType(Function()
' _txtServerInitStatus.ForeColor = Color.DarkBlue
' _txtServerInitStatus.Text = "FXServer objects initialized !"
' End Function, MethodInvoker))
'_txtServerReinitStatus.Invoke(CType(Function()
' _txtServerReinitStatus.ForeColor = Color.DarkGreen
' _txtServerReinitStatus.Text = "FXServer no objects closed !"
' End Function, MethodInvoker))
End Sub
Private Sub objDRunTimeSystem_ServerReinitializationStarted()
CloseFxObjects()
'_txtServerReinitStatus.Invoke(CType(Function()
' _txtServerReinitStatus.ForeColor = Color.Red
' _txtServerReinitStatus.Text = "FXServer objects closed !"
' End Function, MethodInvoker))
'_txtServerInitStatus.Invoke(CType(Function()
' _txtServerInitStatus.ForeColor = Color.DarkOrange
' _txtServerInitStatus.Text = "FXServer objects not initialized !"
' End Function, MethodInvoker))
End Sub
Private Sub objDGeneralFunction_ProgramActivated(ByVal nerrorCode As Short)
MessageBox.Show("Part program activated:" & " " & nerrorCode)
End Sub
Private Sub objDGeneralFunction_OnCncReset(ByVal errorCode As Short)
If errorCode <> 0 Then
MessageBox.Show("Error CNC Reset:" & " " & errorCode.ToString())
End If
Private Sub objDGeneralFunction_OnCncStart(ByVal errorCode As Short)
Dim bOk As Boolean = (errorCode = 0)
m_MachManaging.SetStartPending(bOk)
m_ResultCallbackDlg(CommandTypes.START, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, If(bOk, "", "Error CNC Start: " & errorCode.ToString()))
End Sub
Private Sub objDGeneralFunction_OnCncStop(ByVal errorCode As Short)
If errorCode <> 0 Then
MessageBox.Show("Error Feed Hold:" & " " & errorCode.ToString())
End If
Dim bOk As Boolean = (errorCode = 0)
m_ResultCallbackDlg(CommandTypes.START, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, If(bOk, "", "Error Feed Hold: " & errorCode.ToString()))
End Sub
Private Sub objDGeneralFunction_OnCncStart(ByVal errorCode As Short)
If errorCode <> 0 Then
MessageBox.Show("Error Cycle Start:" & " " & errorCode.ToString())
End If
Private Sub objDGeneralFunction_OnCncReset(ByVal errorCode As Short)
Dim bOk As Boolean = (errorCode = 0)
m_ResultCallbackDlg(CommandTypes.START, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, If(bOk, "", "Error CNC Reset: " & errorCode.ToString()))
End Sub
Private Sub objDGeneralFunction_CncModeWritten(ByVal errorCode As Short)
MessageBox.Show("Error CNC Mode selection completed:" & " " & errorCode.ToString())
If errorCode <> 0 Then EgtOutLog("Error CNC Mode selection completed:" & " " & errorCode.ToString())
End Sub
Private Sub _txtPartProgramNumber_KeyPress(ByVal sender As Object, ByVal e As KeyPressEventArgs)
If e.KeyChar = CChar(Keys.[Return]) Then
e.Handled = True
Dim _CncAxisChannelIndependent As Int16
_PartProgramNumber = Single.Parse(_txtPartProgramNumber.Text)
MessageBox.Show("PartProgNumber:" & " " & _PartProgramNumber.ToString())
Dim _PartProgramNumberActivate As Int32 = Convert.ToInt32(_PartProgramNumber * 10)
MessageBox.Show("PartProgNumberActivate:" & " " & _PartProgramNumberActivate.ToString())
'Private Sub _txtPartProgramNumber_KeyPress(ByVal sender As Object, ByVal e As KeyPressEventArgs)
' If e.KeyChar = CChar(Keys.[Return]) Then
' e.Handled = True
' Dim _CncAxisChannelIndependent As Int16
' _PartProgramNumber = Single.Parse(_txtPartProgramNumber.Text)
' MessageBox.Show("PartProgNumber:" & " " & _PartProgramNumber.ToString())
' Dim _PartProgramNumberActivate As Int32 = Convert.ToInt32(_PartProgramNumber * 10)
' MessageBox.Show("PartProgNumberActivate:" & " " & _PartProgramNumberActivate.ToString())
If _checkChannelTypeState.Checked = True Then
_CncAxisChannelIndependent = 1
Else
_CncAxisChannelIndependent = 0
End If
' If _checkChannelTypeState.Checked = True Then
' _CncAxisChannelIndependent = 1
' Else
' _CncAxisChannelIndependent = 0
' End If
Dim _FXReturn As Int16 = objDGeneralFunction.ActivateProgram(_PartProgramNumberActivate, _CncAxisChannelIndependent)
' Dim _FXReturn As Int16 = objDGeneralFunction.ActivateProgram(_PartProgramNumberActivate, _CncAxisChannelIndependent)
If _FXReturn <> 0 Then
MessageBox.Show("Error Activate Program:" & " " & _FXReturn.ToString())
End If
End If
End Sub
' If _FXReturn <> 0 Then
' MessageBox.Show("Error Activate Program:" & " " & _FXReturn.ToString())
' End If
' End If
'End Sub
Private Sub objDGroupManager_ErrorHandler(ByVal sError As String, ByVal nTextNumber As Short)
MessageBox.Show("ErrorHandler message:" & " " & sError & " " & "ErrorHandler number:" & " " & nTextNumber.ToString())
EgtOutLog("ErrorHandler message:" & " " & sError & " " & "ErrorHandler number:" & " " & nTextNumber.ToString())
End Sub
Private Sub _comboCncAxisChannel_SelectedIndexChanged(ByVal sender As Object, ByVal e As EventArgs)
Select Case _comboCncAxisChannel.SelectedItem.ToString()
Case "Channel 1"
objDGroupManager.AxisGroup = 0
Case "Channel 2"
objDGroupManager.AxisGroup = 1
Case Else
End Select
'Select Case _comboCncAxisChannel.SelectedItem.ToString()
' Case "Channel 1"
' objDGroupManager.AxisGroup = 0
' Case "Channel 2"
' objDGroupManager.AxisGroup = 1
' Case Else
'End Select
End Sub
Private Sub objDGeneralFunction_VariableWritten(ByVal errorCode As Short)
@@ -223,20 +456,378 @@ Public Class NUMFlexiumComm
End If
End Sub
Private Sub _txtBlockSkipLevel_KeyPress(ByVal sender As Object, ByVal e As KeyPressEventArgs)
If e.KeyChar = CChar(Keys.[Return]) Then
e.Handled = True
Dim _GetBlockSkipLevelDecimalValue As UInt32 = Convert.ToUInt32(_txtBlockSkipLevel.Text)
Dim _FXReturn As Int16 = objDGeneralFunction.WriteSkipLevel(20, _GetBlockSkipLevelDecimalValue)
Private Sub objErrorHandler_ErrorOnCnc(ByVal cnc As Short, ByVal channel As Short, ByVal [set] As Short)
'AplCncNumber.Add(cnc)
'AplChannel.Add(channel)
'AplSet.Add([set])
End Sub
If _FXReturn <> 0 Then
MessageBox.Show("Error from WriteSkipLevel:" & " " & _FXReturn.ToString())
End If
Private Sub objErrorHandler_ErrorOnOtherChannel(ByVal status As Short)
'AplStatus = status
End Sub
Private Sub objErrorHandler_Exception(ByVal status As Short)
'ExceptStatus = status
End Sub
Private Sub objErrorHandler_ErrorFromActiveCnc2(ByVal CncNumber As Short, ByVal numberOfError As Short, ByVal ErrorTyp As Object, ByVal ErrorIndex As Object, ByVal ErrorNumber As Object, ByVal ErrorLine As Object, ByVal ErrorMessage As Object, ByVal ErrorAdditional As Object)
_ReadFXMessages.Clear()
Dim AplCnCNumber As Short = CncNumber
Dim AplnumberofError As Short = numberOfError
Dim AplErrorType As Object() = CType(ErrorTyp, Object())
Dim AplErrorIndex As Object() = CType(ErrorIndex, Object())
Dim AplErrorNumber As Object() = CType(ErrorNumber, Object())
Dim AplErrorLine As Object() = CType(ErrorLine, Object())
Dim AplErrorMessage As Object() = CType(ErrorMessage, Object())
Dim AplErrorAdditional As Object() = CType(ErrorAdditional, Object())
For index As Integer = 0 To numberOfError - 1
_ReadFXMessages.Add(New ReadMessages(AplCnCNumber.ToString(), AplnumberofError.ToString(), AplErrorType(index).ToString(), AplErrorIndex(index).ToString(), AplErrorNumber(index).ToString(), AplErrorLine(index).ToString(), AplErrorMessage(index).ToString(), AplErrorAdditional(index).ToString()))
Next
'Timers(TimerStartCounter).Interval = 100
'AddHandler Timers(TimerStartCounter).Elapsed, New System.Timers.ElapsedEventHandler(timer1_Elapsed)
'Timers(TimerStartCounter).Start()
'TimerStartCounter += 1
'Debug.WriteLine("Timer Started")
'Debug.WriteLine(DateTime.Now)
End Sub
#Region "PLC Variables"
Private Sub objDPlcVariables_ReadVariablesChanged(ByVal index As Object, ByVal value As Object)
Dim _ObjIndex As Object() = CType(index, Object())
Dim _ObjValue As Object() = CType(value, Object())
Dim index_1 As Integer = 0
For Each PlcVarIndex As Object In _ObjIndex
Dim indexIn As Integer = Integer.Parse(PlcVarIndex.ToString())
m_ReadingVars(indexIn).SetValue(_ObjValue(index_1).ToString())
index_1 += 1
Next
End Sub
Private Sub objDPlcVariables_ReadOnceVariablesChanged(ByVal lHandle As Integer, ByVal value As Object)
'Dim _ObjValue As Object() = CType(value, Object())
'If lHandle = 10 Then
' For i As Integer = 0 To _ObjValue.Length - 1
' _ReadPlcVariableOnetime(i).Invoke(CType(Function()
' _ReadPlcVariableOnetime(i).Text = _ObjValue(i).ToString()
' End Function, MethodInvoker))
' Next
'End If
End Sub
Private Sub objDPlcVariables_VariablesWritten2(ByVal lHandle As Integer, ByVal errorCode As Integer)
Dim bOk As Boolean = (errorCode <> 0)
m_ResultCallbackDlg(CommandTypes.WRITE, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.RESULT, If(bOk, "", "Error VariablesWritten2 :" & " " & errorCode.ToString()))
End Sub
#End Region ' PLC Variables
#Region "ReadELS"
Private Sub objDReadELS_ValueChanged2(ByVal nHandle As Integer, ByVal dValue As Double, ByVal nerrorCode As Short)
If nHandle < 1 OrElse nHandle > m_ReadingVars.Count - 1 Then Return
If nerrorCode <> 0 Then EgtOutLog(" Error in Validchanged2 : " & nerrorCode & " Handle : " & nHandle)
Try
m_ReadingVars(nHandle).SetValue(dValue.ToString("F04"))
Catch Ex As Exception
EgtOutLog(Ex.Message)
End Try
End Sub
Private Sub objDReadELS_ValueChanged3(ByVal nHandle As Integer, ByVal value As Object, ByVal DataType As Short, ByVal Writable As Short, ByVal nerrorCode As Short)
If nHandle < 1 OrElse nHandle > m_ReadingVars.Count - 1 Then
EgtOutLog(" Invalid handle in Validchanged3 : " & nHandle)
Return
End If
If nerrorCode <> 0 Then EgtOutLog(" Error in Validchanged3 : " & nerrorCode & " Handle : " & nHandle)
Dim sValue As String
Try
Select Case DataType
Case 0
sValue = (CSByte(value)).ToString()
Case 1
sValue = (CByte(value)).ToString()
Case 2
sValue = (CType(value, Int16)).ToString()
Case 3
sValue = (CType(value, UInt16)).ToString()
Case 4
sValue = (CType(value, Int32)).ToString()
Case 5
sValue = (CType(value, UInt32)).ToString()
Case 6
sValue = (CDbl(value)).ToString()
Case 7
sValue = (CBool(value)).ToString()
Case 8
sValue = (CBool(value)).ToString()
Case 9
sValue = (CBool(value)).ToString()
Case 10
sValue = (CType(value, Int64)).ToString()
Case 11
sValue = (CType(value, UInt32)).ToString()
Case -1
sValue = value.ToString()
Case Else
sValue = String.Empty
EgtOutLog("objDReadELS_ValueChanged3() : Unknown Datatype !")
End Select
m_ReadingVars(nHandle).SetValue(sValue)
'_ELS(nHandle - 1, 1).Text = sValue
'_ELS(nHandle - 1, 2).Text = (CType(DataType, eDatatype)).ToString()
'_ELS(nHandle - 1, 3).Text = If(Writable = 0, "No", If(Writable = 1, "Yes", Writable.ToString()))
Catch Ex As Exception
EgtOutLog("objDReadELS_ValueChanged3 " & Ex.Message & " Handle : " + nHandle)
End Try
End Sub
Private Sub objDReadELS_ValueChanged(ByVal nHandle As Short, ByVal dValue As Double, ByVal nerrorCode As Short)
'Throw New NotImplementedException()
End Sub
#End Region ' ReadELS
#Region "File transfer"
Private Sub objDFileTransfer_Completed(ByVal lHandle As Integer)
If lHandle = 10 OrElse lHandle = 20 Then
EgtOutLog("Up- or Download successful completed:" & " " & lHandle.ToString())
End If
End Sub
Private Sub objDGeneralFunction_OnSkipLevelWritten(ByVal lHandle As Integer, ByVal errorCode As Short)
MessageBox.Show("OnSkipLevelWritten:" & "" & "Handle:" & lHandle & " " & "errorCode:" & errorCode)
Private Sub objDFileTransfer_TransferStarted(ByVal lHandle As Integer)
EgtOutLog("Transfer has been started !")
End Sub
Private Sub objDFileTransfer_Failed(ByVal lHandle As Integer, ByVal nSeq As Short, ByVal nReason As Short)
EgtOutLog("Sequence:" & " " & nSeq.ToString() & " " & "Reason:" & " " & nReason.ToString())
End Sub
Private Sub objDFileTransfer_BytesTransfered(ByVal lHandle As Integer, ByVal lBytes As Integer)
m_BytesTransferedCounter += lBytes
End Sub
#End Region ' File transfer
#Region "Position"
Private Sub objDPosition_PositionChanged(ByVal vtArrayIndex As Object, ByVal vtArrayValues As Object)
Dim _indexArray As Object() = CType(vtArrayIndex, Object())
Dim _valueArray As Object() = CType(vtArrayValues, Object())
For _index As Integer = 0 To _indexArray.Length - 1
If m_IsFlexiumPlus = True Then
Dim _index1 As Int16 = CType(_indexArray.GetValue(_index), Int16)
Dim _axisPosValue As Double = CType(_valueArray.GetValue(_index), Double)
Dim _axisRefPosValue As Double = CType(_axisPosValue, Double) / m_LinearAxisPrecision
m_AxisCoordinatesCallbackDlg(_axisPosValue, _index1)
Else
Dim _index1 As Int16 = CType(_indexArray.GetValue(_index), Int16)
Dim _axisPosValue As Int32 = CType(_valueArray.GetValue(_index), Int32)
Dim _axisRefPosValue As Single = CSng(_axisPosValue) / m_LinearAxisPrecision
m_AxisCoordinatesCallbackDlg(_axisPosValue, _index1)
End If
Next
End Sub
#End Region ' Position
#Region "MDI"
Private Sub objDMdiCommand_CommandWritten(ByVal retVal As Short)
If retVal <> 0 Then
EgtOutLog("Error CommandWritten :" & " " & retVal.ToString())
End If
End Sub
#End Region ' MDI
#Region "Variables"
Private Sub objDVariables_VariableWritten2(ByVal lHandle As Integer, ByVal errorCode As Short)
If lHandle <> 2 OrElse errorCode <> 0 Then
EgtOutLog(" Error on objDVariables_VariableWritten2 : handle " & lHandle.ToString() & " errorCode : " & errorCode.ToString())
End If
End Sub
Private Sub objDVariables_VariableWritten(ByVal errorCode As Short)
If errorCode <> 0 Then
EgtOutLog(" Error on objDVariables_VariableWritten errorCode : " & errorCode.ToString())
End If
End Sub
'Private Sub objDVariables_ValueChanged(ByVal vtArrayIndex As Object, ByVal vtArrayValues As Object)
' Dim AplArrayIndex As Object() = CType(vtArrayIndex, Object())
' Dim AplArrayValue As Object() = CType(vtArrayValues, Object())
' Dim Idx As Int16
' If IsFlexiumPlus Then Return
' For index As Integer = 0 To AplArrayIndex.Length - 1
' Try
' Idx = CType(AplArrayIndex.GetValue(index), Int16)
' If Idx > 8 Then Exit For
' _Variables(Idx, 1).Invoke(CType(Function()
' _Variables(Idx, 1).Text = (CDbl(AplArrayValue.GetValue(index))).ToString()
' End Function, MethodInvoker))
' Catch Ex As Exception
' DisplayMessage(Ex.Message)
' End Try
' Next
'End Sub
'Private Sub objDVariables_ValueChanged2(ByVal vtArrayIndex As Object, ByVal vtArrayValues As Object)
' Dim AplArrayIndex As Object() = CType(vtArrayIndex, Object())
' Dim AplArrayValue As Object() = CType(vtArrayValues, Object())
' Dim index, IdxVar, IdxData, Idx As Int16, Datatype As Int16 = -1
' Dim _objValue As Object = Nothing
' Dim sValue As String
' For index = 0 To AplArrayIndex.Length - 1
' Try
' Idx = CType(AplArrayIndex.GetValue(index), Int16)
' IdxVar = CShort((Idx / 10))
' IdxData = CShort((Idx Mod 10))
' If IdxData < 0 OrElse IdxData > 2 OrElse IdxVar > 8 Then Continue For
' Select Case IdxData
' Case 0
' _objValue = AplArrayValue.GetValue(index)
' Case 1
' Me.Invoke(CType(Function()
' _Variables(IdxVar, 2).Tag = CShort(AplArrayValue.GetValue(index))
' _Variables(IdxVar, 2).Text = (CType(AplArrayValue.GetValue(index), eDatatype)).ToString()
' End Function, MethodInvoker))
' Case 2
' Me.Invoke(CType(Function()
' _Variables(IdxVar, 3).Text = If((CShort(AplArrayValue.GetValue(index))) = 0, "No", If((CShort(AplArrayValue.GetValue(index))) = 1, "Yes", (CShort(AplArrayValue.GetValue(index))).ToString()))
' End Function, MethodInvoker))
' End Select
' Me.Invoke(CType(Function()
' Datatype = If(_Variables(IdxVar, 2).Tag IsNot Nothing, CShort(_Variables(IdxVar, 2).Tag), CShort(-2))
' End Function, MethodInvoker))
' If IdxData = 1 OrElse IdxData = 0 AndAlso Datatype <> -1 Then
' Select Case Datatype
' Case 0
' sValue = (CSByte(_objValue)).ToString()
' Case 1
' sValue = (CByte(_objValue)).ToString()
' Case 2
' sValue = (CType(_objValue, Int16)).ToString()
' Case 3
' sValue = (CType(_objValue, UInt16)).ToString()
' Case 4
' sValue = (CType(_objValue, Int32)).ToString()
' Case 5
' sValue = (CType(_objValue, UInt32)).ToString()
' Case 6
' sValue = (CDbl(_objValue)).ToString()
' Case 7
' sValue = (CBool(_objValue)).ToString()
' Case 8
' sValue = (CBool(_objValue)).ToString()
' Case 9
' sValue = (CBool(_objValue)).ToString()
' Case 10
' sValue = (CType(_objValue, Int64)).ToString()
' Case 11
' sValue = (CType(_objValue, UInt32)).ToString()
' Case -1
' sValue = (CType(_objValue, Int32)).ToString()
' Case Else
' sValue = String.Empty
' DisplayMessage("objDVariables_ValueChanged2() : Unknown Datatype !")
' End Select
' Me.Invoke(CType(Function()
' _Variables(IdxVar, 1).Text = sValue
' End Function, MethodInvoker))
' End If
' Catch Ex As Exception
' DisplayMessage("objDVariables_ValueChanged2 " & Ex.Message & " Index : " + index)
' End Try
' Next
'End Sub
#End Region ' Variables
#Region "CNCMode"
Private Sub objDCncMode_ValueChanged(ByVal mode As Short, ByVal preselected As Short)
m_OpStateCallbackDlg(mode)
'Select Case mode
' Case 0
' CncModeSelect = "Auto"
' Case 1
' CncModeSelect = "Single"
' Case 2
' CncModeSelect = "MDI"
' Case 8
' CncModeSelect = "Home"
' Case Else
'End Select
'Select Case preselected
' Case 0
' CncModePreselect = "Auto"
' Case 1
' CncModePreselect = "Single"
' Case 2
' CncModePreselect = "MDI"
' Case 8
' CncModePreselect = "Home"
' Case Else
'End Select
End Sub
#End Region ' CNCMode
#End Region ' EVENTS
End Class
Public Class ReadMessages
Public CMsgCncNumber As String
Public CMsgNumberOfError As String
Public CMsgErrorType As String
Public CMsgErrorIndex As String
Public CMsgErrorNumber As String
Public CMsgErrorLine As String
Public CMsgErrorMessage As String
Public CMsgErrorAdditional As String
Public Sub New(ByVal MsgCncNumber As String, ByVal MsgNumberofError As String, ByVal MsgErrorType As String, ByVal MsgErrorIndex As String, ByVal MsgErrorNumber As String, ByVal MsgErrorLine As String, ByVal MsgErrorMessage As String, ByVal MsgErrorAdditional As String)
CMsgCncNumber = MsgCncNumber
CMsgNumberOfError = MsgNumberofError
CMsgErrorType = MsgErrorType
CMsgErrorIndex = MsgErrorIndex
CMsgErrorNumber = MsgErrorNumber
CMsgErrorLine = MsgErrorLine
CMsgErrorMessage = MsgErrorMessage
CMsgErrorAdditional = MsgErrorAdditional
End Sub
End Class
+4 -4
View File
@@ -9,7 +9,7 @@ Imports System.Threading.Tasks
Imports System.Windows
Imports ISOCNC.Remoting
Class TPAComm
Public Class TPAComm
' creo classe di gestione variabili
Private m_RWVariableManager As RWVariableManager
@@ -26,8 +26,8 @@ Class TPAComm
End Get
End Property
Private _axesVal As Double() = New Double(23) {}
Private _cmdActive As Integer = 0
Private m_opState As ISOCNC.Remoting.MachineOperatingState = ISOCNC.Remoting.MachineOperatingState.Unspecified
Public ReadOnly Property opState As ISOCNC.Remoting.MachineOperatingState
Get
@@ -79,8 +79,8 @@ Class TPAComm
<SecurityPermission(SecurityAction.Demand)>
Public Sub New(Machmanaging As MachManaging)
m_MachManaging = Machmanaging
Public Sub New(MachManaging As MachManaging)
m_MachManaging = MachManaging
Dim properties As System.Collections.Hashtable = New System.Collections.Hashtable()
properties("name") = "remotingClient"
properties("priority") = "20"
+4 -1
View File
@@ -19,10 +19,13 @@
SENDPROG = 10
REMOVEPROG = 11
REMOVEALLPROG = 12
READ = 13
READ_TPA = 13
WRITE = 14
DELETEALARMS = 15
SETOP = 16
READ_NUMFLEXIUM = 17
STOPREAD_NUMFLEXIUM = 18
MDI = 19
End Enum
Public Enum LogCommandTypes As Integer
+6 -1
View File
@@ -76,8 +76,12 @@
<Reference Include="EgtWPFLib5">
<HintPath>..\..\EgtProg\DllD32\EgtWPFLib5.dll</HintPath>
</Reference>
<Reference Include="Interop.FXLog">
<HintPath>..\..\CNC\NUM\Libs\Interop.FXLog.dll</HintPath>
<EmbedInteropTypes>True</EmbedInteropTypes>
</Reference>
<Reference Include="Interop.FXServer">
<HintPath>..\..\CNC\NUM\FXSDK\samples\C#\FXServer\fx_DGeneralFunctions\fx_DGeneralFunctions\obj\x86\Debug\Interop.FXServer.dll</HintPath>
<HintPath>..\..\CNC\NUM\Libs\Interop.FXServer.dll</HintPath>
<EmbedInteropTypes>True</EmbedInteropTypes>
</Reference>
<Reference Include="ISOCNC.Remoting">
@@ -107,6 +111,7 @@
<DependentUpon>AxesPanelV.xaml</DependentUpon>
</Compile>
<Compile Include="AxesPanel\AxesPanelVM.vb" />
<Compile Include="Comms\NUMFlexiumComm.vb" />
<Compile Include="Constants\ConstCommVar.vb" />
<Compile Include="Constants\ConstGen.vb" />
<Compile Include="Constants\ConstIni.vb" />
@@ -230,11 +230,11 @@ Public Class MachCommandMessagePanelVM
Private Sub Init()
' inizializzo valori assi leggendoli da variabili
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ, ASSE_X))
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ, ASSE_Y))
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ, ASSE_Z))
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ, ASSE_B))
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ, ASSE_C))
'MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ_TPA, ASSE_X))
'MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ_TPA, ASSE_Y))
'MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ_TPA, ASSE_Z))
'MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ_TPA, ASSE_B))
'MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ_TPA, ASSE_C))
End Sub
Public ReadOnly Property Disconnect_Command As ICommand
@@ -248,10 +248,6 @@ Public Class MachCommandMessagePanelVM
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.DISCONNECT))
End Sub
Public Sub SetOPState(OpState As Integer)
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.SETOP))
End Sub
Public ReadOnly Property Start_Command As ICommand
Get
If m_cmdStart Is Nothing Then m_cmdStart = New Command(AddressOf Start)
@@ -426,10 +422,8 @@ Public Class MachCommandMessagePanelVM
Map.refAxesPanelVM.AxisCoordinatesCallbackDlg(AxisValue, AxisIndex)
End Sub
Friend Sub OpStateCallbackDlg(newOpState As MachineOperatingState)
If newOpState <> MachineOperatingState.Unspecified Then
Map.refMainWindowVM.SetOPState(newOpState)
End If
Friend Sub OpStateCallbackDlg(newOpState As Integer)
Map.refMainWindowVM.SetOPState(Map.refMainWindowVM.OPStateList.FirstOrDefault(Function(x) x.Id = newOpState))
' Map.refLeftPanelVM.NotifyPropertyChanged(NameOf(Map.refLeftPanelVM.sOPState))
'DbControllers.m_LogMachineController.Create(MachLog.CreateOPStateLog(newOpState))
End Sub
+1 -1
View File
@@ -19,7 +19,7 @@
Public Delegate Sub UpdateCallbackDlg(Param As String, Params As String)
Public Delegate Sub AlarmCallbackDlg(ByVal AlarmOperation As Integer, ByVal AlarmType As Integer, ByVal AlarmMessage As String, ByVal AlarmCode As String, ByVal AlarmDateTime As String)
Public Delegate Sub AxisCoordinatesCallbackDlg(ByVal AxisValue As Double, ByVal AxisIndex As Integer)
Public Delegate Sub OpStateCallbackDlg(ByVal newOpState As ISOCNC.Remoting.MachineOperatingState)
Public Delegate Sub OpStateCallbackDlg(ByVal newOpState As Integer)
Public Delegate Sub ReadVarCallbackDlg(CommandExecutedCorrectly As Boolean, VarAddress As String, VarValue As String, VarType As Integer)
Friend m_ResultCallbackDlg As ResultCallbackDlg
+333 -186
View File
@@ -4,8 +4,9 @@ Imports ISOCNC.Remoting
Imports EgtUILib
Imports EgtWPFLib5
Imports System.IO
Imports EgtCOMMTest.MainWindowVM
Class MachManaging
Public Class MachManaging
Private m_bConnected As Boolean = False
Public ReadOnly Property bConnected As Boolean
@@ -13,11 +14,24 @@ Class MachManaging
Return m_bConnected
End Get
End Property
Friend Sub SetConnected(value As Boolean)
m_bConnected = value
End Sub
Private m_Tpa As TPAComm = Nothing
Private m_CN As Object = Nothing
Public ReadOnly Property CN As Object
Get
Return m_CN
End Get
End Property
Public ReadOnly Property Tpa As TPAComm
Get
Return m_Tpa
Return m_CN
End Get
End Property
Public ReadOnly Property Num_Flexium As NUMFlexiumComm
Get
Return m_CN
End Get
End Property
@@ -37,6 +51,9 @@ Class MachManaging
Friend Sub ResetStartPending()
m_bStartPending = False
End Sub
Friend Sub SetStartPending(value As Boolean)
m_bStartPending = value
End Sub
' prossima barra di cui mando i parametri di carico
Private m_NextBarId As Integer
@@ -54,130 +71,136 @@ Class MachManaging
End Sub
Friend Sub Timer_Tick()
'Dim bCancel As Boolean = False
'callback(0, "Init", bCancel)
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
'Dim bCancel As Boolean = False
'callback(0, "Init", bCancel)
' leggo tutte le variabili
Tpa.RWVariableManager.RefreshAllVars()
' leggo tutte le variabili
CN.RWVariableManager.RefreshAllVars()
' eseguo ciclo principale
Dim nReset_State As Integer
Dim nP_Prod As Integer
Dim nP_Machgroup As Integer
Dim nP_Part As Integer
Dim nP_State As Integer
Tpa.RWVariableManager.ReadVar(P_PROD, nP_Prod)
Tpa.RWVariableManager.ReadVar(P_MACHGROUP, nP_Machgroup)
Tpa.RWVariableManager.ReadVar(P_PART, nP_Part)
Tpa.RWVariableManager.ReadVar(P_STATE, nP_State)
Tpa.RWVariableManager.ReadVar(RESET_STATE, nReset_State)
'' se non ancora fatto, preparo variabili barra successiva
'If m_NextBarId = 0 Then
' SetNextBarVars()
'End If
'Dim TestOpState As Integer = Tpa.remObject.MachineOperativeStatus
'' verifico se scattato stato reset
'If nReset_State <> 0 Then
' ' resetto tutti i programmi
' If Not IsNothing(Map.refProjectVM.SupervisorMachGroupPanelVM) Then Map.refProjectVM.SupervisorMachGroupPanelVM.ResetAllMachGroups()
' ' resetto variabili P
' Tpa.RWVariableManager.WriteVar(P_PROD, 0)
' Tpa.RWVariableManager.WriteVar(P_MACHGROUP, 0)
' Tpa.RWVariableManager.WriteVar(P_PART, 0)
' Tpa.RWVariableManager.WriteVar(P_STATE, 0)
' ' cancello tutti i programmi da memoria CN
' 'RemoveAllProgram() toglie programma default per pending
' ' azzero variabile reset
' Tpa.remObject.SetVariableCommand(CInt(ISOCNC.Remoting.VariableCommands.WriteVar),
' RWVariableManager.GetReadVarFromName(RESET_STATE).sAddress, "0")
' ' resetto prossima barra e variabili V
' m_NextBarId = 0
' For Index = 1 To 6
' Tpa.RWVariableManager.WriteVar(VPAR & Index.ToString(), 0)
' Next
' eseguo ciclo principale
Dim nReset_State As Integer
Dim nP_Prod As Integer
Dim nP_Machgroup As Integer
Dim nP_Part As Integer
Dim nP_State As Integer
CN.RWVariableManager.ReadVar(P_PROD, nP_Prod)
CN.RWVariableManager.ReadVar(P_MACHGROUP, nP_Machgroup)
CN.RWVariableManager.ReadVar(P_PART, nP_Part)
CN.RWVariableManager.ReadVar(P_STATE, nP_State)
CN.RWVariableManager.ReadVar(RESET_STATE, nReset_State)
'' se non ancora fatto, preparo variabili barra successiva
'If m_NextBarId = 0 Then
' SetNextBarVars()
'End If
'Dim TestOpState As Integer = Tpa.remObject.MachineOperativeStatus
'' verifico se scattato stato reset
'If nReset_State <> 0 Then
' ' resetto tutti i programmi
' If Not IsNothing(Map.refProjectVM.SupervisorMachGroupPanelVM) Then Map.refProjectVM.SupervisorMachGroupPanelVM.ResetAllMachGroups()
' ' resetto variabili P
' Tpa.RWVariableManager.WriteVar(P_PROD, 0)
' Tpa.RWVariableManager.WriteVar(P_MACHGROUP, 0)
' Tpa.RWVariableManager.WriteVar(P_PART, 0)
' Tpa.RWVariableManager.WriteVar(P_STATE, 0)
' ' cancello tutti i programmi da memoria CN
' 'RemoveAllProgram() toglie programma default per pending
' ' azzero variabile reset
' Tpa.remObject.SetVariableCommand(CInt(ISOCNC.Remoting.VariableCommands.WriteVar),
' RWVariableManager.GetReadVarFromName(RESET_STATE).sAddress, "0")
' ' resetto prossima barra e variabili V
' m_NextBarId = 0
' For Index = 1 To 6
' Tpa.RWVariableManager.WriteVar(VPAR & Index.ToString(), 0)
' Next
' Return
' ' se macchina pronta e non sta tagliando alcun pezzo
'ElseIf (nP_Prod = 0 AndAlso
' nP_Machgroup = 0 AndAlso
' nP_Part = 0 AndAlso
' nP_State = PartState.NULL) AndAlso
' Tpa.opState = MachineOperatingState.Pending AndAlso Tpa.remObject.MachineOperativeStatus = MachineOperatingState.Pending Then
' ' verifico se c'e' un programma da lanciare
' SendNextProgram()
' ' attesa per essere sicuro che abbia scritto e riletto variabili
' Threading.Thread.Sleep(300)
' ' verifico stati inizio e fine pezzi
'ElseIf nP_Prod <> 0 AndAlso
' nP_Machgroup <> 0 AndAlso
' nP_Part <> 0 Then
' If nP_State = PartState.START Then
' ' scrivo data start su Db pezzo
' Dim dtStart As DateTime = DateTime.Now()
' DbControllers.m_PartController.UpdateStart(nP_Prod, nP_Machgroup, nP_Part, dtStart)
' DbControllers.m_PartController.UpdateStatus(nP_Prod, nP_Machgroup, nP_Part, ItemState.WIP)
' ' recupero gruppo di lavorazione del pezzo
' Dim MachGroup As MyMachGroupVM = Map.refProjectVM.SupervisorMachGroupPanelVM.MachGroupVMList.FirstOrDefault(Function(x) x.Id = nP_Machgroup)
' ' recupero pezzo
' Dim Part As PartVM = MachGroup.PartVMList.FirstOrDefault(Function(x) x.nPartId = nP_Part)
' ' scrivo stato start
' Part.nProduction_State = 1
' Part.dtStartTime = dtStart
' Part.NotifyPropertyChanged(NameOf(Part.nCALC_State))
' ' azzero variabile per far ripartire macchina
' Tpa.RWVariableManager.WriteVar(P_STATE, 0)
' ' se nessun pezzo della barra diverso da quello corrente e' in start
' If Not MachGroup.PartVMList.Any(Function(x) x.nPartId <> nP_Part AndAlso x.nCALC_State = 1) Then
' ' scrivo data start su Db barra
' DbControllers.m_MachGroupController.UpdateStart(nP_Prod, nP_Machgroup, dtStart)
' DbControllers.m_MachGroupController.UpdateStatus(nP_Prod, nP_Machgroup, ItemState.WIP)
' ' scrivo stato start
' MachGroup.MyMachGroupM.SetProductionState(1)
' MachGroup.dtStartTime = dtStart
' MachGroup.NotifyPropertyChanged(NameOf(MachGroup.nCALC_State))
' End If
' ' attesa per essere sicuro che abbia scritto e riletto variabili
' Threading.Thread.Sleep(300)
' ElseIf nP_State = PartState.END_ Then
' ' scrivo data end su Db pezzo
' Dim dtEnd As DateTime = DateTime.Now()
' DbControllers.m_PartController.UpdateEnd(nP_Prod, nP_Machgroup, nP_Part, dtEnd)
' DbControllers.m_PartController.UpdateStatus(nP_Prod, nP_Machgroup, nP_Part, ItemState.Produced)
' ' recupero gruppo di lavorazione del pezzo
' Dim MachGroup As MyMachGroupVM = Map.refProjectVM.SupervisorMachGroupPanelVM.MachGroupVMList.FirstOrDefault(Function(x) x.Id = nP_Machgroup)
' ' recupero pezzo
' Dim Part As PartVM = MachGroup.PartVMList.FirstOrDefault(Function(x) x.nPartId = nP_Part)
' ' scrivo stato end
' Part.nProduction_State = 2
' Part.dtEndTime = dtEnd
' Part.NotifyPropertyChanged(NameOf(Part.nCALC_State))
' ' resetto stato redo
' Part.bRedo = False
' ' azzero variabile per far ripartire macchina
' Tpa.RWVariableManager.WriteVar(P_STATE, 0)
' ' se tutti i pezzi della barra sono in end
' If MachGroup.PartVMList.All(Function(x) x.nCALC_State >= 2) Then
' ' scrivo data end su Db barra
' DbControllers.m_MachGroupController.UpdateEnd(nP_Prod, nP_Machgroup, dtEnd)
' DbControllers.m_MachGroupController.UpdateStatus(nP_Prod, nP_Machgroup, ItemState.Produced)
' ' scrivo stato end
' MachGroup.MyMachGroupM.SetProductionState(2)
' MachGroup.dtEndTime = dtEnd
' MachGroup.NotifyPropertyChanged(NameOf(MachGroup.nCALC_State))
' ' azzero tutte le variabilli per iniziare barra successiva
' Tpa.RWVariableManager.WriteVar(P_PROD, 0)
' Tpa.RWVariableManager.WriteVar(P_MACHGROUP, 0)
' Tpa.RWVariableManager.WriteVar(P_PART, 0)
' Tpa.RWVariableManager.WriteVar(P_STATE, 0)
' End If
' If Map.refMachCommandMessagePanelVM.bPrinterLink Then
' LabelPrinter.SetTestPrintVariables(nP_Prod, nP_Machgroup, nP_Part)
' LabelPrinter.Print()
' End If
' ' attesa per essere sicuro che abbia scritto e riletto variabili
' Threading.Thread.Sleep(300)
' End If
'End If
Case NCTypes.NUM_FLEXIUM
End Select
' Return
' ' se macchina pronta e non sta tagliando alcun pezzo
'ElseIf (nP_Prod = 0 AndAlso
' nP_Machgroup = 0 AndAlso
' nP_Part = 0 AndAlso
' nP_State = PartState.NULL) AndAlso
' Tpa.opState = MachineOperatingState.Pending AndAlso Tpa.remObject.MachineOperativeStatus = MachineOperatingState.Pending Then
' ' verifico se c'e' un programma da lanciare
' SendNextProgram()
' ' attesa per essere sicuro che abbia scritto e riletto variabili
' Threading.Thread.Sleep(300)
' ' verifico stati inizio e fine pezzi
'ElseIf nP_Prod <> 0 AndAlso
' nP_Machgroup <> 0 AndAlso
' nP_Part <> 0 Then
' If nP_State = PartState.START Then
' ' scrivo data start su Db pezzo
' Dim dtStart As DateTime = DateTime.Now()
' DbControllers.m_PartController.UpdateStart(nP_Prod, nP_Machgroup, nP_Part, dtStart)
' DbControllers.m_PartController.UpdateStatus(nP_Prod, nP_Machgroup, nP_Part, ItemState.WIP)
' ' recupero gruppo di lavorazione del pezzo
' Dim MachGroup As MyMachGroupVM = Map.refProjectVM.SupervisorMachGroupPanelVM.MachGroupVMList.FirstOrDefault(Function(x) x.Id = nP_Machgroup)
' ' recupero pezzo
' Dim Part As PartVM = MachGroup.PartVMList.FirstOrDefault(Function(x) x.nPartId = nP_Part)
' ' scrivo stato start
' Part.nProduction_State = 1
' Part.dtStartTime = dtStart
' Part.NotifyPropertyChanged(NameOf(Part.nCALC_State))
' ' azzero variabile per far ripartire macchina
' Tpa.RWVariableManager.WriteVar(P_STATE, 0)
' ' se nessun pezzo della barra diverso da quello corrente e' in start
' If Not MachGroup.PartVMList.Any(Function(x) x.nPartId <> nP_Part AndAlso x.nCALC_State = 1) Then
' ' scrivo data start su Db barra
' DbControllers.m_MachGroupController.UpdateStart(nP_Prod, nP_Machgroup, dtStart)
' DbControllers.m_MachGroupController.UpdateStatus(nP_Prod, nP_Machgroup, ItemState.WIP)
' ' scrivo stato start
' MachGroup.MyMachGroupM.SetProductionState(1)
' MachGroup.dtStartTime = dtStart
' MachGroup.NotifyPropertyChanged(NameOf(MachGroup.nCALC_State))
' End If
' ' attesa per essere sicuro che abbia scritto e riletto variabili
' Threading.Thread.Sleep(300)
' ElseIf nP_State = PartState.END_ Then
' ' scrivo data end su Db pezzo
' Dim dtEnd As DateTime = DateTime.Now()
' DbControllers.m_PartController.UpdateEnd(nP_Prod, nP_Machgroup, nP_Part, dtEnd)
' DbControllers.m_PartController.UpdateStatus(nP_Prod, nP_Machgroup, nP_Part, ItemState.Produced)
' ' recupero gruppo di lavorazione del pezzo
' Dim MachGroup As MyMachGroupVM = Map.refProjectVM.SupervisorMachGroupPanelVM.MachGroupVMList.FirstOrDefault(Function(x) x.Id = nP_Machgroup)
' ' recupero pezzo
' Dim Part As PartVM = MachGroup.PartVMList.FirstOrDefault(Function(x) x.nPartId = nP_Part)
' ' scrivo stato end
' Part.nProduction_State = 2
' Part.dtEndTime = dtEnd
' Part.NotifyPropertyChanged(NameOf(Part.nCALC_State))
' ' resetto stato redo
' Part.bRedo = False
' ' azzero variabile per far ripartire macchina
' Tpa.RWVariableManager.WriteVar(P_STATE, 0)
' ' se tutti i pezzi della barra sono in end
' If MachGroup.PartVMList.All(Function(x) x.nCALC_State >= 2) Then
' ' scrivo data end su Db barra
' DbControllers.m_MachGroupController.UpdateEnd(nP_Prod, nP_Machgroup, dtEnd)
' DbControllers.m_MachGroupController.UpdateStatus(nP_Prod, nP_Machgroup, ItemState.Produced)
' ' scrivo stato end
' MachGroup.MyMachGroupM.SetProductionState(2)
' MachGroup.dtEndTime = dtEnd
' MachGroup.NotifyPropertyChanged(NameOf(MachGroup.nCALC_State))
' ' azzero tutte le variabilli per iniziare barra successiva
' Tpa.RWVariableManager.WriteVar(P_PROD, 0)
' Tpa.RWVariableManager.WriteVar(P_MACHGROUP, 0)
' Tpa.RWVariableManager.WriteVar(P_PART, 0)
' Tpa.RWVariableManager.WriteVar(P_STATE, 0)
' End If
' If Map.refMachCommandMessagePanelVM.bPrinterLink Then
' LabelPrinter.SetTestPrintVariables(nP_Prod, nP_Machgroup, nP_Part)
' LabelPrinter.Print()
' End If
' ' attesa per essere sicuro che abbia scritto e riletto variabili
' Threading.Thread.Sleep(300)
' End If
'End If
End Sub
Private m_Lock_SendProgram As New Object
@@ -258,114 +281,238 @@ Class MachManaging
Case CommandTypes.SETPOINT
SetPoint()
Case CommandTypes.SENDPROG
SendProgram(Command.sVariable)
SendProgram(Command.sVariable, Command.sVariables(1))
Case CommandTypes.REMOVEPROG
RemoveProgram(Command.nVariable, Command.sVariable)
RemoveProgram(Command.nVariable, Command.sVariable, Command.sVariables(1))
Case CommandTypes.REMOVEALLPROG
RemoveAllProgram()
Case CommandTypes.READ
Case CommandTypes.READ_TPA
Tpa.RWVariableManager.RefreshVar(Command.sVariable)
Case CommandTypes.WRITE
Tpa.RWVariableManager.WriteVar(Command.sVariable, Command.sVariables(1))
WriteVar(Command.sVariable, Command.sVariables(1), Command.nVariable)
Case CommandTypes.DELETEALARMS
DeleteAlarms()
Case CommandTypes.SETOP
SetOPState(Command.nVariable)
Case CommandTypes.READ_NUMFLEXIUM
Num_Flexium.StartReadList()
Num_Flexium.StartReadELS()
Case CommandTypes.STOPREAD_NUMFLEXIUM
Num_Flexium.CloseReadList()
Num_Flexium.CloseReadELS()
Case CommandTypes.MDI
Num_Flexium.MDI_Execute(Command.sVariable)
End Select
End Sub
Public Sub Connect()
Try
m_Tpa = New TPAComm(Me)
m_bConnected = Tpa.remObject.OnConnect()
m_ResultCallbackDlg(CommandTypes.CONNECT, CommandStates.OK, ResultTypes.EXECUTED, "")
' creo classe di gestione variabili
Catch ex As Exception
m_ResultCallbackDlg(CommandTypes.CONNECT, CommandStates.ERROR_, ResultTypes.EXECUTED, "Errore: impossibile connettersi!")
Return
End Try
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
Try
m_CN = New TPAComm(Me)
m_bConnected = Tpa.remObject.OnConnect()
m_ResultCallbackDlg(CommandTypes.CONNECT, CommandStates.OK, ResultTypes.EXECUTED, "")
' creo classe di gestione variabili
Catch ex As Exception
m_ResultCallbackDlg(CommandTypes.CONNECT, CommandStates.ERROR_, ResultTypes.EXECUTED, "Errore: impossibile connettersi!")
Return
End Try
Case NCTypes.NUM_FLEXIUM
Try
m_CN = New NUMFlexiumComm(Me)
Num_Flexium.InitFxServer()
m_ResultCallbackDlg(CommandTypes.CONNECT, CommandStates.OK, ResultTypes.EXECUTED, "")
' creo classe di gestione variabili
Catch ex As Exception
m_ResultCallbackDlg(CommandTypes.CONNECT, CommandStates.ERROR_, ResultTypes.EXECUTED, "Errore: impossibile connettersi!")
Return
End Try
End Select
End Sub
Public Sub Disconnect()
Dim bOk As Boolean = Tpa.remObject.OnClose()
m_bConnected = Not bOk
m_ResultCallbackDlg(CommandTypes.DISCONNECT, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
' chiudo classe Tpa
Me.OnDispose()
m_Tpa.OnDispose()
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
Dim bOk As Boolean = Tpa.remObject.OnClose()
m_bConnected = Not bOk
m_ResultCallbackDlg(CommandTypes.DISCONNECT, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
' chiudo classe Tpa
Me.OnDispose()
Tpa.OnDispose()
Case NCTypes.NUM_FLEXIUM
m_bConnected = False
m_ResultCallbackDlg(CommandTypes.DISCONNECT, CommandStates.OK, ResultTypes.EXECUTED, "")
' chiudo classe Num_Flexium
Me.OnDispose()
'Num_Flexium.OnDispose()
End Select
' termino thread di comunicazione
MachineCommThread.StopThread()
End Sub
Public Sub SetOPState()
Public Sub SetOPState(CNMode As NUMFlexiumComm.CNMode)
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.NUM_FLEXIUM
Num_Flexium.SetMode(CNMode)
End Select
End Sub
Public Sub Start()
Dim bOk As Boolean = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.Start))
m_bStartPending = bOk
m_ResultCallbackDlg(CommandTypes.START, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
Dim bOk As Boolean = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.Start))
m_bStartPending = bOk
m_ResultCallbackDlg(CommandTypes.START, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Case NCTypes.NUM_FLEXIUM
Num_Flexium.Start()
End Select
End Sub
Public Sub [Stop]()
Dim bOk As Boolean = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.[Stop]))
m_ResultCallbackDlg(CommandTypes.STOP_, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
Dim bOk As Boolean = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.[Stop]))
m_ResultCallbackDlg(CommandTypes.STOP_, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Case NCTypes.NUM_FLEXIUM
Num_Flexium.Stop_()
End Select
End Sub
Public Sub Reset()
Dim bOk As Boolean = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.[End]))
m_ResultCallbackDlg(CommandTypes.RESET, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
Dim bOk As Boolean = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.[End]))
m_ResultCallbackDlg(CommandTypes.RESET, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Case NCTypes.NUM_FLEXIUM
Num_Flexium.Reset()
End Select
End Sub
Public Sub Step_()
Dim bOk As Boolean = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.Step))
m_ResultCallbackDlg(CommandTypes.STEP_, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
Dim bOk As Boolean = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.Step))
m_ResultCallbackDlg(CommandTypes.STEP_, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Case NCTypes.NUM_FLEXIUM
''
End Select
End Sub
Public Sub SetPoint()
Dim bOk As Boolean = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.SetPoint))
m_ResultCallbackDlg(CommandTypes.SETPOINT, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
Dim bOk As Boolean = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.SetPoint))
m_ResultCallbackDlg(CommandTypes.SETPOINT, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Case NCTypes.NUM_FLEXIUM
''
End Select
End Sub
Public Function SendProgram(ProgramPath As String) As Boolean
If Tpa.opState = MachineOperatingState.Pending Then
Tpa.remObject.RemoveAllProgramsFromList()
Dim bOk As Boolean = False
ProgramPath = ProgramPath.Replace("\\", "\")
bOk = Tpa.remObject.AddProgramToList(ProgramPath)
Threading.Thread.Sleep(1000)
bOk = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.Start_Program_Soft))
m_ResultCallbackDlg(CommandTypes.SENDPROG, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Return bOk
End If
Return False
Public Function SendProgram(ProgramPath As String, ProgramType As String) As Boolean
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
If Tpa.opState = MachineOperatingState.Pending Then
Tpa.remObject.RemoveAllProgramsFromList()
Dim bOk As Boolean = False
ProgramPath = ProgramPath.Replace("\\", "\")
bOk = Tpa.remObject.AddProgramToList(ProgramPath)
Threading.Thread.Sleep(1000)
bOk = Tpa.remObject.SetCommand(CInt(ISOCNC.Remoting.Commands.Start_Program_Soft))
m_ResultCallbackDlg(CommandTypes.SENDPROG, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
Return bOk
End If
Return False
Case NCTypes.NUM_FLEXIUM
Num_Flexium.FileDownload(ProgramType, ProgramPath)
Num_Flexium.StartTransfer()
End Select
End Function
Public Sub RemoveProgram(ProgramIndex As Integer, ProgramPath As String)
Dim bOk As Boolean
Dim sError As String = ""
If ProgramIndex > 0 Then
bOk = Tpa.remObject.RemoveProgramFromListAtIndex(ProgramIndex)
ElseIf Not String.IsNullOrEmpty(ProgramPath) Then
bOk = Tpa.remObject.RemoveProgramFromList(ProgramPath)
Else
bOk = False
sError = "Errore: nessun parametro passato"
End If
m_ResultCallbackDlg(CommandTypes.REMOVEPROG, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, sError)
Public Sub RemoveProgram(ProgramIndex As Integer, ProgramPath As String, ProgramType As String)
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
Dim bOk As Boolean
Dim sError As String = ""
If ProgramIndex > 0 Then
bOk = CN.remObject.RemoveProgramFromListAtIndex(ProgramIndex)
ElseIf Not String.IsNullOrEmpty(ProgramPath) Then
bOk = CN.remObject.RemoveProgramFromList(ProgramPath)
Else
bOk = False
sError = "Errore: nessun parametro passato"
End If
m_ResultCallbackDlg(CommandTypes.REMOVEPROG, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, sError)
Case NCTypes.NUM_FLEXIUM
Num_Flexium.FileDelete(ProgramType, ProgramPath)
Num_Flexium.StartTransfer()
End Select
End Sub
Public Sub RemoveAllProgram()
Dim bOk As Boolean = Tpa.remObject.RemoveAllProgramsFromList()
Dim bOk As Boolean = CN.remObject.RemoveAllProgramsFromList()
m_ResultCallbackDlg(CommandTypes.REMOVEALLPROG, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
End Sub
Public Sub DeleteAlarms()
Dim bOk As Boolean = Tpa.remObject.DeleteAlarms(CInt(AlarmType.ISO))
bOk = Tpa.remObject.DeleteAlarms(CInt(AlarmType.Message))
bOk = Tpa.remObject.DeleteAlarms(CInt(AlarmType.Cycle))
bOk = Tpa.remObject.DeleteAlarms(CInt(AlarmType.System))
Dim bOk As Boolean = CN.remObject.DeleteAlarms(CInt(AlarmType.ISO))
bOk = CN.remObject.DeleteAlarms(CInt(AlarmType.Message))
bOk = CN.remObject.DeleteAlarms(CInt(AlarmType.Cycle))
bOk = CN.remObject.DeleteAlarms(CInt(AlarmType.System))
m_ResultCallbackDlg(CommandTypes.DELETEALARMS, If(bOk, CommandStates.OK, CommandStates.ERROR_), ResultTypes.EXECUTED, "")
End Sub
Public Sub WriteVar(Address As String, Value As String, Type As CommVar.Types)
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
CN.RWVariableManager.WriteVar(Address, Value)
Case NCTypes.NUM_FLEXIUM
Select Case Type
Case CommVar.Types.PLC
Num_Flexium.WritePlcVariables(Address, Value)
Case CommVar.Types.CN
Num_Flexium.WriteNCVariables(Address, Value)
End Select
End Select
End Sub
Public Shared Function InitVar(nIndex As Integer) As CommVar
Dim NewVar As CommVar = GetPrivateProfileVariable(S_VARIABLES, nIndex, Map.refMainWindowVM.MainWindowM.sMachIniFile)
Select Case Map.refMainWindowVM.SelNCType
Case NCTypes.TPA
Return RWVariableManager.InitVar(NewVar)
Case NCTypes.NUM_FLEXIUM
Return NUMFlexiumComm.InitVar(NewVar)
End Select
End Function
Private Shared Function GetPrivateProfileVariable(IpAppName As String, IpKeyName As String, IpFileName As String) As CommVar
Dim sVariable As String = ""
EgtUILib.GetPrivateProfileString(IpAppName, IpKeyName, "", sVariable, IpFileName)
Dim sVariableValues() As String = sVariable.Split(","c)
If Not sVariableValues.Count >= 4 Then Return Nothing
For Index = 0 To sVariableValues.Count - 1
sVariableValues(Index) = sVariableValues(Index).Trim()
Next
Dim ReadType As CommVar.ReadTypes
Select Case sVariableValues(2).ToLower()
Case "o"
ReadType = CommVar.ReadTypes.ONETIME
Case "c"
ReadType = CommVar.ReadTypes.CONTINUOUS
Case Else
ReadType = CommVar.ReadTypes.NULL
End Select
Dim Type As CommVar.Types
Select Case sVariableValues(3).ToLower()
Case "plc"
Type = CommVar.Types.PLC
Case "cn"
Type = CommVar.Types.CN
Case Else
Type = CommVar.ReadTypes.NULL
End Select
Return New CommVar(sVariableValues(0), sVariableValues(1), ReadType, Type)
End Function
End Class
+2 -2
View File
@@ -40,7 +40,7 @@
End Class
Class ThreadCommand
Public Class ThreadCommand
Private m_CommandType As CommandTypes
Public ReadOnly Property CommandType As CommandTypes
@@ -119,7 +119,7 @@ Class ThreadCommand
End Function
Public Shared Function CreateReadCommand(sVariable As String) As ThreadCommand
Dim NewCommand As ThreadCommand = New ThreadCommand
NewCommand.m_CommandType = CommandTypes.READ
NewCommand.m_CommandType = CommandTypes.READ_TPA
NewCommand.m_sVariables(0) = sVariable
Return NewCommand
End Function
+34 -14
View File
@@ -50,13 +50,13 @@ Public Class RWVariableManager
Public Sub RefreshAllVars()
For Each Var In m_ReadingVars
' rileggo solo variabili continue
If Not IsNothing(Var) AndAlso Var.sType = CommVar.CommVarTypes.CONTINUOUS Then IntRefreshVar(Var.sAddress)
If Not IsNothing(Var) AndAlso Var.nReadType = CommVar.ReadTypes.CONTINUOUS Then IntRefreshVar(Var.sAddress)
Next
End Sub
Public Shared Function InitVar(Name As String, Address As String, Type As CommVar.CommVarTypes) As Integer
Public Shared Function InitVar(Name As String, Address As String, Type As CommVar.ReadTypes) As Integer
Dim Index As Integer = Array.IndexOf(m_ReadingVars, Nothing)
m_ReadingVars(Index) = New CommVar(Name, Address, Type)
m_ReadingVars(Index) = New CommVar(Name, Address, Type, CommVar.Types.NULL)
Return Index
End Function
@@ -66,6 +66,12 @@ Public Class RWVariableManager
Return m_ReadingVars(Index)
End Function
Public Shared Function InitVar(Variable As CommVar) As CommVar
Dim Index As Integer = Array.IndexOf(m_ReadingVars, Nothing)
m_ReadingVars(Index) = Variable
Return m_ReadingVars(Index)
End Function
Private Shared Function GetPrivateProfileVariable(IpAppName As String, IpKeyName As String, IpFileName As String) As CommVar
Dim sVariable As String = ""
EgtUILib.GetPrivateProfileString(IpAppName, IpKeyName, "", sVariable, IpFileName)
@@ -74,16 +80,16 @@ Public Class RWVariableManager
For Index = 0 To sVariableValues.Count - 1
sVariableValues(Index) = sVariableValues(Index).Trim()
Next
Dim Type As CommVar.CommVarTypes
Dim Type As CommVar.ReadTypes
Select Case sVariableValues(2).ToLower()
Case "o"
Type = CommVar.CommVarTypes.ONETIME
Type = CommVar.ReadTypes.ONETIME
Case "c"
Type = CommVar.CommVarTypes.CONTINUOUS
Type = CommVar.ReadTypes.CONTINUOUS
Case Else
Type = CommVar.CommVarTypes.NULL
Type = CommVar.ReadTypes.NULL
End Select
Return New CommVar(sVariableValues(0), sVariableValues(1), Type)
Return New CommVar(sVariableValues(0), sVariableValues(1), Type, CommVar.Types.NULL)
End Function
Public Sub RefreshVar(Name As String)
@@ -135,7 +141,7 @@ Public Class RWVariableManager
Private Sub UpdateContinuousVars()
Dim bReaded As Boolean = True
For Each Var In m_ReadingVars
If Not IsNothing(Var) AndAlso Var.sType = CommVar.CommVarTypes.CONTINUOUS AndAlso Not Var.bReaded Then
If Not IsNothing(Var) AndAlso Var.nReadType = CommVar.ReadTypes.CONTINUOUS AndAlso Not Var.bReaded Then
bReaded = False
Exit For
End If
@@ -160,7 +166,7 @@ Public Class RWVariableManager
'Dim bChangedVal As Boolean = ()
Var.SetValue(VarValue)
' se variabile ripetitiva lancio update variabili ripetitive
If Var.sType = CommVar.CommVarTypes.CONTINUOUS Then
If Var.nReadType = CommVar.ReadTypes.CONTINUOUS Then
EgtOutLog(CommandExecutedCorrectly & " . " & VarName & " . " & VarValue)
EgtOutLog(Var.sName & " . " & Var.sAddress & " . " & Var.sValue & " . " & Var.bReaded)
UpdateContinuousVars()
@@ -191,12 +197,18 @@ Public Class CommVar
Public Event NewValue As EventHandler(Of NewValueEventArgs)
Public Enum CommVarTypes As Integer
Public Enum ReadTypes As Integer
NULL = 0
ONETIME = 1
CONTINUOUS = 2
End Enum
Public Enum Types As Integer
NULL = 0
PLC = 1
CN = 2
End Enum
Private m_sName As String
Public Property sName As String
Get
@@ -215,12 +227,19 @@ Public Class CommVar
m_sAddress = value
End Set
End Property
Private m_nType As CommVarTypes
Public ReadOnly Property sType As CommVarTypes
Private m_nReadType As ReadTypes
Public ReadOnly Property nReadType As ReadTypes
Get
Return m_nReadType
End Get
End Property
Private m_nType As Types
Public ReadOnly Property nType As Types
Get
Return m_nType
End Get
End Property
Private m_sValue As String
Public ReadOnly Property sValue As String
Get
@@ -241,9 +260,10 @@ Public Class CommVar
End Get
End Property
Sub New(Name As String, Address As String, Type As CommVarTypes)
Sub New(Name As String, Address As String, ReadType As ReadTypes, Type As Types)
m_sName = Name
m_sAddress = Address
m_nReadType = ReadType
m_nType = Type
End Sub
+19 -5
View File
@@ -6,7 +6,7 @@
DataContext="{StaticResource MainWindowVM}"
Style="{DynamicResource {x:Type EgtWPFLib5:EgtCustomWindow}}"
Title="{Binding Title}" Icon="/Resources/EgtCOMMTest.ico"
MinHeight="700" MinWidth="800"
MinHeight="800" MinWidth="800"
AboutBoxCommand="{Binding AboutBox_Command}"
CloseCommand="{Binding CloseApplication_Command,Mode=OneWay,UpdateSourceTrigger=PropertyChanged}">
@@ -64,12 +64,26 @@
</GroupBox>
<GroupBox Header="OPState">
<ComboBox ItemsSource="{Binding OPStateList}"
SelectedItem="{Binding SelOPState}"/>
SelectedItem="{Binding SelOPState}"
DisplayMemberPath="Name"/>
</GroupBox>
<StackPanel>
</StackPanel>
<GroupBox Header="Channel">
<ComboBox ItemsSource="{Binding ChannelList}"
SelectedItem="{Binding SelChannel}"/>
</GroupBox>
<GroupBox Header="MDI">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="1*"/>
<ColumnDefinition Width="Auto"/>
</Grid.ColumnDefinitions>
<TextBox Text="{Binding MDI_Text}"/>
<Button Grid.Column="1"
Content="OK"
Command="{Binding MDI_Command}"/>
</Grid>
</GroupBox>
</StackPanel>
</EgtWPFLib5:EgtCustomWindow>
+91 -46
View File
@@ -1,7 +1,7 @@
Imports System.Threading
Imports EgtCOMMTest.Core
Imports EgtCOMMTest.MachCommandMessagePanelVM
Imports EgtWPFLib5
Imports EgtUILib
Public Class MainWindowVM
Inherits VMBase
@@ -58,6 +58,23 @@ Public Class MainWindowVM
End Set
End Property
Private m_ChannelList As List(Of String)
Public ReadOnly Property ChannelList As List(Of String)
Get
Return m_ChannelList
End Get
End Property
Private m_SelChannel As String
Public Property SelChannel As String
Get
Return m_SelChannel
End Get
Set(value As String)
m_SelChannel = value
End Set
End Property
Private m_CurrMachineName As String
Private m_ProgramPath As String
@@ -79,33 +96,6 @@ Public Class MainWindowVM
End Set
End Property
Private m_VarName As String
Public Property VarName As String
Get
Return m_VarName
End Get
Set(ByVal value As String)
m_VarName = value
End Set
End Property
Private m_VarValue As String = ""
Public Property VarValue As String
Get
Return m_VarValue
End Get
Set(ByVal value As String)
m_VarValue = value
End Set
End Property
Public Sub SetVarValue(ByVal value As Object)
m_VarValue = CStr(value)
NotifyPropertyChanged(NameOf(VarValue))
End Sub
'Private m_OPState As MachineOperatingState
'Public ReadOnly Property OPState As MachineOperatingState
@@ -138,33 +128,43 @@ Public Class MainWindowVM
' NotifyPropertyChanged(NameOf(sOPState))
'End Sub
Private _OPStateList As List(Of MachineOperatingState)
Private _OPStateList As List(Of OPState)
Public Property OPStateList As List(Of MachineOperatingState)
Public Property OPStateList As List(Of OPState)
Get
Return _OPStateList
End Get
Set(ByVal value As List(Of MachineOperatingState))
Set(ByVal value As List(Of OPState))
_OPStateList = value
End Set
End Property
Private _SelOPState As MachineOperatingState
Private _SelOPState As OPState
Public Property SelOPState As MachineOperatingState
Public Property SelOPState As OPState
Get
Return _SelOPState
End Get
Set(ByVal value As MachineOperatingState)
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.SETOP, value))
Set(ByVal value As OPState)
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.SETOP, value.Id))
_SelOPState = value
End Set
End Property
Friend Sub SetOPState(value As MachineOperatingState)
Friend Sub SetOPState(value As OPState)
_SelOPState = value
NotifyPropertyChanged(NameOf(SelOPState))
End Sub
Private m_MDI_Text As String
Public Property MDI_Text As String
Get
Return m_MDI_Text
End Get
Set(value As String)
m_MDI_Text = value
End Set
End Property
' Definizione comandi
Private m_cmdAboutBox As ICommand
Private m_cmdCloseApplication As ICommand
@@ -173,6 +173,7 @@ Public Class MainWindowVM
Private m_cmdRemoveProgram As ICommand
Private m_cmdReadVar As ICommand
Private m_cmdWriteVar As ICommand
Private m_cmdMDI As ICommand
#Region "CONSTRUCTOR"
@@ -186,16 +187,27 @@ Public Class MainWindowVM
' Impostazione path MachIni file
MainWindowM.SetMachIniFile(MainWindowM.sMachinesRoot & "\" & m_CurrMachineName & "\" & m_CurrMachineName & ".ini")
' recupero tipo di controllo
SelNCType = GetMainPrivateProfileInt(S_GENERAL, K_NCTYPE, 0)
SelNCType = GetPrivateProfileInt(S_GENERAL, K_NCTYPE, 0, Map.refMainWindowVM.MainWindowM.sMachIniFile)
' carico stati della macchina
_OPStateList = New List(Of MachineOperatingState) From {
MachineOperatingState.Start,
MachineOperatingState.[Stop],
MachineOperatingState.[End],
MachineOperatingState.SetPoint,
MachineOperatingState.Pending,
MachineOperatingState.Unspecified
Select Case SelNCType
Case NCTypes.TPA
_OPStateList = New List(Of OPState) From {
New OPState("Start", 1),
New OPState("Stop", 2),
New OPState("End", 3),
New OPState("SetPoint", 4),
New OPState("Pending", 5),
New OPState("Unspecified", 100)
}
Case NCTypes.NUM_FLEXIUM
_OPStateList = New List(Of OPState) From {
New OPState("Auto", 0),
New OPState("Single", 1),
New OPState("Mdi", 2),
New OPState("Manual", 7),
New OPState("Home", 8)
}
End Select
End Sub
@@ -302,7 +314,7 @@ Public Class MainWindowVM
End Property
Public Sub AddProgram(ByVal param As Object)
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.SENDPROG, m_ProgramPath))
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.SENDPROG, {}, {}, {m_ProgramPath, "%770"}))
End Sub
Public ReadOnly Property RemoveProgram_Command As ICommand
@@ -324,7 +336,7 @@ Public Class MainWindowVM
End Property
Public Sub ReadVar(ByVal param As Object)
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ))
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.READ_TPA))
End Sub
Public ReadOnly Property WriteVar_Command As ICommand
@@ -338,6 +350,39 @@ Public Class MainWindowVM
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.WRITE))
End Sub
Public ReadOnly Property MDI_Command As ICommand
Get
If m_cmdMDI Is Nothing Then m_cmdMDI = New Command(AddressOf MDI)
Return m_cmdMDI
End Get
End Property
Public Sub MDI(ByVal param As Object)
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.MDI, m_MDI_Text))
End Sub
#End Region ' COMMANDS
End Class
Public Class OPState
Private m_Name As String
Public ReadOnly Property Name As String
Get
Return m_Name
End Get
End Property
Private m_Id As Integer
Public ReadOnly Property Id As Integer
Get
Return m_Id
End Get
End Property
Sub New(Name As String, Id As Integer)
m_Name = Name
m_Id = Id
End Sub
End Class
-2
View File
@@ -1,2 +0,0 @@
# EgtCOMMTest
+20 -19
View File
@@ -14,25 +14,26 @@ Public Class VariablesListVM
Sub New()
' inizializzo tutte le variabili
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(2)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(3)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(4)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(5)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(6)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(7)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(1)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(8)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(9)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(10)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(11)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(12)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(13)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(14)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(15)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(16)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(17)))
m_VariablesList.Add(New Variable(RWVariableManager.InitVar(18)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(1)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(2)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(3)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(4)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(5)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(6)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(7)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(8)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(9)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(10)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(11)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(12)))
m_VariablesList.Add(New Variable(MachManaging.InitVar(13)))
'm_VariablesList.Add(New Variable(MachManaging.InitVar(14)))
'm_VariablesList.Add(New Variable(MachManaging.InitVar(15)))
'm_VariablesList.Add(New Variable(MachManaging.InitVar(16)))
'm_VariablesList.Add(New Variable(MachManaging.InitVar(17)))
'm_VariablesList.Add(New Variable(MachManaging.InitVar(18)))
'm_VariablesList.Add(New Variable(RWVariableManager.InitVar(19)))
End Sub
End Class
@@ -70,7 +71,7 @@ Public Class Variable
Return CommVar.sValue
End Get
Set(value As String)
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.WRITE, Nothing, Nothing, {CommVar.sName, value}))
MachManaging.CommandList.Add(ThreadCommand.CreateCommand(CommandTypes.WRITE, {CommVar.nType}, Nothing, {CommVar.sName, value}))
NotifyPropertyChanged(NameOf(sValue))
End Set
End Property