Hello Guest it is December 08, 2019, 06:09:58 PM

Show Posts

This section allows you to view all posts made by this member. Note that you can only see posts made in areas you currently have access to.


Messages - TPS

541
General Mach Discussion / Re: tool changer
« on: October 28, 2018, 03:14:28 AM »
made som minor changes on your M6 macro, lets see, maybe it helps

Code: [Select]
'********************************************************************************
'*                   MACRO - CAMBIO DE HERRAMIENTA AUTOMATICO                   *
'********************************************************************************                 
'*      Version: 1.1                                                            *
'* Fecha inicio: 26/07/2015                                                     *
'* Fecha modif.: 25/08/2015                                                     *
'*     Objetivo: Realizar el cambio de herramienta automatico en Mach3          *
'*      Fichero: M6start.ms1                                                    *
'********************************************************************************
'*                                                                              *
'* Drescripción:                                                                *
'*                                                                              *
'* 1. Se mueve el eje Z a cero                                             *
'* 2. Se mueve el eje Y a posición segura                                  *
'* 3. Espera a que se pare el mandrino                                     *
'* 4. Se mueve el eje X para soltar herramienta                            *
'* 5. Se mueve el eje Z a posición de intercambio                          *
'* 6. Se mueve el eje Y para encastrar herramienta                         *
'* 7. Activar el cambio de herramienta                                     *
'* 8. Espera a que Mandrino suelta la Herramienta                          *
'* 9. Se mueve el eje Z a cero                                             *
'* 10. Se mueve el eje X e Y a coordenadas nueva Herramienta               *
'* 11. Se mueve el eje Z a posicion de intercambio                         *
'* 12. Desactivar el cambio de herramienta                                 *
'* 13. Espera a que Mandrino coja la herramienta                           *
'* 14. Se mueve el eje Y para descastrar herramienta                       *
'* 15. Se mueve el eje Z a cero                                            *
'* 16. Se mueve el eje X, Y a punto de partida                             *
'*                                                                         *
'********************************************************************************


Sub Main()
'Call SetUserDRO (1200,0)
' Inicialización del temporizador para el cambio de herramienta
'SetTimer(1)
'---------- Mensaje de inicio ---------------------------------------------------
Message "<< Iniciado el cambio de herramienta ..." 'Pone este mensaje en la barra de estado

'---------- Declaravión de Variables --------------------------------------------
MaxToolNum = 5 'Numero máximo de herramientas en el cambiador
ToolUp = -10 'Posición de Z segura arriba
ToolDw = -287.54 'Posición de Z para coger o dejar una herramienta
ToolSf = 90 'Posición de Y segura para extraer o insertar herramienta

'---------- Recoger Información de la herramienta actual ------------------------
ToolOld = GetOEMDRO (1200) 'Tomar el valor de la herramienta actual
x = GetToolChangeStart( 0 ) 'Tomar la posición de X actual
y = GetToolChangeStart( 1 ) 'Tomar la posición de Y actual
z = GetToolChangeStart( 2 ) 'Tomar la posición de Z actual

'---------- Recoger Información de la nueva Herramienta -------------------------
ToolNew = GetSelectedTool() 'Tomar el valor de la nueva herramienta
While ToolNew < 1 Or ToolNew > MaxToolNum 'Si el numero de la herramienta es superior
   'El operador deberá introducir un valor desde la pantalla
   ToolNew = Question ("Introduzca un numero de herramienta válido (1..." & MaxToolNum & ")")
Wend
If ToolNew = ToolOld Then 'Si la nueva herramienta es igual a la existente
   Exit Sub 'Salimos de la subrutina
End If
Message "<< Cambio de " & ToolOld & ",por " & ToolNew

'---------- Movimientos hacia el intercambiador ---------------------------------
'DoSpinStop() ' Parar mandrino
Message "<< Moviendo eje Z a cero ...." 'Pone este mensaje en la barra de estado
Code "G00 G53 Z" & ToolUp 'Subir el eje Z a cero
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
Message "Moviendo eje Y a posicion segura ..." 'Pone este mensaje en la barra de estado
Code "G53 Y10 X10" 'Desplaza eje Y a posición segura.
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
' Realiza un Home
DoButton( 24 )
DoButton( 23 )
DoButton( 22 )
DoButton( 25 )

Code "G53 Y" & ToolSf 'Desplaza eje Y a posición segura.
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend

'---------- Espera hasta que el mandrino se pare --------------------------------
Message "<< Espera a que el mandrico se pare ..." 'Pone este mensaje en la barra de estado
'While GetOEMDRO(99) <> 0 'Esperar a que el mandrino se pare
'Wend
Message "<< Mandrino parado ..." 'Pone este mensaje en la barra de estado

'---------- Movimientos para soltar herramienta actual --------------------------
Message "<< Posicionando para soltar herramienta ..." 'Pone este mensaje en la barra de estado
Call MovePos(ToolOld,"X") 'Mover primero eje X a la posición herramienta
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
Code "G53 Z" & ToolDw 'Mover el eje Z a la altura de cambio
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
Call MovePos(ToolOld,"Y") 'Mover eje Y a la posición soltar herramienta
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
Message "<< Posicionado completado ..." 'Pone este mensaje en la barra de estado

'---------- Soltar herramienta actual -------------------------------------------
Message "<< Accionando Change Tool ..." 'Pone este mensaje en la barra de estado
Code "G4 P.25" 'Esperar un pequeño tiempo
ActivateSignal(Output6) 'Activar la salida para soltar herramienta
'Esperar a el sistema neumatico del mandrino indique herramienta liberada
'SetTimer(2)
CTime = 0 'Inicializa el Temporizador
While Not(IsActive(input1) And Not IsActive(input2) And IsActive(input3))
'CTime = GetTimer(2)
CTime = CTime + 1
If CTime > 1000000 Then
Ret = MachMsg("No se ha podido SOLTAR la Herramienta.... Por Favor revise el Circuito neumático del mandrino....", _
"Tool Change Warning", 5)
If Ret = 2 Then
'MachMsg("Cambio de Herramienta Cancelado....", "Tool Change", 0)
Message "<< Cambio de Herramienta Cancelado" 'Pone este mensaje en la barra de estado
Exit Sub
Else
'SetTimer(2) 'Inicializa el Temporizador
CTime = 0
End If
End If
Wend
Code "G4 P1.0" 'Esperar un pequeño tiempo
Message "<< Herramienta Soltada ..." 'Pone este mensaje en la barra de estado

'---------- Movimientos para coger nueva herramienta ----------------------------
Message "<< Moviendo eje Z a cero ..." 'Pone este mensaje en la barra de estado
Code "G53 Z" & ToolUp 'Subir el eje Z para alejarse de la herramienta
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
Message "<< Posicionado para coger nueva Herramienta ..." 'Pone este mensaje en la barra de estado
Call MovePos(ToolNew,"X") 'Mover primero eje X a la posición herramienta
Call MovePos(ToolNew,"Y") 'Mover eje Y a la posición coger herramienta
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
Code "G53 Z" & ToolDw 'Mover el Eje Z para tomar la Herramienta
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
Message "<< Posicionado completado ..." 'Pone este mensaje en la barra de estado

'---------- Coger nueva herramienta -------------------------------------------
Message "<< Desactivar Change Tool ..." 'Pone este mensaje en la barra de estado
Code "G4 P.25" 'Esperar un pequeño tiempo
DeActivateSignal(Output6) 'Desactivar la salida para coger la herramienta
'Esperar a el sistema neumatico del mandrino indique herramienta esta cogida
'SetTimer(2)
Ctime = 0
While Not(Not IsActive(input1) And IsActive(input2) And Not IsActive(input3))
'CTime = GetTimer(2)
CTime = CTime + 1
If CTime > 1000000 Then
Ret = MachMsg("No se ha podido COGER la Herramienta.... Por Favor revise el Circuito neumático del mandrino....", _
"Tool Change Warning", 5)
If Ret = 2 Then
'MachMsg("Cambio de Herramienta Cancelado....", "Tool Change", 0)
Message "<< Cambio de Herramienta Cancelado" 'Pone este mensaje en la barra de estado
Exit Sub
Else
'SetTimer(2) 'Inicializa el Temporizador
CTime = 0
End If
CTime = 0
End If
'Pregunta por si se ha producido un Error al coger la herramienta
If(IsActive(input1) And IsActive(input2) And Not IsActive(input3)) Then
MachMsg("Colector cerrado sin herramienta... Por favor revise el Colector del mandrino....", _
"Tool Change Warning", 0)
End If
Wend
Code "G4 P1.0" 'Esperar un pequeño tiempo
Message "<< Herramienta sujeta ..." 'Pone este mensaje en la barra de estado


'---------- Movimientos a Coordenadas Seguras ---------------------------------
Message "<< Moviendo eje Y a posición segura ..." 'Pone este mensaje en la barra de estado
Code "G53 Y" & ToolSf 'Desplaza eje Y a posición segura.
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
Code "G53 Z" & ToolUp 'Subir el Eje Z
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
Message "<< Moviendo eje Z a cero ..." 'Pone este mensaje en la barra de estado

'---------- Asignar Herramienta recogida en el sistema ------------------------
Call SetUserDRO (1200,ToolNew)
SetCurrentTool( ToolNew )

'---------- Auto Tool Zero ----------------------------------------------------
'Code "(Iniciado Auto Tool Zero...)" 'Pone este mensaje en la barra de estado
'Code "G0 X100 Y100" 'Mueve a la posición de Prueba
'Code "G4 P5" 'Este tiempo me da para poder colocar la sonda
'Code "G31Z-10 F100" 'El movimiento de prueba, puede cambiar la velocidad
'While IsMoving() 'Esperar a que se ejecute el movimiento
'Wend
'ZProbePos = GetVar(2002) 'Obtener el punto exacto cuando la sonda sea golpeada
'Code "G0 Z" & ZProbePos 'Volver de nuevo a ese punto,
'While IsMoving () 'Esperar a que se ejecute el movimiento
'Wend
'Call SetDro (2, PlateThickness) 'Ajustar el eje Z a lo que se establece como espesor de la placa
'Code "G4 P0.25" 'Esperar un pequeño tiempo
'Code "G0 Z" & ToolUp 'Subir el Eje Z
'Code "(Moviendo eje Z a cero)" 'Pone este mensaje en la barra de estado

'---------- Regresar al punto de partida --------------------------------------
Message "<< Regresando al punto de partida ..." 'Pone este mensaje en la barra de estado
Code "G00 X" & x & " Y" & y '& " Z" & z  'Mueve la máquina al punto de partida
While IsMoving() 'Esperar a que se ejecute el movimiento
Wend
Code "G4 P1.00" 'Esperar un pequeño tiempo
Message "<< Cambio de Herramienta realizado" 'Pone este mensaje en la barra de estado

End Sub

Sub MovePos(ByVal ToolNumber As Integer, ByVal EjeMove As String)
'Subrutina donde estan las posiciones de cada herramienta
Select Case ToolNumber     
Case Is = 1
XPos = 125
YPos = 11.2
Case Is = 2
XPos = 299
YPos = 11.2
Case Is = 3
XPos = 474
YPos = 11.2
Case Is = 4
XPos = 815
YPos = 11.2
Case Is = 5
XPos = 991
YPos = 11.2
Case Is = 0 ' Posición de herramienta no existente
XPos = 1164
YPos = 11.2

End Select
       
If EjeMove = "X" Then
Code "G00 G53 X" & XPos
End If
If EjeMove = "Y" Then
Code "G01 G53 Y" & YPos & " F1500"
End If

End Sub


542
General Mach Discussion / Re: tool changer
« on: October 27, 2018, 12:39:02 PM »
oh jeah, we are on the chinese Controller road  :o :o

as sayed in a Prior reply, i have tested your code on my PP machine without any Problem.
have you buyed this machine/controller from China?

any Support avaliable?


543
General Mach Discussion / Re: tool changer
« on: October 27, 2018, 08:04:41 AM »
so you can only try and error

use the line

N130G71G91.1 without the G71

because there is allready a G21 in the line before:

N120G00G21G17G90G40G49G80

i am only trying to guess, without a real idea, why it is doing this.

btw. witch Controller are you using?

544
General Mach Discussion / Re: tool changer
« on: October 27, 2018, 03:35:48 AM »
sorry for the Long delay, was too busy this week.

so it is going from

N310G43H4


to

N130G71G91.1


right? that makes no sense for me.

545
General Mach Discussion / Re: tool changer
« on: October 21, 2018, 01:08:33 PM »
i have run your g-code and M6 Conde on my PP testmachine without any Problem.

can you describe the exact line whre the Loop starts ?

546
General Mach Discussion / Re: tool changer
« on: October 19, 2018, 02:14:54 AM »
can you please post your m6 macro?

547
General Mach Discussion / Re: VB Script
« on: October 11, 2018, 02:29:46 AM »
here we have the X-Center without the debug Windows
Code: [Select]
'simple X-center script
Sub Main()
SetOEMDro(800,0)

    'do the X- probe
    Message ("probe X- ")
    Code "G31 X-100 F150"
    While IsMoving()
        x = GetOEMDRO(800) 'X actpos
        If x <= -100 Then
            DoOEMButton(1003) 'Stop too far no probe hit
            MsgBox ("Probe X- canceled , no probe hit!" )
            Exit Sub
        End If
    Wend           

Sleep(200)
'get the exact probepos
ProbeXNeg = GetVar(2000)

'clear the probe
Code "G91 X2 F150"
    While IsMoving()
Sleep(10)
    Wend           
Code "G90"


    'do the X+ probe
    Message ("probe X+ ")
    Code "G31 X200 F150"
    While IsMoving()
        x = GetOEMDRO(800) 'X actpos
        If x >= 200 Then
            DoOEMButton(1003) 'Stop too far no probe hit
            MsgBox ("Probe X+ canceled , no probe hit!" )
            Exit Sub
        End If
    Wend           

Sleep(200)
'get the exact probepos
ProbeXPos = GetVar(2000)

'clear the probe
Code "G91 X-2 F150"
    While IsMoving()
Sleep(10)
    Wend           
Code "G90"

'goto the center
middle = ProbeXNeg + ((ProbeXPos - ProbeXNeg)/2)
Code "G90 G01 X" + CStr(middle)
    While IsMoving()
Sleep(10)
    Wend           
SetOEMDro(800,0)

End Sub


and the y-Center

Code: [Select]
'simple Y-center script
Sub Main()
SetOEMDro(801,0)

    'do the Y- probe
    Message ("probe Y- ")
    Code "G31 Y-100 F150"
    While IsMoving()
        y = GetOEMDRO(801) 'Y actpos
        If y <= -100 Then
            DoOEMButton(1003) 'Stop too far no probe hit
            MsgBox ("Probe Y- canceled , no probe hit!" )
            Exit Sub
        End If
    Wend           

Sleep(200)
'get the exact probepos
ProbeYNeg = GetVar(2001)

'clear the probe
Code "G91 Y2 F150"
    While IsMoving()
Sleep(10)
    Wend           
Code "G90"


    'do the Y+ probe
    Message ("probe Y+ ")
    Code "G31 Y200 F150"
    While IsMoving()
        y = GetOEMDRO(801) 'Y actpos
        If y >= 200 Then
            DoOEMButton(1003) 'Stop too far no probe hit
            MsgBox ("Probe Y+ canceled , no probe hit!" )
            Exit Sub
        End If
    Wend           

Sleep(200)
'get the exact probepos
ProbeYPos = GetVar(2001)

'clear the probe
Code "G91 Y-2 F150"
    While IsMoving()
Sleep(10)
    Wend           
Code "G90"

'goto the center
middle = ProbeYNeg + ((ProbeYPos - ProbeYNeg)/2)
Code "G90 G01 Y" + CStr(middle)
    While IsMoving()
Sleep(10)
    Wend           
SetOEMDro(801,0)

End Sub



hope i did everthing right


 

548
General Mach Discussion / Re: VB Script
« on: October 10, 2018, 07:00:12 AM »
here is a Version with a small delay after the probes, maybe it is more acurate

Code: [Select]
'simple X-center script
Sub Main()
SetOEMDro(800,0)

    'do the X- probe
    Message ("probe X- ")
    Code "G31 X-100 F150"
    While IsMoving()
        x = GetOEMDRO(800) 'X actpos
        If x <= -100 Then
            DoOEMButton(1003) 'Stop too far no probe hit
            MsgBox ("Probe X- canceled , no probe hit!" )
            Exit Sub
        End If
    Wend           

Sleep(200)
'get the exact probepos
ProbeXNeg = GetVar(2000)


MsgBox "X Probe - : " + CStr(ProbeXNeg)


'clear the probe
Code "G91 X2 F150"
    While IsMoving()
Sleep(10)
    Wend           
Code "G90"


    'do the X+ probe
    Message ("probe X+ ")
    Code "G31 X200 F150"
    While IsMoving()
        x = GetOEMDRO(800) 'X actpos
        If x >= 200 Then
            DoOEMButton(1003) 'Stop too far no probe hit
            MsgBox ("Probe X+ canceled , no probe hit!" )
            Exit Sub
        End If
    Wend           

Sleep(200)
'get the exact probepos
ProbeXPos = GetVar(2000)


MsgBox "X Probe + : " + CStr(ProbeXPos)



'clear the probe
Code "G91 X-2 F150"
    While IsMoving()
Sleep(10)
    Wend           
Code "G90"

'goto the center
middle = ProbeXNeg + ((ProbeXPos - ProbeXNeg)/2)
Code "G90 G01 X" + CStr(middle)
    While IsMoving()
Sleep(10)
    Wend           
SetOEMDro(800,0)

End Sub


549
General Mach Discussion / Re: VB Script
« on: October 10, 2018, 04:48:05 AM »
the third number is the calculated Center of the two Pobepositions:


Center = ProbeXNeg + ((ProbeXPos - ProbeXNeg) / 2)








550
General Mach Discussion / Re: VB Script
« on: October 09, 2018, 05:21:32 PM »
ok was a "Little bit" ofline, added some debuging msg boxes, to see what is going on


Code: [Select]
'simple X-center script
Sub Main()
SetOEMDro(800,0)

    'do the X- probe
    Message ("probe X- ")
    Code "G31 X-100 F150"
    While IsMoving()
        x = GetOEMDRO(800) 'X actpos
        If x <= -100 Then
            DoOEMButton(1003) 'Stop too far no probe hit
            MsgBox ("Probe X- canceled , no probe hit!" )
            Exit Sub
        End If
    Wend           

'get the exact probepos
ProbeXNeg = GetVar(2000)


MsgBox "X Probe - : " + CStr(ProbeXNeg)


'clear the probe
Code "G91 X2 F150"
    While IsMoving()
Sleep(10)
    Wend           
Code "G90"


    'do the X+ probe
    Message ("probe X+ ")
    Code "G31 X200 F150"
    While IsMoving()
        x = GetOEMDRO(800) 'X actpos
        If x >= 200 Then
            DoOEMButton(1003) 'Stop too far no probe hit
            MsgBox ("Probe X+ canceled , no probe hit!" )
            Exit Sub
        End If
    Wend           

'get the exact probepos
ProbeXPos = GetVar(2000)


MsgBox "X Probe + : " + CStr(ProbeXPos)



'clear the probe
Code "G91 X-2 F150"
    While IsMoving()
Sleep(10)
    Wend           
Code "G90"

'goto the center
middle = ProbeXNeg + ((ProbeXPos - ProbeXNeg)/2)


MsgBox "center : " + CStr(middle)

Code "G90 G01 X" + CStr(middle)
    While IsMoving()
Sleep(10)
    Wend           
SetOEMDro(800,0)

End Sub