Rubrik: Controls · Sonstiges | VB-Versionen: VB4, VB5, VB6 | 21.02.05 |
autom. Navigation im SSTab-Control Dieser Tipp zeigt wie sich beim Drücken der TAB-Taste im letzten Eingabecontrol einer Registerkarte autom. die nächste Registerkarte im SSTab-Control öffnen lässt. | ||
Autor: Wolfgang Christ | Bewertung: | Views: 16.271 |
ohne Homepage | System: Win9x, WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
Wäre das nicht toll, wenn beim Drücken der TAB-Taste im letzten Eingabecontrol einer Registerkarte autom. die nächste Registerkarte im SSTab-Control geöffnet werden würde?
Auf diese Weise müsste der Anwender also nicht extra zur Maus greifen und die nächste Registerlasche anklicken.
Ok... kurze Überlegung... alles klar
Wenn das letzte Control verlassen wurde (LostFocus), müssen wir einfach prüfen, ob dies mittels der TAB-Taste passiert ist. Wenn ja, dann nächste Registerkarte aktivieren und nochmals die TAB-Taste senden, um autom. das erste Control der neuen Registerkarte zu aktivieren.
Fügen Sie hierzu nachfolgenden Code in den Codeteil der Form ein:
Option Explicit ' API - Funktionen Private Declare Function GetKeyboardState Lib "user32" ( _ pbKeyState As Byte) As Long ' benötigte Konstanten Private Const VK_TAB = &H9 Private Const VK_SHIFT = &H10
' Prüft, ob Tab-Taste gedrückt wurde. ' Optional in Verbindung mit der Shift-Taste Public Function CheckIfTabPressed( _ Optional ByVal bWithShift As Boolean = False) As Boolean Dim bKeyArray(255) As Byte ' Status ermitteln Call GetKeyboardState(bKeyArray(0)) ' 1. Prüfung: wurde TAB gedrückt ? If ((bKeyArray(VK_TAB) And &H80) = &H80) Then ' 2. Prüfung: SHIFT od. NICHT SHIFT If bWithShift Then ' Ist Shift gedrückt ? CheckIfTabPressed = ((bKeyArray(VK_SHIFT) And &H80) = &H80) Else ' Ist Shift nicht gedrückt ? CheckIfTabPressed = ((bKeyArray(VK_SHIFT) And &H80) <> &H80) End If Else ' Tab wurde nicht gedrückt CheckIfTabPressed = False End If End Function
Wie wendet man die Funktion nun an?
Fügen Sie dem Formular ein SSTab-Control hinzu. Platzieren Sie auf die 1. Registerkarte 2 TextBox-Controls (Text1 und Text2) und auf die 2. Registerkarte ebenfalls ein paar TextBox-Controls (Text3, Text4 und Text5). Auf die 3. Registerkarte platzieren Sie nur ein Control (Text6). Damit der Code korrekt funktioniert muss peinlichst auf die korrekte TAB-Reihenfolge geachtet werden, d.h. das SSTab-Control bekommt den TabIndex=0, die 1. TextBox den TabIndex=1, die 2. TextBox den TabIndex=3 usw.
Private Sub Form_Load() ' 1. Registerkarte aktivieren SSTab1.Tab = 0 ' 1. Control aktivieren SendKeys "{TAB}" End Sub
Private Sub Text1_LostFocus() If CheckIfTabPressed(True) Then ' Bei Shift+TAB letzte Registerkarte aktivieren SSTab1.Tab = SSTab1.Tabs - 1 SendKeys "{TAB}", True End If End Sub
Private Sub Text2_LostFocus() If CheckIfTabPressed(False) Then ' Bei TAB nächste Registerkarte aktivieren SSTab1.Tab = SSTab1.Tab + 1 SendKeys "{TAB}", True End If End Sub
Private Sub Text3_LostFocus() If CheckIfTabPressed(True) Then ' Bei Shift+TAB vorige Registerkarte aktivieren SSTab1.Tab = SSTab1.Tab - 1 SendKeys "{TAB}", True End If End Sub
Private Sub Text5_LostFocus() If CheckIfTabPressed(False) Then ' Bei TAB nächste Registerkarte aktivieren SSTab1.Tab = SSTab1.Tab + 1 SendKeys "{TAB}", True End If End Sub
Private Sub Text6_LostFocus() If CheckIfTabPressed(True) Then ' Bei Shift+TAB vorige Registerkarte aktivieren SSTab1.Tab = SSTab1.Tab - 1 SendKeys "{TAB}", True ElseIf CheckIfTabPressed(False) Then ' bei TAB 1. Registerkarte aktivieren SSTab1.Tab = 0 SendKeys "{TAB}", True End If End Sub