Autor Tema: Traer ventana de Access a primer plano  (Leído 2974 veces)

Desconectado xavi

  • Administrador
  • Habitual
  • *****
  • Mensajes: 220
Traer ventana de Access a primer plano
« en: Abril 20, 2012, 07:44:59 pm »
Palabras clave: ventana, Access, emergente, primer plano
Autor: Búho
Extraído de: La web del Búho

Pregunta
¿Cómo puedo hacer que al cargarse un formulario se coloque como ventana activa, aunque me encuentre trabajando en otra aplicación, por ejemplo Word?

Se trataría de hacer una agenda con avisos, y necesito que éstos se muestren aunque el usuario tenga minimizado Access y esté trabajando en otra aplicación.

Happy lo intenta con...
No se si es esto exactamente lo que buscas, pero puedes poner esta instrucción en el evento Al cargar del formulario, que lo que hará será maximizar la ventana de Access

    DoCmd.RunCommand acCmdAppMaximize

espero que te sirva

... pero parece que no es lo que se espera...
Gracias, pero no funciona.

Necesito que Access recupere el foco, que se convierta en la ventana
activa de Windows.

¿Alguna sugerencia?

El búho dice:
En un modulo

Código: [Seleccionar]
Option Compare Database
Option Explicit

'*********** Code Start **********
' This code was originally written by Dev Ashish.
' It is not to be altered or distributed,
' except as part of an application.
' You are free to use it in any application,
' provided the copyright notice is left unchanged.
'
' Code Courtesy of
' Dev Ashish
'
Global Const SW_HIDE = 0
Global Const SW_SHOWNORMAL = 1
Global Const SW_SHOWMINIMIZED = 2
Global Const SW_SHOWMAXIMIZED = 3


Private Declare Function apiShowWindow Lib "user32" _
    Alias "ShowWindow" (ByVal hwnd As Long, _
          ByVal nCmdShow As Long) As Long

Function fSetAccessWindow(nCmdShow As Long)
'Usage Examples
'Maximize window:
'       ?fSetAccessWindow(SW_SHOWMAXIMIZED)
'Minimize window:
'       ?fSetAccessWindow(SW_SHOWMINIMIZED)
'Hide window:
'       ?fSetAccessWindow(SW_HIDE)
'Normal window:
'       ?fSetAccessWindow(SW_SHOWNORMAL)
'
Dim loX  As Long
Dim loForm As Form
    On Error Resume Next
    Set loForm = Screen.ActiveForm
    If Err <> 0 Then 'no Activeform
      If nCmdShow = SW_HIDE Then
        MsgBox "Cannot hide Access unless " _
                    & "a form is on screen"
      Else
        loX = apiShowWindow(hWndAccessApp, nCmdShow)
        Err.Clear
      End If
    Else
        If nCmdShow = SW_SHOWMINIMIZED And loForm.Modal = True Then
            MsgBox "Cannot minimize Access with " _
                    & (loForm.Caption + " ") _
                    & "form on screen"
        ElseIf nCmdShow = SW_HIDE And loForm.PopUp <> True Then
            MsgBox "Cannot hide Access with " _
                    & (loForm.Caption + " ") _
                    & "form on screen"
        Else
            loX = apiShowWindow(hWndAccessApp, nCmdShow)
        End If
    End If
    fSetAccessWindow = (loX <> 0)
End Function

'************ Code End **********

Bastaría que en el form que utilizas como agenda, cuando se dispare el evento (Supongo que lo pondrás en el evento Timer) pusieras:


fSetAccessWindow(SW_SHOWMAXIMIZED)

Prueba, creo que esto funciona.