Das FlexGrid ist ein beliebtes Control unter VB6. Viele User wünschen sich aber eine Eigenschaft, die es erlaubt, dass immer die gesamte Datenzeile selektiert wird und nicht nur die aktuelle Zelle. Mit nachfolgendem Tipp kann man genau dieses Verhalten nachbilden. Option Explicit ' MutliSelect erlauben ja/nein Private bMultiSelect As Boolean ' zuletzt selektierte Datenzeile Private intSelectedRow As Long Private Sub Form_Load() ' FlexGrid-Eigenschaften With MSFlexGrid1 .AllowBigSelection = False .FocusRect = flexFocusNone .SelectionMode = flexSelectionByRow .FixedCols = 0 .Rows = 20 .Cols = 5 End With bMultiSelect = False End Sub Private Sub MSFlexGrid1_GotFocus() ' Bei Fokuserhalt bspw. durch die TAB-Taste, ' sicherstellen, dass die gesamte Zeile selektiert wird With MSFlexGrid1 If .Row > 0 Then MarkLine .Row End If End With End Sub Private Sub MSFlexGrid1_MouseDown(Button As Integer, Shift As Integer, _ x As Single, y As Single) ' Datenzeile "merken" intSelectedRow = MSFlexGrid1.MouseRow End Sub Private Sub MSFlexGrid1_MouseMove(Button As Integer, Shift As Integer, _ x As Single, y As Single) With MSFlexGrid1 If Button <> 0 And Not bMultiSelect Then ' wenn kein MultiSelect, sicherstellen, dass immer nur die Datenzeile ' selektiert ist, unter der sich der Mauszeiger befindet If intSelectedRow <> .MouseRow And .MouseRow > 0 Then intSelectedRow = .MouseRow MarkLine intSelectedRow End If End If End With End Sub Private Sub MarkLine(ByVal Row As Long) ' Markiert die gesamte angegebene Datenzeile With MSFlexGrid1 .Row = Row .RowSel = .Row .Col = .FixedCols .ColSel = .Cols - 1 End With End Sub Dieser Tipp wurde bereits 14.301 mal aufgerufen.
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
TOP! Unser Nr. 1 ![]() Neu! sevDataGrid 3.0 Mehrspaltige Listen, mit oder ohne DB-Anbindung. Autom. Sortierung, Editieren von Spalteninhalten oder das interaktive Hinzufügen von Datenzeilen sind ebenso möglich wie das Erstellen eines Web-Reports. Tipp des Monats Access-Tools Vol.1 ![]() Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
|
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. |
|||||||||||||||||


FullRowSelect für das MSFlexGrid-Control


