viernes, 25 de agosto de 2023

Tesys T LTMR + Gambas3 + Modbus + V0.01

' 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:

IRC

#freenode->#usljujuy

Seguidores

Eventos n_n

Tira Ecol Nano,Bilo y Luca