WPF text Wrap vs WrapWithOverflow

WpfWord Wrap

Wpf Problem Overview


What's the "conceptual" difference between TextWrapping="Wrap" and TextWrapping="WrapWithOverflow" (e.g. for a TextBox)? In the MSDN page about the class TextBox there is nothing ... Thank you.

Wpf Solutions


Solution 1 - Wpf

Some examples:

This is the original, unwrapped version:

No wrapping


This is NoWrap.

NoWrap


This is Wrap. The words Remove and Sample have been wrapped at the ve and le, respectively, even though there is no line break opportunity.

Wrap


This is WrapWithOverflow. The ve and le are not visible (they overflow the available block width) because there is no line break opportunity. The All, in both cases, has been wrapped because the space character is a line break opportunity.

WrapWithOverflow


Edit:

As suggested in the comments, here's some examples of how Wrap treats spaces. When Width is 100, Wrap and WrapWithOverflow are identical. Wrap treats the space between wider and example as a line-break opportunity, so example is put on a new line to preserve the entire, continuous word.

enter image description here

Solution 2 - Wpf

MSDN

> WrapWithOverflow Line-breaking occurs if the line overflows beyond > the available block width. However, a line may overflow beyond the > block width if the line breaking algorithm cannot determine a line > break opportunity, as in the case of a very long word constrained in a > fixed-width container with no scrolling allowed. NoWrap No line > wrapping is performed. Wrap Line-breaking occurs if the line > overflows beyond the available block width, even if the standard line > breaking algorithm cannot determine any line break opportunity, as in > the case of a very long word constrained in a fixed-width container > with no scrolling allowed.

Hope this helps

Solution 3 - Wpf

One thing to add to the other answers, WrapWithOverflow lets you use text trimming (ellipsis) on the long words that get cut off:

enter image description here

<TextBlock TextWrapping="WrapWithOverflow" Width="120" TextTrimming="CharacterEllipsis">
    A really long word is antidisestablishmentarianism and we can use ellipsis trimming.
</TextBlock>

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionDaniele ArmanascoView Question on Stackoverflow
Solution 1 - WpfkenView Answer on Stackoverflow
Solution 2 - WpfArsen MkrtchyanView Answer on Stackoverflow
Solution 3 - WpfVimesView Answer on Stackoverflow