Título: Dar el foco a otra aplicacion (vba) Publicado por: Zeroql en 13 Julio 2014, 15:04 pm Buenos dias,
Mi pregunta seria como darle el foco a una aplicacion en ejecucion sabiendo solo el nombre del .exe me explico: Tengo una macro en excel que ejecuta el script de una aplicación, al ejecutarse el script la aplicación dueña de este lo realiza pero queda con el foco oculto, y necesito que se vea en pantalla el resultado (ventana del aplicativo) tengo un código pero este funciona con el titulo de la ventana de las aplicación en ejecución, y el aplicativo cambia el nombre según el resultado,, este es el codigo: Código
he buscado en internet, pero solo encuentro resultados de dar el foco auna aplicación con el nombre del .exe para vb.net. De ante mano muchas gracias!!! Título: Re: Dar el foco a otra aplicacion (vba) Publicado por: Eleкtro en 13 Julio 2014, 15:47 pm No se si te podré ayudar mucho, pero respecto a darle foco a una aplicación externa, puedes utilizar la función SetForegroundWindow, pasándole como parámetro el handle de la ventana del proceso (que no el PID).
Documentación de la API: · SetForegroundWindow function (http://msdn.microsoft.com/en-us/library/windows/desktop/ms633539%28v=vs.85%29.aspx) Declaraciones al estilo VB6: Código
O bien puedes utilizar el método AppActivate de VB, pasándole como parámetro el título de la ventana del proceso. ¿Como obtener el título de la ventana sabiendo unicamente el nombre del proceso? Pues en Vb.NET es sencillo, la verdad es que el Framework lo pone bien a disposición en tan solo un par de instrucciones, y yo no manejo VBA, pero parece que tienes mucha labor por delante con varias funciones de la WinAPI, imagino que podrías recurrir a alguna otra función o que quizás las classes de WMI dispondrán de alguna propiedad para obtener ese dato sí que podrías realizar una query por WMI, informate sobre ello. De todas formas mírate la función GetWindowText (http://msdn.microsoft.com/en-us/library/windows/desktop/ms633520%28v=vs.85%29.aspx), te servirá para obtener el título d ela ventana una vez ya haya conseguido obtener el Handle de la ventana dado el nombre del proceso. Código
EDITO: Aquí tienes una solución para obtener el PID según el nombre de un proceso, le podrías enviar el resultado a la API GetWindowText obteniendo el handle de la ventana según el PID, o bien adaptar el código apra que devuelva directamente el texto y no el PID. http://www.vbforums.com/showthread.php?537531-RESOLVED-How-to-find-Process-Handle-by-Process-Name Saludos. Título: Re: Dar el foco a otra aplicacion (vba) Publicado por: Zeroql en 15 Julio 2014, 23:33 pm Eleкtro Muchas gracias, lo resolvi con el EDITO.
|