Kennen Sie das Problem? Sie verwenden für die Darstellung von Daten das Microsoft FlexGrid Control. Meist enthält das Control dann auch mehr Zeilen als im sichtbaren Client-Bereich angezeigt werden können. Die Row-Eigenschaft lässt sich dann wunderbar dazu verwenden, den Fokus auf eine bestimmte Zeile zu setzen. Nehmen wir an das FlexGrid enthält insgesamt 200 Zeilen. Nun soll per Code die 100. Zeile den Fokus bekommen. Nichts einfacher als das, sollte man meinen: MSFlexGrid1.Row = 100 Und tatsächlich: die 100. Zeile bekommt den Fokus. Doch oh Schreck - die Zeile ist weg? Nein, nicht weg, sondern nur außerhalb des sichtbaren Clientbereichs. Obwohl die Zeile den Fokus hat. Wohlgemerkt! Mit einem kleinen Trick lässt sich dieser m.E. FlexGrid-Bug aber umgehen. Drückt man jetzt z.B. die Cursortaste nach unten, und dann wieder nach oben, so wird die Darstellung des FlexGrid aktualisiert. Die 100. Zeile wird somit sichtbar. Und genau das tun wir jetzt eben per Code Private Sub FlexGrid_SetRow(ByVal lRow As Long) With MSFlexGrid1 If lRow >= 0 And lRow < .Rows - 1 Then .Row = lRow .SetFocus SendKeys "{UP}{DOWN}", True End If End With End Sub Anstelle von MSFlexGrid1.Row = 100 müssen Sie jetzt allerdings folgende Anweisung einsetzen: FlexGrid_SetRow 100
Aber ich denke, das lässt sich verschmerzen Dieser Tipp wurde bereits 23.738 mal aufgerufen.
Anzeige
![]() ![]() ![]() (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. |
vb@rchiv CD Vol.6 ![]() ![]() Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! Online-Update-Funktion Entwickler-Vollversionen u.v.m. Tipp des Monats Neu! sevCoolbar 3.0 ![]() Professionelle Toolbars im modernen Design! Mit sevCoolbar erstellen Sie in wenigen Minuten ansprechende und moderne Toolbars und passen diese optimal an das Layout Ihrer Anwendung an (inkl. große Symbolbibliothek) - für VB und MS-Access |
||||||||||||||||
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. |