vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
TOP-Angebot: 17 bzw. 24 Entwickler-Vollversionen zum unschlagbaren Preis!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Fortgeschrittene
Re: MsgBoxes abfangen 
Autor: mquadrat
Datum: 17.08.12 10:25

Punkt 1: Lustig :-|
Punkt 2: Nun ja...

Ich hab mir über API (! , ja, keine direkte "Listener-API" aber nahe dran) inzwischen ein Programm gebastelt, welches die gewünschte Funktionalität aufweist. Die verkürzte Form sieht folgendermaßen aus:

Public Class Form1
 
    Private Declare Function GetWindowText Lib "user32" Alias "GetWindowTextA" ( _
        ByVal hwnd As Long, _
        ByVal lpString As String, _
        ByVal cch As Long _
        ) As Long
 
    Private Declare Function FindWindowEx Lib "user32" Alias "FindWindowExA" ( _
        ByVal hwndParent As Long, _
        ByVal hwndChildAfter As Long, _
        ByVal lpszClass As String, _
        ByVal lpszCaption As String _
        ) As Long
 
    Private Declare Function GetParent Lib "user32" (ByVal hwnd As Long) As Long
 
    Public Declare Function SendMessage Lib "user32" Alias "SendMessageA" ( _
        ByVal hwnd As IntPtr, _
        ByVal uMsg As Int32, _
        ByVal wParam As Int32, _
        ByVal lParam As Int32) As Int32
 
    Private WM_NCDESTROY As Integer = &H82
 
    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As _
      System.EventArgs) Handles MyBase.Load
 
        Timer1.Interval = 1000
        Timer1.Start()
 
    End Sub
 
    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As _
      System.EventArgs) Handles Button1.Click
        MsgBox(1, MsgBoxStyle.Question, "h")
        'MessageBox.Show("s", "d", MessageBoxButtons.YesNo)
    End Sub
 
    Private Sub Timer1_Tick(ByVal sender As Object, ByVal e As _
      System.EventArgs) Handles Timer1.Tick
        Dim dlghWnd As Long
        Dim lpString As String 'owners caption
        Dim lhwnd As Long
        Dim hWndOwner As Long
        While lpString <> "Form1" 'owners caption
            lpString = Space(255)
            dlghWnd = FindWindowEx(0&, lhwnd, "#32770", vbNullString)  'Suchen 
            ' nach Fenster mit MsgBox-Handle
            If dlghWnd = 0 Then Exit Sub
            hWndOwner = GetParent(dlghWnd)  'Handle der Owner-Form bestimmen
            GetWindowText(hWndOwner, lpString, 255&)  'Titel der Owner-Form 
            ' bestimmen
            lpString = Mid(lpString, 1, InStr(lpString, Chr(0)) - 1)  'Titel 
            ' der Owner-Form zurechtschneiden
            lhwnd = dlghWnd
        End While
        dlghWnd = SendMessage(lhwnd, WM_NCDESTROY, 0, 0)  'MsgBox schließen
    End Sub
End Class
Wenn auf Button1 geklickt wird, fängt Timer1 die MsgBox automatisch ab und schließt sie.
Prinzipiell löst das mein Problem wahrscheinlich schon, ich bin halt nur nicht sicher ob der Timer im Hintergrund zuviel Ressourcen frisst, sodass meine (teils recht aufwändigen) Berechnungen dadurch performancemäßig beeinflusst werden.
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
MsgBoxes abfangen1.204mquadrat17.08.12 08:05
Re: MsgBoxes abfangen817ModeratorFZelle17.08.12 10:04
Re: MsgBoxes abfangen775mquadrat17.08.12 10:25
Re: MsgBoxes abfangen782Enium17.08.12 10:25
Re: MsgBoxes abfangen742mquadrat17.08.12 10:27
Re: MsgBoxes abfangen726mquadrat17.08.12 13:45
Re: MsgBoxes abfangen704ModeratorFZelle17.08.12 14:40
Re: MsgBoxes abfangen721Micke17.08.12 14:58

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel