' Gambas class file
Public DatoRegistro As String
Public DatoINT[256] As Integer
Public Sub Socket1_Closed()
PictureBox8.Picture = Picture.Load("led_verde_off.png")
End
Public Sub Socket1_Ready()
PictureBox8.Picture = Picture.Load("led_verde_on.png")
End
Public Function BIN_DEC(Binario As String, n As Integer) As Integer
Dim L, i, e, Entero As Integer
e = 0
For i = n To 0 Step -1
If Binario[i] = "1" Then
Entero = Entero + 2 ^ e
Endif
e = e + 1
Next
Return Entero
End
Public Function DEC_BIN(Decimal As Integer) As String
Dim i As Integer
Dim CadenaBit As String
For i = 0 To 15
If (Decimal % 2 == 1) Then
CadenaBit = CadenaBit & "1"
Else
CadenaBit = CadenaBit & "0"
End If
Decimal = Decimal / 2
Next
Return (Byte[].FromString(CadenaBit)).Reverse().ToString()
End
Function Leer_MDBUS_TCP(Registro As Integer) As String
Dim i, l As Integer
Dim Byte_LO As String
Dim Byte_HI As String
Escribir_MODBUS_TCP(0, 3, Registro, 1)
l = Len(DatoRegistro)
For i = 0 To l
DatoINT[i] = Asc(DatoRegistro[i])
Next
'For i = 0 To l
' Print i, DatoINT[i], DEC_BIN(DatoINT[i])
'Next
Byte_LO = Right$(DEC_BIN(DatoINT[10]), 8)
Byte_HI = Right$(DEC_BIN(DatoINT[9]), 8)
Return Byte_HI & Byte_LO
End
Public Sub Escribir_MODBUS_TCP(Direccion As Integer, CodigoFuncion As Integer, DireccionRegistro As Integer, Dato As Integer)
Dim TRAMA As New Integer[256]
Dim DATO_TX As String
Dim BIN, HI, LO As String
'Identificador de la transaccion
TRAMA[0] = 0
TRAMA[1] = 0
'Identificador del protocolo 0 para modbus
TRAMA[2] = 0
TRAMA[3] = 0
'Numero de bytes en esta trama
TRAMA[4] = 0
TRAMA[5] = 6
'Direccion del dispositivo
TRAMA[6] = Direccion
'Codigo de funcion
TRAMA[7] = CodigoFuncion
'Direccion registro
BIN = DEC_BIN(DireccionRegistro)
HI = Mid$(BIN, 1, 8)
LO = Mid$(BIN, 9, 16)
TRAMA[8] = BIN_DEC(HI, 7)
TRAMA[9] = BIN_DEC(LO, 7)
'Datos del registro
BIN = DEC_BIN(Dato)
HI = Mid$(BIN, 1, 8)
LO = Mid$(BIN, 9, 16)
TRAMA[10] = BIN_DEC(HI, 7)
TRAMA[11] = BIN_DEC(LO, 7)
DATO_TX = Chr$(TRAMA[0]) & Chr$(TRAMA[1]) & Chr$(TRAMA[2]) & Chr$(TRAMA[3]) & Chr$(TRAMA[4]) & Chr$(TRAMA[5]) & Chr$(TRAMA[6]) & Chr$(TRAMA[7]) & Chr$(TRAMA[8]) & Chr$(TRAMA[9]) & Chr$(TRAMA[10]) & Chr$(TRAMA[11])
If (Socket1.Status = Net.Connected) Then
Write #Socket1, DATO_TX, Len(DATO_TX)
Endif
End
Public Sub Cerrar_Click()
Escribir_MODBUS_TCP(0, 6, 704, 1)
End
Public Sub Socket1_Error()
Select Case Socket1.Status
Case Net.CannotCreateSocket
Message.Error("El sistema no permite crear un socket")
Case Net.HostNotFound
Message.Error("Host no encontrado")
Case Net.ConnectionRefused
Message.Error("No es posible conectar. La solicitud fue rechazada")
Case Net.CannotRead
Message.Error("Error leyendo datos")
Case Net.CannotWrite
Message.Error("Error escribiendo datos")
End Select
End
Public Sub Abrir_Click()
Escribir_MODBUS_TCP(0, 6, 704, 0)
End
Public Sub Conectar_Click()
Socket1.Host = TextBox1.Text
Socket1.Port = Val(TextBox2.Text)
Socket1.Connect()
End
Public Sub Timer1_Timer()
Dim BITs As String
Dim Entero As Integer
If (Socket1.Status = Net.Connected) Then
BITs = Leer_MDBUS_TCP(459)
Print BITs
If BITs[3] = "1" Then
PictureBox3.Picture = Picture.Load("contactor_close.png")
Else If BITs[3] = "0" Then
PictureBox3.Picture = Picture.Load("contactor_open.png")
Endif
If BITs[2] = "1" Or BITs[14] = "1" Then
PictureBox2.Picture = Picture.Load("Interruptor_close.png")
Else If BITs[2] = "0" Or BITs[14] = "0" Then
PictureBox2.Picture = Picture.Load("Interruptor_open.svg.png")
Endif
Endif
End
Public Sub O2_Click()
Escribir_MODBUS_TCP(0, 6, 704, 2)
End
Public Sub Reset_Click()
Escribir_MODBUS_TCP(0, 6, 704, 8)
End
Public Sub Socket1_Read()
Read #Socket1, DatoRegistro, Lof(Socket1)
End
Public Sub Form_Open()
Timer1.Enabled = True
End
No hay comentarios:
Publicar un comentario