Die Funktion GetRowContent liefert den Inhalt einer beliebigen Zeile eines RichTextBox-/TextBox-Controls. Wird keine Zeilenummer angegeben, wird der Inhalt der aktuellen Zeile ausgelesen, d.h. der Inhalt der Zeile, in der sich der Eingabecursor befindet. Option Explicit ' Benötigte API-Deklarationen Private Declare Function SendMessage Lib "user32" _ Alias "SendMessageA" ( _ ByVal hwnd As Long, _ ByVal wMsg As Long, _ ByVal wParam As Long, _ lParam As Any) As Long Private Const EM_GETLINE = &HC4 Private Const EM_GETSEL = &HB0 Private Const EM_LINEFROMCHAR = &HC9 Private Const EM_LINEINDEX = &HBB Private Const EM_LINELENGTH = &HC1 ' Beliebige Zeile eines RTF-/TextBox-Controls auslesen Private Function GetRowContent(hwnd As Long, _ Optional ByVal nLine As Long = 0) As String Dim CursorPos As Long Dim FirstChar As Long Dim RowLength As Long Dim Buffer() As Byte ' Falls keine Zeilennummer angegeben, ' Inhalt der aktuellen Zeile ermitteln If nLine < 1 Then CursorPos = SendMessage(hwnd, EM_GETSEL, 0, ByVal 0&) \ 65536 nLine = SendMessage(hwnd, EM_LINEFROMCHAR, CursorPos, ByVal 0&) Else nLine = nLine - 1 End If ' Zeilenlänge ermitteln FirstChar = SendMessage(hwnd, EM_LINEINDEX, nLine, ByVal 0&) RowLength = SendMessage(hwnd, EM_LINELENGTH, FirstChar, ByVal 0&) ' Puffer vorbereiten ReDim Buffer(RowLength + 1) Buffer(0) = RowLength + 1 ' Zeileninhalt in Puffer auslesen SendMessage hwnd, EM_GETLINE, nLine, Buffer(0) ' Inhalt als String zurückgeben GetRowContent = Left$(StrConv(Buffer, vbUnicode), RowLength) End Function Aufrufbeispiel: Dim sLine As String ' Inhalt der aktuellen Zeile sLine = GetRowContent(RichTextBox1.hWnd) ' Inhalt der 10. Zeile sLine = GetRowContent(RichTextBox1.hWnd, 10) Dieser Tipp wurde bereits 18.525 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (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. |
Neu! sevDTA 3.0 Pro SEPA mit Kontonummernprüfung Erstellen von SEPA-Dateien mit integriertem BIC-Verzeichnis und Konto- nummern-Prüfverfahren, so dass ungültige Bankdaten bereits im Vorfeld ermittelt werden können. Tipp des Monats März 2024 Dieter Otter UTF-8 Konvertierung von Dateien und Strings VB6 selbst verfügt über keine Funktionen zur UTF-8 Konvertierung von Daten. Mit Hilfe des ADODB.Stream-Objekts lassen sich diese fehlenden Funktionen aber schnell nachrüsten. 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. |