3

我有一列有很长的用户评论。我使用以下代码加载它...

<my:DataGridTextColumn Header="Message"
                       Binding="{Binding UserMessage, Mode=OneWay}" 
                       CanUserSort="True">
    <my:DataGridTextColumn.ElementStyle>
        <Style TargetType="{x:Type TextBlock}"
               BasedOn="{StaticResource {x:Type TextBlock}}">
               <Setter Property="TextWrapping"
                       Value="NoWrap" />
               <Setter Property="TextTrimming"
                       Value="CharacterEllipsis"/>                                    
               <Setter Property="ToolTip"
                       Value="{Binding Path=UserMessage, Mode=OneWay}"/>
        </Style>
    </my:DataGridTextColumn.ElementStyle>
</my:DataGridTextColumn>

但是省略号不起作用。该列继续显示数据的长文本。此外,当我将文本块的宽度显式设置为某个值时,省略号可以正常工作,但是当我调整列的大小时,它不会在其中显示更多文本。

没有一个starighforward的方式来做到这一点?

谢谢Vinit Sankhe。

4

2 回答 2

5

尝试在只需要静态宽度的列上设置宽度。在此列上,您将宽度设置为“*”

<my:DataGridTextColumn Header="Message"
                       Binding="{Binding UserMessage, Mode=OneWay}" 
                       CanUserSort="True"
                       Width="*">
    <my:DataGridTextColumn.ElementStyle>
        <Style TargetType="{x:Type TextBlock}"
               BasedOn="{StaticResource {x:Type TextBlock}}">
               <Setter Property="TextWrapping"
                       Value="NoWrap" />
               <Setter Property="TextTrimming"
                       Value="CharacterEllipsis"/>                                    
               <Setter Property="ToolTip"
                       Value="{Binding Path=UserMessage, Mode=OneWay}"/>
        </Style>
    </my:DataGridTextColumn.ElementStyle>
</my:DataGridTextColumn>

我通过谷歌搜索你的问题找到了你的问题。我拿了你的代码,只是在我的列中添加了宽度(“标题”列除外),并且能够让它正确放置省略号。我还添加了一个 MinWidth 以确保在调整窗口大小时该列不会被压扁。

于 2012-01-27T14:45:05.127 回答
0

看看这篇文章。它认为这是您正在寻找的解决方案:

于 2010-08-19T06:32:46.147 回答