vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#

https://www.vbarchiv.net
Rubrik: Grafik und Font · Font & Text   |   VB-Versionen: VB2005, VB200824.06.10
Textlänge prüfen und mit Punkten modifizieren

Eine Funktion, die einen Text automatisch mit "..." kürzt, damit dieser in einem Control angezeigt werden kann.

Autor:   Dieter OtterBewertung:  Views:  9.582 
www.tools4vb.deSystem:  Win2k, WinXP, Vista, Win7, Win8, Win10 Beispielprojekt auf CD 

Heute möchten wir Ihnen eine kleine Funktion vorstellen, mit der sich der Text innerhalb eines Controls so kürzen lässt, dass dieser ggf. mit 3 abschließenden Punkten (...) angezeigt wird, wenn der Text nicht vollständig sichtbar im Control dargestellt werden kann.

''' <summary>
''' Modifiziert einen String mit "..." am Ende falls notwendig
''' </summary>
''' <param name="sender">Objekt (Control), das den gekürzten String anzeigen soll</param>
''' <param name="Text">Text, der ggf. gekürzt angezeigt werden soll</param>
''' <returns>Modifizierter Text</returns>
Public Function CompactText(ByVal sender As Object, ByVal Text As String) As String
  Dim flags As System.Windows.Forms.TextFormatFlags
 
  ' Flags für die Ausgabe des Textes
  flags = TextFormatFlags.Left Or _
    TextFormatFlags.WordEllipsis Or TextFormatFlags.EndEllipsis Or _
    TextFormatFlags.ModifyString
 
  ' Graphics-Objekt erstellen
  Using gr As Graphics = System.Drawing.Graphics.FromHwnd(sender.Handle)
    With sender
      ' Text gekürzt zurückgeben (falls erforderlich)
      TextRenderer.DrawText(gr, Text, .Font, .ClientRectangle, .ForeColor, flags)
      Return Text
    End With
  End Using
End Function

Aufrufbeispiel:
Benötigt wird ein Label-Control, eine TextBox und ein Button.

Private Sub Form1_Load(ByVal sender As System.Object, _
  ByVal e As System.EventArgs) Handles MyBase.Load
 
  Label1.AutoSize = False
  Label1.Width = 100
End Sub
Private Sub Button1_Click(ByVal sender As System.Object, _
  ByVal e As System.EventArgs) Handles Button1.Click
 
  ' Textbox-Inhalt im Label anzeigen und ggf. kürzen
  Label1.Text = CompactText(Label1, TextBox1.Text)
End Sub



Anzeige

Kauftipp Unser Dauerbrenner!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.
 
 
Copyright ©2000-2021 vb@rchiv Dieter OtterAlle Rechte vorbehalten.


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.