Rubrik: Oberfläche · Fenster | VB-Versionen: VB4, VB5, VB6 | 11.02.02 |
Fenster IMMER sichtbar anzeigen Nachfolgender Tipp zeigt, wie eine Form immer sichtbar angezeigt wird und nicht - auch nicht vom Desktop - verdeckt werden kann. | ||
Autor: TekoW | Bewertung: | Views: 35.877 |
ohne Homepage | System: Win9x, WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
Wie lässt sich eine Form immer im Vordergrund anzeigen? D.h. das Fenster soll nicht von anderen Anwendungsfenstern verdeckt werden können.
Hierzu haben wir Ihnen vor längerer Zeit schon einmal eine entsprechende Lösung aufgezeigt - und zwar mittels der API-Funktion SetWindowPos.
Das ganze funktioniert auch sehr gut - nur: Das Fenster lässt sich durch einen Klick auf "Desktop anzeigen" vom Desktop verdecken. Was aber, wenn das Fenster immer im Vordergrund angezeigt werden soll?
Lösung:
Man setze die BorderStyle-Eigenschaft der Form auf 3 - Dialog. Der Nachteil ist: Standardmässig werden jetzt keine Minimieren- und Maximieren-Buttons mehr angezeigt. Doch auch hierfür gibt es eine (API-)Lösung
Fügen Sie den gesamten nachfolgende Code in ein Modul ein.
Option Explicit ' alle benötigten API-Deklarationen Private Declare Function SetWindowPos Lib "user32" ( _ ByVal hwnd As Long, _ ByVal hWndInsertAfter As Long, _ ByVal x As Long, _ ByVal y As Long, _ ByVal cx As Long, _ ByVal cy As Long, _ ByVal wFlags As Long) As Long Private Declare Function GetWindowLong Lib "user32" _ Alias "GetWindowLongA" ( _ ByVal hwnd As Long, _ ByVal nIndex As Long) As Long Private Declare Function SetWindowLong Lib "user32" _ Alias "SetWindowLongA" ( _ ByVal hwnd As Long, _ ByVal nIndex As Long, _ ByVal dwNewLong As Long) As Long Private Const SWP_FRAMECHANGED = &H20 Private Const SWP_NOMOVE = &H2 Private Const SWP_NOSIZE = &H1 Private Const SWP_NOZORDER = &H4 Private Const SWP_NOACTIVATE = &H10 Private Const SWP_REFRESH = SWP_NOZORDER Or _ SWP_NOSIZE Or SWP_NOMOVE Or SWP_NOACTIVATE Or _ SWP_FRAMECHANGED Private Const GWL_STYLE = (-16) Private Const WS_MAXIMIZEBOX = &H10000 Private Const WS_MINIMIZEBOX = &H20000 Private Const HWND_TOPMOST = -1
' Minimieren/Maximieren Button einer Form anzeigen Public Sub MinMaxButton(Form As Form) Dim Style As Long With Form Style = GetWindowLong(.hwnd, GWL_STYLE) Style = Style Or WS_MINIMIZEBOX Or WS_MAXIMIZEBOX SetWindowLong .hwnd, GWL_STYLE, Style SetWindowPos .hwnd, 0, 0, 0, 0, 0, SWP_REFRESH End With End Sub
' Fenster immer im Vordergrund Public Sub TopWindow(hwnd As Long) SetWindowPos hwnd, HWND_TOPMOST, 0, 0, 0, 0, _ SWP_NOSIZE + SWP_NOMOVE End Sub
Um nun ein Fenster immer im Vordergrund anzuzeigen, welches nicht von anderen Anwendungen - auch nicht vom Windows-Desktop - verdeckt werden kann, fügen Sie folgenden Code in das Form_Load Event der Form ein:
Private Sub Form_Load() ' Minimieren/Maximieren Buttons zur ' Laufzeit anzeigen MinMaxButton Me ' Fenster immer im Vordergrund anzeigen TopWindow Me.hwnd End Sub
Einzig das Aktivieren des Bildschirmschoners kann das Fenster nun verdecken. Und wenn Sie diesen Zustand auch noch verhindern möchten, müssen Sie einfach noch einen Timer auf die Form setzen, die Interval-Eigenschaft entsprechendfestlegen und folgenden Code einfügen:
Private Sub Timer1_Timer() Call TopWindow(Me.hwnd) End Sub