Advertisement
ASP_Volume3 VB function enhancement #47299

Auto close messagebox

This function replaces VB's msgbox function and closes itself after the parameter provided number of seconds. The syntax and return values are exactly the same as msgbox except the first parameter is the number of seconds to display. Just add this code to a module (not a cls or frm) in your project and call ACmsgbox. Thanks to Sparq's submission here for help in writing this. with the added parameter of

AI

AI Summary: This codebase represents a historical implementation of the logic described in the metadata. Our preservation engine analyzes the structure to provide context for modern developers.

Source Code
original-source
Public Function ACmsgbox(AutoCloseSeconds As Long, prompt As String, Optional buttons As Long, _
      Optional title As String, Optional helpfile As String, _
      Optional context As Long) As Long
  
  sLastTitle = title
  SetTimer Screen.ActiveForm.hWnd, NV_CLOSEMSGBOX, AutoCloseSeconds * 1000, AddressOf TimerProc
  ACmsgbox = MsgBox(prompt, buttons, title, helpfile, context)
End Function
Private Sub TimerProc(ByVal hWnd As Long, ByVal uMsg As Long, ByVal idEvent As Long, ByVal dwTime As Long)
  Dim hMessageBox As Long
  
  KillTimer hWnd, idEvent
  
  Select Case idEvent
  Case NV_CLOSEMSGBOX
    hMessageBox = FindWindow("#32770", sLastTitle)
    If hMessageBox Then
      Call SetForegroundWindow(hMessageBox)
      SendKeys "{enter}"
    End If
    
    sLastTitle = vbNullString
  End Select
End Sub
Original Comments (3)
Recovered from Wayback Machine