elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Arreglado, de nuevo, el registro del warzone (wargame) de EHN


+  Foro de elhacker.net
|-+  Programación
| |-+  Programación General
| | |-+  .NET (C#, VB.NET, ASP)
| | | |-+  Programación Visual Basic (Moderadores: LeandroA, seba123neo)
| | | | |-+  Como pegar o enviar un textbox a otro programa?
0 Usuarios y 1 Visitante están viendo este tema.
Páginas: [1] Ir Abajo Respuesta Imprimir
Autor Tema: Como pegar o enviar un textbox a otro programa?  (Leído 1,744 veces)
Fucko

Desconectado Desconectado

Mensajes: 239


Fucko the Clown Rules!!!


Ver Perfil WWW
Como pegar o enviar un textbox a otro programa?
« en: 22 Enero 2023, 22:00 pm »

Buenas, estoy intentando enviar el contenido de un textbox a otra app, y no puedo hacerlo, sin tener foco en la app que lo recibe....
con sendkeys, funciona, pero no es estable al 100%

con sendmessage, no puedo lograrlo....

en realidad, puedo enviar sin foco, pero el vm_paste no.....

adjunto codigo, a ver si se ve el error... gracias

Código:
Private Declare Function FindWindowX Lib "user32" Alias "FindWindowExA" (ByVal hWnd1 As Long, _
ByVal hWnd2 As Long, ByVal lpsz1 As Long, ByVal lpsz2 As Long) As Long

Private Declare Function ShowWindow Lib "user32" (ByVal hWnd As Long, ByVal nCmdShow As Long) As Long

Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
Private Declare Function BringWindowToTop Lib "user32" (ByVal hWnd As Long) As Long
Private Declare Function PostMessage Lib "user32" Alias "PostMessageA" (ByVal hWnd As Long, _
ByVal wMsg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long

Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hWnd As Long, ByVal wMsg As Long, ByVal wParam As Integer, ByVal lParam As Integer) As Long
Private Const WM_PASTE = &H302
Private Const WM_KEYDOWN = &H100
Private Const WM_KEYUP = &H101

Sub Three()

    hWind = FindWindow(vbNullString, "Calculadora")
    cWind = FindWindowX(hWind, 0, 0, 0)
    Debug.Print PostMessage(cWind, WM_KEYDOWN, vbKey1, 0)
    Debug.Print PostMessage(cWind, WM_KEYDOWN, vbKey2, 0)
    Debug.Print PostMessage(cWind, WM_KEYDOWN, vbKey3, 0)

End Sub


Private Sub Command1_Click()
    Three
End Sub


Sub Three2()

    hWind = FindWindow(vbNullString, "Calculadora")
    cWind = FindWindowX(hWind, 0, 0, 0)
    Debug.Print PostMessage(cWind, WM_KEYDOWN, vbKey1, 0)
    Debug.Print PostMessage(cWind, WM_KEYDOWN, vbKey2, 0)
    Debug.Print PostMessage(cWind, WM_KEYDOWN, vbKey3, 0)
End Sub


Private Sub Command2_Click()
    Three2
End Sub

Private Sub Command3_Click()
    lnghwnd = FindWindow(vbNullString, "Calculadora")
    Debug.Print lnghwnd
    BringWindowToTop lnghwnd
    ShowWindow lnghwnd, 1
    'strProv = "Esta es una prueba"
    
    'For i = 1 To Len(strProv)
    'keybd_event Asc(Mid(strProv, i, 1)), 0, 0, 0
    'keybd_event Asc(Mid(strProv, i, 1)), 0, KEYEVENTF_KEYUP, 0
    'Next i
    
    'keybd_event 13, 0, 0, 0
    'keybd_event 13, 0, KEYEVENTF_KEYUP, 0
    
    If lnghwnd <> 0 Then
    
        SendKeys ("123")
        SendKeys ("{+}")
        SendKeys ("456")
        SendKeys ("{enter}")
        'Timer2.Enabled = True
        'Me.WindowState = 1
        Exit Sub
    End If
End Sub

Private Function FromClip(hWnd As Long)
    SendMessage hWnd, WM_PASTE, 0, 0
End Function

Private Sub Command4_Click()
    lnghwnd = FindWindow(vbNullString, "Calculadora")
    Debug.Print lnghwnd
    BringWindowToTop lnghwnd
    ShowWindow lnghwnd, 1
    'strProv = "Esta es una prueba"
    
    'For i = 1 To Len(strProv)
    'keybd_event Asc(Mid(strProv, i, 1)), 0, 0, 0
    'keybd_event Asc(Mid(strProv, i, 1)), 0, KEYEVENTF_KEYUP, 0
    'Next i
    
    'keybd_event 13, 0, 0, 0
    'keybd_event 13, 0, KEYEVENTF_KEYUP, 0
    
    If lnghwnd <> 0 Then
        FromClip (lnghwnd)
        'SendKeys ("123")
        'SendKeys ("{+}")
        'SendKeys ("456")
        'SendKeys ("{enter}")
        'Timer2.Enabled = True
        'Me.WindowState = 1
        Exit Sub
    End If
End Sub


dejo los comentarios porque eran ideas, que fui cambiando... gracias
ps: el command4 es el que da lios....



« Última modificación: 22 Enero 2023, 22:02 pm por Fucko » En línea

Cree en los que buscan la verdad, duda de los que la han encontrado...
Fucko

Desconectado Desconectado

Mensajes: 239


Fucko the Clown Rules!!!


Ver Perfil WWW
Re: Como pegar o enviar un textbox a otro programa?
« Respuesta #1 en: 23 Enero 2023, 06:56 am »

Ya encontré el problema....
el handle generado por FindWindow es de la ventana, pero NO del textbox donde quiero que se pegue la info....
lo hice con spy++, así que ahora, resta ver si se puede obtener el handle que necesito...
gracias

SOLUCIONADO!!

restaba encontrar el handle correspondiente...
no era suficiente con el de la ventana...

solución: Agregar la linea de código:

Código:
lnghwnd = FindWindowEx(lnghwnd, 0, "Edit", vbNullString)


« Última modificación: 23 Enero 2023, 07:29 am por Fucko » En línea

Cree en los que buscan la verdad, duda de los que la han encontrado...
Páginas: [1] Ir Arriba Respuesta Imprimir 

Ir a:  

WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines