gpt4 book ai didi

c# - 如何获取用星号定义的 WPF 网格列来剪辑内容?

转载 作者:太空狗 更新时间:2023-10-29 21:27:34 28 4
gpt4 key购买 nike

我有一个 Grid 控件,它使用星号来成比例,例如

<Grid.ColumnDefinitions>
<ColumnDefinition Width="50*" />
<ColumnDefinition Width="100*" />
<ColumnDefinition Width="50*" />
</Grid.ColumnDefinitions>

然而,在溢出的网格中放置一个长的 TextBlock 会导致比例被打乱。例如

<TextBlock Text="Foo" Grid.Column="0" />
<TextBlock Text="Some long text here which overflows" Grid.Column="1" />
<TextBlock Text="Foo" Grid.Column="2" />

这导致中心列比其他两个多一倍以上。如何保持指定的比例?是否可以剪辑内容?

我已经在 TextBlocks 上设置了 TextTrimming="CharacterEllipsis" 但没有成功。

编辑

看起来很重要,网格在 DataTemplate 中,粘贴以下内容以观察行为,

<!-- FallbackValue is just a quick hack to get some rows to show at design-time -->
<ListBox ItemsSource="{Binding Foo, FallbackValue=1234}"
HorizontalContentAlignment="Stretch">
<ListBox.ItemTemplate>
<DataTemplate>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="50*" />
<ColumnDefinition Width="100*" />
<ColumnDefinition Width="50*" />
</Grid.ColumnDefinitions>
<TextBlock Text="Foo" Grid.Column="0" />
<TextBlock Text="Some long text here which overflows" TextTrimming="CharacterEllipsis" Grid.Column="1" />
<TextBlock Text="Foo" Grid.Column="2" />
</Grid>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>

这很重要的原因是我有另一个 Grid 作为 ListBox 的兄弟,它显示 中显示的列的“标题” ListBox如下,

<Grid>
... Headers and column definitions here
</Grid>

<ListBox ...>
<ListBox.ItemTemplate>
<DataTemplate>
<Grid>
... Matching column definitions here
</Grid>
</DateTemplate>
</ListBox.ItemTemplate>
</ListBox>

所以列匹配很重要。

我试图将 DataTemplate 中的 ColumnDefinitions 绑定(bind)到外部 Grid ColumnDefinitions 但我无法获取很容易成为对它的绑定(bind)引用。

最佳答案

这是 WPF 最烦人的问题之一。由于提供给模板化网格的可用空间是无限的,因此实际内容将占用任意多的空间。

最简单的方法是为 Grid 固定一定的宽度,但这只能解决没有调整大小的情况。

虽然您想拉伸(stretch) ListBox 的大小(具体来说是宽度),但不幸的是,我猜想除了自定义转换器之外没有更好的解决方案。

这是我的解决方案:

<Window.Resources>
<local:MyConv x:Key="cv1" />
</Window.Resources>
<Grid>
<ListBox
ItemsSource="{Binding Foo, FallbackValue=1234}"
HorizontalContentAlignment="Stretch"
>
<ListBox.ItemTemplate>
<DataTemplate>
<Grid Width="{Binding Path=ActualWidth, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=ListBox}, Converter={StaticResource cv1}}">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="50*" />
<ColumnDefinition Width="100*" />
<ColumnDefinition Width="50*" />
</Grid.ColumnDefinitions>
<TextBlock Text="Foo" Grid.Column="0" />
<TextBlock Text="Some long text here which overflows" TextTrimming="CharacterEllipsis" Grid.Column="1" />
<TextBlock Text="Foo" Grid.Column="2" />
</Grid>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
</Grid>

和转换器:

class MyConv : IValueConverter
{
public object Convert(
object value,
Type targetType,
object parameter,
System.Globalization.CultureInfo culture
)
{
return (double)value - 30.0;
}

public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
throw new NotImplementedException();
}
}

关于c# - 如何获取用星号定义的 WPF 网格列来剪辑内容?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25567474/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com