问题描述
我对 TextBox 有一个奇怪的问题,其中 TextTrimming 设置为 CharacterElipsis,在 WPF 应用程序的 DataTemplate 中使用。在应用程序开始时一切正常。但是当我调整窗口大小 - 减小宽度时,修剪不起作用。
在下面的例子中:
<Grid>
<DockPanel>
<DockPanel.Resources>
<DataTemplate x:Key="lowerLevel" >
<Grid>
<Grid.ColumnDeFinitions>
<ColumnDeFinition Width="34*" />
<ColumnDeFinition Width="26*" />
<ColumnDeFinition Width="26*" />
<ColumnDeFinition Width="14*" />
</Grid.ColumnDeFinitions>
<TextBlock Text="textBoxvalue1" Grid.Column="0" FontWeight="Bold" VerticalAlignment="Center" Margin="15,10,10" TextTrimming="CharacterEllipsis" textwrapping="Nowrap" />
<TextBlock Text="textBoxvalue2" Grid.Column="1" FontWeight="Bold" VerticalAlignment="Center" TextTrimming="CharacterEllipsis" textwrapping="Nowrap" />
<TextBlock Text="textBoxvalue3" Grid.Column="2" FontWeight="Bold" VerticalAlignment="Center" Margin="0,10" TextTrimming="CharacterEllipsis" textwrapping="Nowrap" />
<CheckBox IsChecked="True" Content="ApprovedText" FontWeight="Bold" Grid.Column="3" VerticalAlignment="Center" Margin="0,15,10" />
</Grid>
</DataTemplate>
</DockPanel.Resources>
<ListView x:Name="listViewControl" ItemTemplate="{StaticResource lowerLevel}" VerticalAlignment="Stretch" VerticalContentAlignment="Stretch" HorizontalContentAlignment="Stretch" />
</DockPanel>
<Grid>
<Grid.ColumnDeFinitions>
<ColumnDeFinition Width="34*" />
<ColumnDeFinition Width="26*" />
<ColumnDeFinition Width="26*" />
<ColumnDeFinition Width="14*" />
</Grid.ColumnDeFinitions>
<TextBlock Text="textBoxvalue1" Grid.Column="0" FontWeight="Bold" VerticalAlignment="Center" Margin="15,10" TextTrimming="CharacterEllipsis" textwrapping="Nowrap" />
<TextBlock Text="textBoxvalue2" Grid.Column="1" FontWeight="Bold" VerticalAlignment="Center" TextTrimming="CharacterEllipsis" textwrapping="Nowrap" />
<TextBlock Text="textBoxvalue3" Grid.Column="2" FontWeight="Bold" VerticalAlignment="Center" Margin="0,10" TextTrimming="CharacterEllipsis" textwrapping="Nowrap" />
<CheckBox IsChecked="True" Content="ApprovedText" FontWeight="Bold" Grid.Column="3" VerticalAlignment="Center" Margin="0,10" />
</Grid>
</Grid>
我有两个相同的网格,但第一个放置在 DataTemplate 中,第二个只是一个单独的控件。调整窗口大小时,底部网格中的文本框正在正确修剪,但是在调整窗口大小时,DataTemplate 中的文本框不适合父列的宽度。
背后的代码是:
public partial class MainWindow : Window
{
private ListCollectionView comparedFamiliesView;
public ListCollectionView ComparedFamiliesView
{
get
{
if (comparedFamiliesView == null)
{
comparedFamiliesView = new ListCollectionView(new List<Object>() { new Object(),new Object(),new Object() });
}
return comparedFamiliesView;
}
}
public MainWindow()
{
InitializeComponent();
listViewControl.ItemsSource = ComparedFamiliesView;
}
}
它基本上添加了三个对象,以便在 ListView 上查看。
我尝试了 VerticalAlignment、VerticalContentAlignment 的不同组合 - 没有奏效。 我曾尝试将每个 TextBox 放在单独的 Grid 中,以便将其 Width 绑定到 TextBox Width 或 MaxWidth,例如:
<Grid Grid.Column="0" x:Name="grid1">
<TextBlock Text="textBoxvalue1" FontWeight="Bold" VerticalAlignment="Center" Margin="15,10" TextTrimming="CharacterEllipsis" textwrapping="Nowrap" MaxWidth="{Binding ActualWidth,ElementName=grid1}" />
</Grid>
也没有用。
如何强制 DataTemplate 中的 TextBox 与单独的 Grid 中的 TextBox 具有相同的行为? 或者在 DataTemplate 中使用 TextTrimming 时我做错了什么。
感谢您的帮助!!!
问候,
爱丽儿
解决方法
尝试将ScrollViewer.HorizontalScrollBarVisibility
的{{1}}附加属性设置为ListView
:
Disabled