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

 

 


Tema destacado: (TUTORIAL) Aprende a emular Sentinel Dongle By Yapis


  Mostrar Mensajes
Páginas: 1 ... 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 [78] 79 80
771  Programación / .NET (C#, VB.NET, ASP) / Re: Necesito tutorial de controles de VB.Net 2010 en PDF o blog en: 9 Febrero 2015, 18:10 pm
Gracias,

El tengo el MSDN de VB6 (pero en inglés) el de VB.NET 2005( también en inglés) y el de VB.NET 2010 (en castellano), pero cuando busco por ejemplo como usar el control MonthTimer siempre me salen referéncias a Clases, es decir crear objetos Timer, y en muchos casos las propiedades de objetos no están disponibles en el control mismo. Esto es lo que realmente me molesta. Además, en ocasiones me sale en inglés, según el caso. Otra cosa me fastidia es no encontrar ejemplos por ejemplo de como usar una determinada función API, tan sólo obtengo descripciones.
772  Programación / Programación Visual Basic / Re: Abrir ejecutable en un form - ¿Es posible abrir Chrome? en: 9 Febrero 2015, 17:50 pm
@okik, quería consultarte algo.

Por qué es que en mi PC funciona normal cuando genero el .exe, pero cuando intento abrir el ejecutable en otra PC, sólo se abre Chrome mas no lo incrusta en el picture del form.

Supuse que quizá el problema esté en esta parte

Código
  1. HWNDParent = FindWindow("Chrome_WidgetWin_1", vbNullString) 'Obtiene el handle padre
  2. Call SetParent(HWNDParent, Picture1.hwnd) 'Meter la apcliación en el picture

Quizá el problema esté en no poder obtener el handle padre o no poder meter la aplicación al picture.

Reitero que en mi PC funciona perfecto, pero cuando pruebo el .exe generado en otra PC no logra incrustar Chrome al picture.

Cómo podría solucionarlo?...

Gracias.

Hola @NsTeam,
Lo he probado en un portátil LG con Vista y en un PC con XP y funciona en los dos. Sinceramente no se que puede ser. Si no lo mete se me ocurren dos casos. Uno es, que como tu dices pudiera ser que no encuentra el Handle (hwnd) de Chrome. Es decir el número que hace a referéncia a la ventana abierta de Chrome. Si ocurre esto, puede ser porque el nombre de clase (Chrome_WidgetWin_1) sea distinto por ser una versión más antigua o algo así, o bien porque dicho PC es lento y al Chrome no le da tiempo a abrirse antes de que que tu programa trate de obtener el handle de la ventana de Chrome. Piensa que no se puede obtener el handle hasta que no se haya cargado el programa por completo.
Para solucionar estos posibles problemas haremos lo siguiente:
- Determinar el nombre de clase de Chrome.
VB6 y posteriores versiones disponen de una herramienta externa llamada Spy++. Si lo has instalado, vas al menú "Programas/Microsoft Visual Studio 6.0/Herramientas de Microsoft Visual Studio 6.0/" y aquí encontrarás el acceso directo. El nombre del EXE es SPYXX.EXE.

Ahora abre una ventana de Chrome, no hace falta que sea desde tu programa. Ejecuta el Spy++  y una vez abierto pulsa CTRL+F. Se abrirá un formulario y dentro hay un icono con una diana. La diana es arrastrable. Pulsa en ella y arrastrala hasta una ventana abierta de Chrome. Spy++ te irá mostrando los nombre de clase  a medida que vayas arrastrando la diana por la ventana de Chrome y se mostrará un cuadro en negrita hayá por donde arrastres que indica el objeto seleccionado. Tiene varios nombres de clase, el que te interesa el que hace referéncia a la ventana más externa de Chrome. Es posible hacer tu propio Spy++ de forma sencilla mediante GetCursorPos , WindowFromPointXY  y GetClassName. Más adelante en este post pondré el código.

- Esperar a que Chrome se cargue antes de obtener el Handle
Como parece ser que lo de Espara(5) (esperar 5 segundos) es ineficiente. Vamos a hacer que el programa no trate de obtener el handle hasta que Chrome no se haya abierto del todo. Para ello hacemos un bucle con Do/Loop que se repetirá indefinidamente hasta que el handle tenga un valor distinto de 0:

Sustituye el código en el lugar que nos ocupa por el siguiente:
Código
  1. HWNDParent = 0
  2.   ShellExecute Me.hwnd, "", "chrome.exe", _
  3.    "www.elhacker.net", Environ("programfiles") & "\Google\Chrome\Application\", SW_SHOWMINIMIZED
  4.   Espera (1)  'Espera  un segundo antes de intantar obtener el handle
  5.   Do While HWNDParent = 0
  6.   HWNDParent = FindWindow("Chrome_WidgetWin_1", vbNullString) 'Obtiene el handle padre
  7.   DoEvents
  8.   Loop

Como ves sigo poniendo el Espera(1), porque si no lo hago, obtiene el handle y carga el chrome pero lo hace tan rápido que no le da tiempo a graficarse y solo muestra un pestaña de color negro.

Luego el código queda así:
Código
  1. Private Sub Command1_Click()
  2. HWNDParent = 0
  3.   ShellExecute Me.hwnd, "", "chrome.exe", _
  4.    "www.elhacker.net", Environ("programfiles") & "\Google\Chrome\Application\", SW_SHOWMINIMIZED
  5.   Espera (1)  'Espera  un segundo antes de intantar obtener el handle
  6.   Do While HWNDParent = 0
  7.   HWNDParent = FindWindow("Chrome_WidgetWin_1", vbNullString) 'Obtiene el handle padre
  8.   DoEvents
  9.   Loop
  10.  
  11. Call SetParent(HWNDParent, Picture1.hwnd) 'Meter la apcliación en el picture
  12. 'Ajusta la ventana de Chrome al Picture
  13. Call SetWindowPos(HWNDParent, HWND_TOP, 0, 0, _
  14. Picture1.ScaleWidth, _
  15. Picture1.ScaleHeight, _
  16. SWP_NOZORDER)
  17. End Sub


Espero que esto sirva para solucionar el problema.   ;D


Lo prometido es deuda, así que aquí te dejo  un código que te permitira obtener los nombres de clase  y otros datos de cualquier ventana que haya abierta en tu escritorio de Windows con tan sólo pasar el puntero del ratón.

- Crea en un form un cuadro de texto TextBox
- Cambia la propiedad del TextBox a Multiline=true (es de solo lectura así que se debe hacer desde la ventana de propiedades)
- Crea un control Timer
Código
  1. Private Type POINTAPI
  2. x As Long
  3. y As Long
  4. End Type
  5.  
  6. Private Declare Function GetCursorPos Lib "user32" _
  7. (lpPoint As POINTAPI) As Long
  8. Private Declare Function WindowFromPointXY Lib "user32" Alias "WindowFromPoint" _
  9. (ByVal xPoint As Long, ByVal yPoint As Long) As Long
  10. Private Declare Function GetModuleFileName Lib "kernel32" Alias "GetModuleFileNameA" _
  11. (ByVal hModule As Long, _
  12. ByVal lpFileName As String, _
  13. ByVal nSize As Long) As Long
  14. Private Declare Function GetWindowWord Lib "user32" _
  15. (ByVal hwnd As Long, ByVal nIndex As Long) As Integer
  16. Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" _
  17. (ByVal hwnd As Long, _
  18. ByVal nIndex As Long) As Long
  19. Private Declare Function GetParent Lib "user32" _
  20. (ByVal hwnd As Long) As Long
  21. Private Declare Function GetClassName Lib "user32" Alias "GetClassNameA" _
  22. (ByVal hwnd As Long, _
  23. ByVal lpClassName As String, _
  24. ByVal nMaxCount As Long) As Long
  25. Private Declare Function GetWindowText Lib "user32" Alias "GetWindowTextA" _
  26. (ByVal hwnd As Long, _
  27. ByVal lpString As String, _
  28. ByVal cch As Long) As Long
  29.  
  30. Const GWW_HINSTANCE = (-6)
  31. Const GWW_ID = (-12)
  32. Const GWL_STYLE = (-16)
  33. Dim DATOS As String
  34.  
  35. Private Sub Form_Load()
  36. Text1.Text = ""
  37. Timer1.Interval = 1
  38. Timer1.Enabled = True
  39. End Sub
  40.  
  41. Sub Timer1_Timer()
  42. Dim pt32 As POINTAPI
  43. Dim ptx As Long
  44. Dim pty As Long
  45. Dim sWindowText As String * 100
  46. Dim sClassName As String * 100
  47. Dim hWndOver As Long
  48. Dim hWndParent As Long
  49. Dim sParentClassName As String * 100
  50. Dim wID As Long
  51. Dim lWindowStyle As Long
  52. Dim hInstance As Long
  53. Dim sParentWindowText As String * 100
  54. Dim sModuleFileName As String * 100
  55. Static hWndLast As Long
  56.  
  57. Call GetCursorPos(pt32)                ' obtiene la posición del cursor
  58. ptx = pt32.x
  59. pty = pt32.y
  60. hWndOver = WindowFromPointXY(ptx, pty) ' Obtiene el handle debajo del cursor
  61. If hWndOver <> hWndLast Then
  62. hWndLast = hWndOver
  63. DATOS = ""
  64.  
  65. ' Muestra el handle de la ventana
  66. DATOS = DATOS & "Window Handle: &H" & Hex(hWndOver) & vbCrLf
  67. r = GetWindowText(hWndOver, sWindowText, 100)      ' Window text
  68. DATOS = DATOS & "Window Text: " & Left(sWindowText, r) & vbCrLf
  69. r = GetClassName(hWndOver, sClassName, 100)         ' Window Class
  70. DATOS = DATOS & "Window Class Name: " & Left(sClassName, r) & vbCrLf
  71. lWindowStyle = GetWindowLong(hWndOver, GWL_STYLE)   ' Window Style
  72. DATOS = DATOS & "Window Style: &H" & Hex(lWindowStyle) & vbCrLf
  73.  
  74. hWndParent = GetParent(hWndOver) ' Consigue el handle padre de una ventana
  75.  
  76. 'Obtiene más información si hay un handle padre
  77. If hWndParent <> 0 Then
  78. wID = GetWindowWord(hWndOver, GWW_ID) ' Obiene el ID
  79. DATOS = DATOS & "Window ID Number: &H" & Hex(wID) & vbCrLf
  80. DATOS = DATOS & "Parent Window Handle: &H" & Hex(hWndParent) & vbCrLf
  81.  
  82. 'Obiene el texto de la ventana
  83. r = GetWindowText(hWndParent, sParentWindowText, 100)
  84. DATOS = DATOS & "Parent Window Text: " & Left(sParentWindowText, r) & vbCrLf
  85.  
  86. 'Consigue el ClassName de la ventana padre
  87. r = GetClassName(hWndParent, sParentClassName, 100)
  88. DATOS = DATOS & "Parent Window Class Name: " & Left(sParentClassName, r) & vbCrLf
  89. Else
  90.  
  91. 'Obtiene los campos cuando no es padre:
  92. DATOS = DATOS & "Window ID Number: N/A" & vbCrLf
  93. DATOS = DATOS & "Parent Window Handle: N/A" & vbCrLf
  94. DATOS = DATOS & "Parent Window Text : N/A" & vbCrLf
  95. DATOS = DATOS & "Parent Window Class Name: N/A" & vbCrLf
  96. End If
  97. ' Consigue el  window instance:
  98. hInstance = GetWindowWord(hWndOver, GWW_HINSTANCE)
  99.  
  100. 'Consigue el modulo de nombre de archivo (obsoleto)
  101. r = GetModuleFileName(hInstance, sModuleFileName, 100)
  102. DATOS = DATOS & "Module: " & Left(sModuleFileName, r)
  103. End If
  104. Text1.Text = DATOS
  105. End Sub
  106.  

Saludos


773  Programación / Programación Visual Basic / Re: Abrir ejecutable en un form - ¿Es posible abrir Chrome? en: 7 Febrero 2015, 12:19 pm
Hola,

Esta idea de meter una aplicación dentro de un form, me ha venido genial para un viejo programa de inglés que tengo que requiere ejecutarse a pantalla completa y una resolución de  640x480, tapándome la barra de tareas de windows. El programa se veía en un cuadrito en el centro de la pantalla y el resto en negro, a no ser que redujese la resolución.  Así que gracias.

En cuanto al código que puse he visto fallos. Por ejemplo al cerrar la aplicación también se cerraban todas las ventanas de Chrome, la de dentro del form y las que estaban fuera si era el caso. Se debe a que valor del handle no es público. También ocurre que al utilizar ShowWindow se genera un error de visualización si la última vez que se cerró Chrome estaba en modo Normal. Lo he sustituido por SetWindowPos.

Aquí dejo el código algo mejorado:
Código
  1. 'Nombres de clase (ClassName) de Chrome
  2. 'Chrome_WidgetWin_1           <---Padre
  3. 'Chrome_RenderWidgetHostHWND  <---hijo
  4.  
  5. '//Funciones API para incrustar la aplicación en el picture
  6. Private Declare Function SetParent Lib "user32" _
  7. (ByVal hWndChild As Long, _
  8. ByVal HWNDParent As Long) As Long
  9. Private Declare Function ShowWindow Lib "user32" _
  10. (ByVal hwnd As Long, _
  11. ByVal nCmdShow As Long) As Long
  12. Private Declare Function SetWindowPos Lib "user32" _
  13. (ByVal hwnd As Long, _
  14. ByVal hWndInsertAfter As Long, ByVal x As Long, _
  15. ByVal y As Long, ByVal cx As Long, _
  16. ByVal cy As Long, _
  17. ByVal wFlags As Long) As Long
  18.  
  19. '//Funcion API para obtener el handle de la aplicación que se quiere menter en el Picture
  20. Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" _
  21. (ByVal lpClassName As String, _
  22. ByVal lpWindowName As String) As Long
  23.  
  24. '//Ejecuta el programa
  25. Private Declare Function ShellExecute Lib "shell32.dll" Alias "ShellExecuteA" _
  26. (ByVal hwnd As Long, _
  27. ByVal lpOperation As String, _
  28. ByVal lpFile As String, _
  29. ByVal lpParameters As String, _
  30. ByVal lpDirectory As String, ByVal nShowCmd As Long) As Long
  31.  
  32. '//Función para cerrar la aplicación incrustada
  33. Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" _
  34. (ByVal hwnd As Long, _
  35. ByVal wMsg As Long, _
  36. ByVal wParam As Long, _
  37. lParam As Any) As Long
  38.  
  39. Const SHOW_FULLSCREEN = 3
  40. Const SW_SHOWMINIMIZED = 2
  41. Const SW_SHOWMAXIMIZED = 3
  42. Const SWP_NOZORDER = &H4
  43. Const WM_SYSCOMMAND = &H112
  44. Const SC_CLOSE = &HF060&
  45.  
  46. '//////////////////////////////////////////////
  47. '//'Variable para el handle padre de Chrome  //
  48. '//Debe ser variable pública para que al     //
  49. '//cerrar el form únicamente se cierre el    //
  50. '//chrome incrustado en el picture y no      //
  51. '//otra ventana externa de chrome         /////
  52.        Dim HWNDParent As Long
  53. '//////////////////////////////////////////////
  54.  
  55. Private Sub Command1_Click()
  56.   ShellExecute Me.hwnd, "", "chrome.exe", _
  57.    "www.elhacker.net", Environ("programfiles") & "\Google\Chrome\Application\", SW_SHOWMINIMIZED
  58.   Espera (5)  'Espera cinco segundos a que se cargue
  59.   HWNDParent = FindWindow("Chrome_WidgetWin_1", vbNullString) 'Obtiene el handle padre
  60. Call SetParent(HWNDParent, Picture1.hwnd) 'Meter la apcliación en el picture
  61. 'Ajusta la ventana de Chrome al Picture
  62. Call SetWindowPos(HWNDParent, HWND_TOP, 0, 0, _
  63. Picture1.ScaleWidth, _
  64. Picture1.ScaleHeight, _
  65. SWP_NOZORDER)
  66. End Sub
  67. Private Sub Espera(Segundos As Single)
  68. Dim ComienzoSeg As Single
  69. Dim FinSeg As Single
  70. ComienzoSeg = Timer
  71. FinSeg = ComienzoSeg + Segundos
  72. Do While FinSeg > Timer
  73.     DoEvents
  74.     If ComienzoSeg > Timer Then
  75.         FinSeg = FinSeg - 24 * 60 * 60
  76.     End If
  77. Loop
  78. End Sub
  79.  
  80. Private Sub Cerrar_Chrome(hwnd As Long)
  81. If HWNDParent <> 0 Then
  82.    Call SetParent(HWNDParent, 0)  ' Libera el programa
  83.    Call SendMessage(HWNDParent, WM_SYSCOMMAND, SC_CLOSE, ByVal 0&) 'Cierra el programa
  84.    HWNDParent = 0
  85. End If
  86.   End Sub
  87. Private Sub Form_Load()
  88.    Picture1.ScaleMode = 3 'pixels <-importante para mover _
  89.     y establecer correctamente las dimensiones de la ventana _
  90.     de chrome dentro del picture
  91. End Sub
  92.  
  93. Private Sub Form_Unload(Cancel As Integer)
  94.   Call Cerrar_Chrome(HWNDParent) 'Cierra Chrome
  95. End Sub
  96.  
  97.  

El handle (hwnd) o 'asa' es un número aleatorio que Windows asigna a cada ventana que se abre en el escritorio. Se pueden cambiar características o enviar mensajes a  dichas ventanas usando ese número. Como se ha podido ver con SetWindowPos, SetParent, SendMessage y ShowWindow.

 
774  Programación / Programación Visual Basic / Descargar archivos grandes con API en VB6 en: 5 Febrero 2015, 16:30 pm
Hola,
Ya uso Vb,net pero estoy corrigiendo un programa que hice con vb6. Es un poco grande y no quiero pasarlo a vb.net.

El programa descarga archivos pero ocurre que NO descarga archivos que sean demasiado grandes.

El código que uso para descargar es este:

Código
  1. Private Declare Function URLDownloadToFile Lib "urlmon" _ Alias "URLDownloadToFileA" (ByVal pCaller As Long,  _
  2. ByVal szURL As String,  _
  3. ByVal szFileName As String,  _
  4. ByVal dwReserved As Long,  _
  5. ByVal lpfnCB As Long) As Long
  6. Dim Contador As Integer
  7.    Const ERROR_SUCCESS As Long = 0
  8.    Const INTERNET_FLAG_RELOAD As Long = &H80000000
  9.    Const BINDF_ASYNCHRONOUS = &H1
  10.    Const BINDF_ASYNCSTORAGE = &H2
  11.    Const BINDF_NOPROGRESSIVERENDERING = &H4
  12.    Const BINDF_OFFLINEOPERATION = &H8
  13.    Const BINDF_GETNEWESTVERSION = &H10 ' El funcionamiento del lazo debe recuperar la más nueva versión de los datos.
  14.    Const BINDF_NOWRITECACHE = &H20
  15.    Const BINDF_NEEDFILE = &H40
  16.    Const BINDF_PULLDATA = &H80
  17.    Const BINDF_IGNORESECURITYPROBLEM = &H100
  18.    Const BINDF_RESYNCHRONIZE = &H200
  19.    Const BINDF_HYPERLINK = &H400
  20.    Const BINDF_NO_UI = &H800
  21.    Const BINDF_SILENTOPERATION = &H1000
  22.    Const BINDF_PRAGMA_NO_CACHE = &H2000
  23.    Const BINDF_FREE_THREADED = &H10000
  24.    Const BINDF_DIRECT_READ = &H20000
  25.    Const BINDF_FORMS_SUBMIT = &H40000
  26.    Const BINDF_GETFROMCACHE_IF_NET_FAIL = &H80000
  27.  
  28.  
  29.  
  30. Public Function DownloadFile(URL As String,  _
  31. LocalFilename As String) As Boolean
  32.    Dim lngRetVal As Long
  33.    lngRetVal = URLDownloadToFile(0&, URL, LocalFilename, BINDF_ASYNCHRONOUS , 0&)
  34.    If lngRetVal = 0 Then DownloadFile = True
  35. End Function
775  Programación / Programación Visual Basic / Re: Abrir ejecutable en un form - ¿Es posible abrir Chrome? en: 4 Febrero 2015, 15:13 pm
Sin hardcodear:

Código
  1. GetModuleFileName(NULL, EXEFullPath, MAX_PATH);
  2.  

El NULL es el baseaddress, yo lo llamo desde un hook (DLL) y cuando pasa por una función mia, estoy seguro que es del thread del mismo exe y no de mi thread de la DLL.

PD: éso si está en ejecución, de lo contrario es fijarse en el Registro en donde está la lista de todos los programas instalados.

¿Sin hardcodear? jajaja, ¿Eso está en el diccionario? ¿Qué significa? Es igual, lo supongo :P

"sin hardcodear" otra forma que hay de obtener el /Program files/ del sistema que tenía por ahí guardada y que estaba buscando es esta:

Código
  1. Private Sub Command1_Click()
  2. Dim X As Variant
  3. Dim Y As Variant
  4.   Set X = CreateObject("Wscript.Shell")
  5.    Set Y = X.Environment("Process")
  6.    Print Y("PROGRAMFILES")
  7. End Sub


En cuanto  a lo que has posteado  Miseryk , lo de GetModuleHandle no lo he probado y no se muy bien como va. He probado lo siguiente:
Código
  1. Dim hModule%, Buffer$, Length%, Msg$
  2.         hModule% = GetModuleHandle("notepad.exe")
  3.         Buffer$ = Space$(255)
  4.         Length% = GetModuleFileName(hModule%, Buffer$, Len(Buffer$))
  5.         Buffer$ = Left$(Buffer$, Length%)
  6.         Msg$ = Buffer$
  7.         Msgbox Msg$
:

Pero me da el directorio de VB6.EXE y no el del notepad.exe en este caso, ni siquiera estando en ejecución. He probado sustituyendo hModule% por el hande de la aplicación (en ejecución). Pero nada, que tampoco.

Al usar NULL supongo que tu vas por C++ y no VB, ya que NULL  no es válido en VB6, en sustitución sería vbNull
776  Programación / Programación Visual Basic / Re: Abrir ejecutable en un form - ¿Es posible abrir Chrome? en: 4 Febrero 2015, 13:53 pm
Hola @okik , probé tu código y funciona perfecto. Tengo una duda, ¿Es posible detectar automáticamente la Ruta de Chrome, sin necesidad de que el usuario busque la ruta, en mi caso es "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe"?, me preguntaba si hay alguna forma de detectar la ruta de chrome.exe automáticamente.

Muchas gracias nuevamente.

Si claro que se puede. Se me ocurren varias maneras.

Pero antes de nada permíteme corregir unas líneas del código que te he dado antes. Hice un copia y pega de mi propio código en Form_Unload y se han colado un par de líneas que no tienen utilidad ahí, se trata de la variable hWndChild   que fue un intento de introducir sólamente la Web en el Picture, funcionaba con el Notepad por ejemplo, pero no con Google Chrome. Lo borré en otras partes del código, pero no en el Form_Load, se me pasó. También está lo de Espera(5) que si que es necesario más arriba, porque hay que esperar a que se cargue Google Chrome antes de introducirlo en el Picture, pero para cerrar no hace falta.

Código
  1. Private Sub Form_Unload(Cancel As Integer)
  2.    Dim hwnd As Long
  3.    Dim hWndChild As Long  '<---- BORRAR ESTA LÍNEA
  4.    'Espera (5) '<---- BORRAR ESTA LÍNEA
  5.    hwnd = FindWindow("Chrome_WidgetWin_1", vbNullString)
  6.    Call Cerrar_Google(hwnd) 'cierra Google
  7. End Sub

Debería ser así:

Código
  1. Private Sub Form_Unload(Cancel As Integer)
  2.    Dim hwnd As Long
  3.    hwnd = FindWindow("Chrome_WidgetWin_1", vbNullString)
  4.    Call Cerrar_Google(hwnd) 'cierra Google
  5. End Sub

En cuanto a lo de
- Primera opción: Crear un código de busqueda de Chrome.exe y obtener su directorio (ideal para programas que al actualizarse van cambiando la ubicación) por ejemplo si fuera "\Google\Chrome\Application\V0014\Chrome.exe" y al actualizarse cambiara a  "\Google\Chrome\Application\V00321\Chrome.exe". Que no es el caso. Te lo digo por si alguna vez te encuentras alguna cosa así.

- Segunda opción: Obtener mediante la función Environ el directorio de \program files\ del sistema:
Código
  1. Private Sub Command1_Click()
  2. Print Environ("programfiles")
  3. End Sub
  4.  
y luego añades el resto  "\Google\Chrome\Application\chrome.exe"
Código
  1. Print Environ("programfiles") & "\Google\Chrome\Application\chrome.exe"

- Tercera opción: accediendo al registro de windows



777  Programación / Programación Visual Basic / Re: Abrir ejecutable en un form - ¿Es posible abrir Chrome? en: 3 Febrero 2015, 18:22 pm
Hola

Me resultó interesante tu idea. Así que he estado trabajando un poquillo en el tema. A mi me funciona:
- Crea un Picture (que sea un poco grande)
- Crea un CommandButton
-Intruduce el siguiente código en un form
Código
  1.   '//Funciones API para incrustar el programa en el picture
  2.    Private Declare Function SetParent Lib "user32" (ByVal hWndChild As Long,  _
  3. ByVal hWndParent As Long) As Long
  4.    Private Declare Function ShowWindow Lib "user32" (ByVal hwnd As Long,  _
  5. ByVal nCmdShow As Long) As Long
  6.    Const SHOWMAXIMIZED_eSW = 3&
  7.  
  8.    '//Funciones API para obtener el handle de la aplicación que queremos meter en un picture
  9.    Private Declare Function FindWindow Lib "user32" Alias "FindWindowA"  _
  10. (ByVal lpClassName As String,  _
  11. ByVal lpWindowName As String) As Long
  12.  
  13.    '//Ejecuta el programa
  14.    Private Declare Function ShellExecute Lib "shell32.dll" Alias "ShellExecuteA" (ByVal hwnd As Long, _
  15. ByVal lpOperation As String,  _
  16. ByVal lpFile As String,  _
  17. ByVal lpParameters As String,  _
  18. ByVal lpDirectory As String, ByVal nShowCmd As Long) As Long
  19.  
  20.    Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, _
  21.    ByVal wMsg As Long, _
  22.    ByVal wParam As Long, _
  23.    lParam As Any) As Long
  24.  
  25.  
  26.    Const WM_SYSCOMMAND = &H112
  27.    Const SC_CLOSE = &HF060&
  28.  
  29. 'ClassName Chrome
  30. 'Chrome_RenderWidgetHostHWND  <---hijo
  31. 'Chrome_WidgetWin_1  <----Padre
  32. Private Sub Command1_Click()
  33.    Dim hwnd As Long
  34.    ' "C:\Program Files\Google\Chrome\Application\chrome.exe", vbHide 'No sirve
  35.    ShellExecute Me.hwnd, "Open", "C:\Program Files\Google\Chrome\Application\chrome.exe",  _
  36. "www.elhacker.net", "", 1
  37.    Espera (5) 'Espera cinco segundos a que se cargue
  38.    hwnd = FindWindow("Chrome_WidgetWin_1", vbNullString) 'Obtiene el handle padre
  39. Call SetParent(hwnd, Picture1.hwnd) 'Meter la apcliación en el picture
  40. Call ShowWindow(hwnd, SHOWMAXIMIZED_eSW) 'Lo ajusta al cuadro
  41. End Sub
  42.  
  43. Private Sub Espera(Segundos As Single)
  44.  Dim ComienzoSeg As Single
  45.  Dim FinSeg As Single
  46.  ComienzoSeg = Timer
  47.  FinSeg = ComienzoSeg + Segundos
  48.  Do While FinSeg > Timer
  49.      DoEvents
  50.      If ComienzoSeg > Timer Then
  51.          FinSeg = FinSeg - 24 * 60 * 60
  52.      End If
  53.  Loop
  54. End Sub
  55.  
  56.    Private Sub Cerrar_Google(hwnd As Long)
  57.    If hwnd <> 0 Then
  58.    Call SetParent(hwnd, 0)  ' Libera el programa
  59.    Call SendMessage(hwnd, WM_SYSCOMMAND, SC_CLOSE, ByVal 0&) 'Cierra el programa
  60.    hwnd = 0
  61.    End If
  62.    End Sub
  63.  
  64.  
  65. Private Sub Form_Unload(Cancel As Integer)
  66.    Dim hwnd As Long
  67.    hwnd = FindWindow("Chrome_WidgetWin_1", vbNullString)
  68.    Call Cerrar_Google(hwnd) 'cierra Google
  69. End Sub

NOTA IMPORTANTE:
Tan sólo hay un problemilla. Cuando le des al botón, Chrome se iniciará pero fuera de form, pasado un par de segundos se introduce en el form. Lo suyo sería iniciarlo en modo hide (oculto) y luego volverlo a hacer visible.  Estoy mirando a ver, el shell "programa", vbhide, no funciona.

La ventaja que tiene usar ShellExecute es que puedes elegir la URL que quieres que muestre

Si usas 64Bits, la dirección del programa debes cambiarla a "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" y bueno ya tu ya sabes, el directorio debe ser el que tu tengas en tu compu o sea

Saludos
778  Sistemas Operativos / Windows / Re: Alguien a probado y dispone de Windows 10? en: 3 Febrero 2015, 15:59 pm
http://windows.microsoft.com/en-us/windows/preview-iso

http://www.xatakawindows.com/windows/windows-10
779  Sistemas Operativos / Windows / Como motrar el sistema de búsqueda clásico de Windows (98,Me) en: 3 Febrero 2015, 15:34 pm
Hola,
windows XP te muestra un perrito que quiero llevar a la perrera...vamos quitarlo de ahí.






En realidad es mera curiosidad de como hacerlo, porque una vez me descargué un XP de windowsue, que había sido modificado, incluso el programa de instalación. Venía con algunos reagalitos (virus, troyanos), y había quitado el perrito. Siempre me he preguntado como lo hizo. Supongo que el sistema de búsqueda usa algunos dlls, y que habrá que sustiturilos o modificarlos.

Gracias



Me respondo yo mismo... lo encontre aquí:

http://www.fermu.com/es/start/16-regedit/configuracion-del-sistema/87-quitar-el-perrito-de-la-busqueda-de-xp

Hay que entrar en el registro de windows:
-Tecla windows + R
- escribir: regedit
-ir a:
[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\CabinetState]
- Crear una nueva clave alfanumérica y nombrarla: use search asst
- Modificar la clave y poner: no
- no hace falta reiniciar
780  Programación / .NET (C#, VB.NET, ASP) / Como saltarme la "Alerta de seguridad" con Webbrowser en VB.Net 2010 en: 3 Febrero 2015, 14:48 pm


La informacion de revocacion del certificado de seguridad de este sitio no está disponible. ¿Desea continuar?


He econtrado este código:

Código
  1. Public Shared Function ValidateServerCertificate(ByVal sender As Object, ByVal certificate As System.Security.Cryptography.X509Certificates.X509Certificate, ByVal chain As System.Security.Cryptography.X509Certificates.X509Chain, ByVal sslPolicyErrors As System.Net.Security.SslPolicyErrors) As Boolean
  2.        Return True
  3.    End Function
  4.    Private Sub WebBrowser1_Validated(ByVal sender As Object, ByVal e As System.EventArgs) Handles WebBrowser1.Validated
  5.        System.Net.ServicePointManager.ServerCertificateValidationCallback = AddressOf ValidateServerCertificate
  6.    End Sub

Me funcionó  creo que un par de veces pero ahora no se porqué no funciona, sigue vuelve a salir la alerta de seguridad.

y si pongo:
Código
  1. WebBrowser1.ScriptErrorsSuppressed = True

simplemente no entra y ni sale mensaje ni nada


Páginas: 1 ... 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 [78] 79 80
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines