How can I wrap text in a label using WPF?
Asked Answered
W

12

300

I have a TextBox and a Label. After clicking a button, I execute the following code:

 label1.Content = textbox1.Text; 

My question is, how do I enable text wrapping of the label? There may be too much text to display on one line, and I want it to automatically wrap to multiple lines if that is the case.

Welltodo answered 16/2, 2011 at 6:8 Comment(0)
V
454

The Label control doesn't directly support text wrapping in WPF. You should use a TextBlock instead. (Of course, you can place the TextBlock inside of a Label control, if you wish.)

Sample code:

<TextBlock TextWrapping="WrapWithOverflow">
    Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec adipiscing
    nulla quis libero egestas lobortis. Duis blandit imperdiet ornare. Nulla
    ac arcu ut purus placerat congue. Integer pretium fermentum gravida.
</TextBlock>
Venation answered 16/2, 2011 at 6:14 Comment(4)
This is fine, but not if you want to use the Target property feature of the Label--which to be fair is probably the only reason you'd use a Label over a TextBlock. I have provided an answer to this question that show's how to get wrapping in a Label (below)Humectant
JulianM - they already readonly https://mcmap.net/q/101798/-making-textblock-readonly ? Maybe they weren't in 2011Gabriella
@JulianM are you confusing TextBlock with TextBox? -- TextBlock's have been read-only since WPF was code named "Avalon".Katerine
I needed to set Padding="5" to match the padding in my other Label controls on the form. See Rajesh's answer below.Salomon
H
121

Often you cannot replace a Label with a TextBlock as you want to the use the Target property (which sets focus to the targeted control when using the keyboard e.g. ALT+C in the sample code below), as that's all a Label really offers over a TextBlock.

However, a Label uses a TextBlock to render text (if a string is placed in the Content property, which it typically is); therefore, you can add a style for TextBlock inside the Label like so:

<Label              
    Content="_Content Text:"
    Target="{Binding ElementName=MyTargetControl}">
    <Label.Resources>
        <Style TargetType="TextBlock">
            <Setter Property="TextWrapping" Value="Wrap" />
        </Style>
    </Label.Resources>
 </Label>
 <CheckBox x:Name = "MyTargetControl" />

This way you get to keep the functionality of a Label whilst also being able to wrap the text.

Humectant answered 1/3, 2012 at 11:13 Comment(3)
Does this actually work? From what I've seen the textblock that WPF adds does not exist in the logical tree and will not pick up your resource.Camisado
Yes, this does work—I tested it before I published my answer. You are right in that the elements targeted are not in the logical tree, but it's the visual tree that matters here.Humectant
This is a few years old but this does not seem to work with VS 2015. What does seem to work is using a TextBlock in a label <Label> <TextBlock TextWrapping="Wrap" Text="Whatever" /> </Label>Cigarillo
C
121

I used the following code.

    <Label>
        <Label.Content>
            <AccessText TextWrapping="Wrap" Text="xxxxx"/>
        </Label.Content>
    </Label>
Crystalcrystalline answered 15/10, 2012 at 6:39 Comment(4)
This is what worked best for me. Simple, no need to use other controls or add much code.Fatso
@jeremychan, I would mark this as the answer. I am happy that I scrolled down and seen this answer.Parsnip
I revert my up vote.. I tried using this but it by-passed my "HorizontalAlignment="Center"". Unlike using Textblock, it didn't...Judkins
The Label.Content part is unnecessary, as anything within the label tag is automatically content. Nonetheless, an excellent answer as it retains the ability to provide access keys, where all the solutions using a TextBlock fail in this regard.Refectory
R
40

You can put a TextBlock inside the label:

<Label> 
  <TextBlock Text="Long Text . . . ." TextWrapping="Wrap" /> 
</Label> 
Recountal answered 16/2, 2011 at 6:14 Comment(1)
I like this approach because it allows your Label styles to apply to this textblock without having to make additional styles for the TextBlock.Motor
D
20

To wrap text in the label control, change the the template of label as follows:

<Style x:Key="ErrorBoxStyle" TargetType="{x:Type Label}">
    <Setter Property="BorderBrush" Value="#FFF08A73"/>
    <Setter Property="BorderThickness" Value="1"/>
    <Setter Property="Foreground" Value="Red"/>
    <Setter Property="Background" Value="#FFFFE3DF"/>
    <Setter Property="FontWeight" Value="Bold"/>
    <Setter Property="Padding" Value="5"/>
    <Setter Property="HorizontalContentAlignment" Value="Left"/>
    <Setter Property="VerticalContentAlignment" Value="Top"/>
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type Label}">
                <Border BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" Padding="{TemplateBinding Padding}" SnapsToDevicePixels="true" CornerRadius="5" HorizontalAlignment="Stretch">
                     
                    <TextBlock TextWrapping="Wrap" Text="{TemplateBinding Content}"/>
                </Border>
                    
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>
Desperate answered 5/1, 2012 at 9:57 Comment(2)
Addendum: if you need to add text wrapping or other TextBlock-specific properties you can mix-in with the following recipe #3970785Femoral
Be careful with this answer. A normal Label can have a control as its content but this one doesn't allow it.Genna
J
13

Instead of using a Label class, I would recommend using a TextBlock. This allows you to set the TextWrapping appropriately.

You can always do:

 label1.Content = new TextBlock() { Text = textBox1.Text, TextWrapping = TextWrapping.Wrap };

However, if all this "label" is for is to display text, use a TextBlock instead.

Joon answered 16/2, 2011 at 6:13 Comment(1)
I ended up using this method for populating dynamic label contents. Seems to be the easiest and cleanest method. I imagine you could incorporate the line into the label1 definition, i.e. <br/> Label label1 = new Label() { Content = new TextBlock() { Text = caption, TextWrapping = TextWrapping.Wrap }, FontWeight = FontWeights.Normal };Indirection
K
6

We need to put some kind of control that can wrap text like textblock/textbox

 <Label Width="120" Height="100" >
        <TextBlock TextWrapping="Wrap">
            this is a very long text inside a textblock and this needs to be on multiline.
        </TextBlock>
    </Label>
Kasey answered 22/1, 2016 at 17:52 Comment(0)
R
2

try use this

lblresult.Content = lblresult.Content + "prime are :" + j + "\n";
Rozellarozelle answered 20/7, 2015 at 3:34 Comment(0)
B
2
 <Label x:Name="datetimeofmsg" 
           HorizontalAlignment="Left" Margin="4.286,55,0,0" 
           VerticalAlignment="Top" Background="{x:Null}" 
           FontWeight="Bold" Width="61.714" Height="20" Foreground="White">
        <Label.Content>
            <AccessText TextWrapping="Wrap"/>
        </Label.Content>
    </Label>
Batton answered 3/3, 2016 at 10:12 Comment(0)
U
1

I used this to retrieve data from MySql Database:

AccessText a = new AccessText();    
a.Text=reader[1].ToString();       // MySql reader
a.Width = 70;
a.TextWrapping = TextWrapping.WrapWithOverflow;
labels[i].Content = a;
Urease answered 11/6, 2018 at 22:35 Comment(0)
I
0

Try my version

<Label x:Name="myLabel">
        <TextBox FontSize="20" FontWeight="Bold" Background="Transparent" BorderBrush="Transparent"
                 IsReadOnly="true" TextWrapping="Wrap" HorizontalAlignment="Center" Focusable="False"
                 Foreground="{Binding Foreground, ElementName=myLabel}"
            Text="longMeeeeessssagggeeeeeeeeeeeeeeeeeeeeeeeeeee_Ooooooooeeeeeeeeeee" />
</Label>

Not necessary to use ScrollViewer control.

Ives answered 10/1, 2024 at 9:22 Comment(0)
F
0

Something else to keep in mind is parent containers, <Grid/> and what not. Impacted <ColumnDefinition/> needs to be adjusted accordingly, or the wrapping has no effect.

<Grid>
  <Grid.ColumnDefinitions>
    <!-- auto prohibits wrapping -->
    <ColumnDefinition Width="auto" />
    <!-- whereas the Kleene star allows wrapping -->
    <ColumnDefinition Width="*" />
  </Grid.ColumnDefinitions>
</Grid>
Fulani answered 22/2, 2024 at 20:8 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.