Manche Datenbankfelder beinhalten Memos, die eine unbestimmte Anzahl an Buchstaben besitzen. Lädt man solch ein DB-Feld in ein MSHFlexGrid, dann wird bei aktivem WORD-WRAP zwar der Text umgebrochen, aber die Zeilenhöhe bleibt bestehen (man sieht nur die erste Zeile) Stellt man nun die RowHeight-Eigenschaft auf einen festen Wert, dann bringt das nicht sehr viel !!! Man kann zwar AllowUserResizing auf 2 (Zeilen) stellen, dies hat nur den Nachteil, dass der Benutzer viel hin und herschieben muß, um beispielsweise einen Text zu suchen! Hier die Abhilfe .... Wir benötigen:
Hier die Funktion: Public Function MSH_CELLHOEHE( _ ByVal Textbaustein As String, _ Buchstaben As Integer, _ Cellhoehe As Integer) As Long Dim zz As Long zz = Len(Textbaustein) If zz > Buchstaben Then zz = Int(Len(Textbaustein) / Buchstaben) + 1 MSH_CELLHOEHE = Cellhoehe * zz Else MSH_CELLHOEHE = Cellhoehe End If End Function Beschreibung der Funktion: Die Funktion benötigt:
Aufruf der Funktion: ' Im nachfolgenden Beispiel werden eine ID und 4 ' Textfelder (MEMO) aus der Datenbank geladen. ' Das Flexgrid hat 5 Cols. Die Cellheight setze ich ' mit 285 und die Anzahl aller Buchstaben die in ' eine Zelle nebeneinander passen setze ich auf 33 ' (entspricht in etwa eine Colwidth von 2700) Public Sub MSHFLEXGRID1_FUELLEN() Dim rs As New ADODB.Recordset Dim ff as integer ' Rowzaehler Dim zellmax as long ' Prüft, welche Row die höchste Cell hat ff = 1 ' Recordset erstellen rs.Open "SELECT ID, Text1, Text2, Text3, Text4 " & _ " FROM tblIrgendeineTabelle ORDER BY ID", _ adocn, adOpenForwardOnly, adLockReadOnly If rs.State = adStateOpen Then Do Until rs.EOF With Form1.MSHFlexGrid1 .Rows = ff + 1 .Row = ff .Col = 0: .Text = rs(0) ' ID .Col = 1: .Text = nz(rs(1)) ' TEXT 1 .RowHeight(ff) = MSH_CELLHOEHE(nz(rs(1)), 33, 285) zellmax = MSH_CELLHOEHE(nz(rs(1)), 33, 285) .Col = 2: .Text = nz(rs(2)) ' TEXT 2 If MSH_CELLHOEHE(nz(rs(2)), 33, 285) >= zellmax Then zellmax = MSH_CELLHOEHE(nz(rs(2)), 33, 285) .RowHeight(ff) = MSH_CELLHOEHE(nz(rs(2)), 33, 285) End If .Col = 3: .Text = nz(rs(3)) ' TEXT 3 If MSH_CELLHOEHE(nz(rs(3)), 33, 285) >= zellmax Then zellmax = MSH_CELLHOEHE(nz(rs(3)), 33, 285) .RowHeight(ff) = MSH_CELLHOEHE(nz(rs(3)), 33, 285) End If .Col = 4: .Text = nz(rs(4)) ' TEXT 4 If MSH_CELLHOEHE(nz(rs(4)), 33, 285) >= zellmax Then zellmax = MSH_CELLHOEHE(nz(rs(4)), 33, 285) .RowHeight(ff) = MSH_CELLHOEHE(nz(rs(4)), 33, 285) End If zellmax = 0 ff = ff + 1 rs.MoveNext End With Loop End If rs.Close Set rs = Nothing End Sub Private Function nz(ByVal vValue As Variant) As Variant ' Prüft, ob ein Feld den Wert NULL hat, ' um so den unliebsamen Fehler 94 zu vermeiden If IsNull(vValue) Then nz = "" Else nz = vValue End If End Function |