Die Community zu .NET und Classic VB.
Menü

VB 5/6-Tipp 0098: Weichen Umbrüche einer Textbox in Harte umwandeln

 von 

Beschreibung 

Texte die in einer Textbox stehen und länger als die Breite derselben sind, werden weich umgebrochen. Beim Versuch diese zu Drucken, wird das meiste wahrscheinlich abgeschnitten. Dieser Tip bietet die Möglichkeit einen Text in der gleichen Formatierung, wie ihn die TextBox darstellt, aus ihr auszulesen.

Schwierigkeitsgrad:

Schwierigkeitsgrad 2

Verwendete API-Aufrufe:

SendMessageA (SendMessage)

Download:

Download des Beispielprojektes [2,83 KB]

'Dieser Quellcode stammt von http://www.activevb.de
'und kann frei verwendet werden. Für eventuelle Schäden
'wird nicht gehaftet.

'Um Fehler oder Fragen zu klären, nutzen Sie bitte unser Forum.
'Ansonsten viel Spaß und Erfolg mit diesem Source!

'------------- Anfang Projektdatei Project1.vbp -------------
'--------- Anfang Formular "Form1" alias Form1.frm  ---------
' Steuerelement: Listen-Steuerelement "List1"
' Steuerelement: Schaltfläche "Command1"
' Steuerelement: Textfeld "Text1"
' Steuerelement: Beschriftungsfeld "Label1"

Option Explicit

Private Declare Function SendMessage Lib "user32" Alias _
        "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal _
        wParam As Long, ByVal lParam As Any) As Long
        
Private Const EM_GETLINE As Long = &HC4&
Private Const EM_GETLINECOUNT As Long = &HBA&
Private Const MAX_CHAR_PER_LINE As Long = &H100&

Private Sub Command1_Click()
    Dim Max As Long, X As Long
    
    Max = SendMessage(Text1.hwnd, EM_GETLINECOUNT, 0, 0&) - 1
    List1.Clear
    
    For X = 0 To Max
        List1.AddItem GetLine(Text1, X)
    Next X
End Sub

Private Sub List1_Click()
    Label1.Caption = List1.List(List1.ListIndex)
End Sub

Function GetLine(Text As TextBox, ByVal Line&) As String
    Dim Lo As Long, Hi As Long
    Dim Result As Long
    Dim Buff As String

    Lo = MAX_CHAR_PER_LINE And &HFF
    Hi = Int(MAX_CHAR_PER_LINE / &H100)
    Buff = Chr$(Lo) & Chr$(Hi) & Space$(MAX_CHAR_PER_LINE - 2)
    
    Result = SendMessage(Text.hwnd, EM_GETLINE, Line, Buff)
    GetLine = Left$(Buff, Result)
End Function
'---------- Ende Formular "Form1" alias Form1.frm  ----------
'-------------- Ende Projektdatei Project1.vbp --------------

Tipp-Kompatibilität:

Windows/VB-VersionWin32sWin95Win98WinMEWinNT4Win2000WinXP
VB4
VB5
VB6

Hat dieser Tipp auf Ihrem Betriebsystem und mit Ihrer VB-Version funktioniert?

Ja, funktioniert!

Nein, funktioniert nicht bei mir!

VB-Version:

Windows-Version:

Ihre Meinung  

Falls Sie Fragen zu diesem Artikel haben oder Ihre Erfahrung mit anderen Nutzern austauschen möchten, dann teilen Sie uns diese bitte in einem der unten vorhandenen Themen oder über einen neuen Beitrag mit. Hierzu können sie einfach einen Beitrag in einem zum Thema passenden Forum anlegen, welcher automatisch mit dieser Seite verknüpft wird.

Archivierte Nutzerkommentare 

Klicken Sie diesen Text an, wenn Sie die 2 archivierten Kommentare ansehen möchten.
Diese stammen noch von der Zeit, als es noch keine direkte Forenunterstützung für Fragen und Kommentare zu einzelnen Artikeln gab.
Aus Gründen der Vollständigkeit können Sie sich die ausgeblendeten Kommentare zu diesem Artikel aber gerne weiterhin ansehen.

Kommentar von Micha am 09.03.2005 um 21:21

Hallo,

wie kann ich die Zeichen-Nummer (Index) des ersten Zeichens dieser Zeile im ges. Len(Text1) ermitteln?

Danke Micha

Kommentar von Micha am 09.03.2005 um 21:21

Hallo,

wie kann ich die Zeichen-Nummer (Index) des ersten Zeichens dieser Zeile im ges. Len(Text1) ermitteln?

Danke Micha