在下面的WPF网格中,中间列不是6.文本B一直向右而不是远离文本A 6.我已尝试*而不是自动用于其他列,但结果是相同的
如何制作中间列6?有解决方法吗?为什么会这样?是预期的行为还是错误?
我以这种方式制作我的网格,这样我就不必为每个元素设置边距。
<ScrollViewer HorizontalScrollBarVisibility="Auto">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="6" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="Auto" />
<RowDefinition Height="6" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
<TextBlock Grid.ColumnSpan="3" Grid.Column="0" HorizontalAlignment="Left">xxxxxxxxxxxxxxxxxxxxxxxxxxxx</TextBlock>
<TextBlock Grid.Row="2">Text A</TextBlock>
<Rectangle Fill="YellowGreen" Grid.Column="1" Grid.Row="2" HorizontalAlignment="Stretch" />
<TextBlock Grid.Row="2" Grid.Column="2" Background="LightCoral">Text B</TextBlock>
</Grid>
</ScrollViewer>
注意:我的窗口宽度为自动。
编辑: 使用@flq's solution但添加了水平滚动的滚动查看器,问题又回来了。这可能与解决方案在设计器中没有正确显示的原因相同,这与WPF无法知道如何在没有约束宽度的情况下计算宽度有关。
答案 0 :(得分:2)
我无法确认将第三列设置为*不起作用。使用以下XAML:
<Grid HorizontalAlignment="Left">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="6" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="Auto" />
<RowDefinition Height="6" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
<TextBlock Grid.ColumnSpan="3" Grid.Column="0" HorizontalAlignment="Left">xxxxxxxxxxxxxxxxxxxxxxxxxxxx</TextBlock>
<TextBlock Grid.Row="2">Text A</TextBlock>
<Rectangle Fill="YellowGreen" Grid.Column="1" Grid.Row="2" HorizontalAlignment="Stretch" />
<TextBlock Grid.Row="2" Grid.Column="2" Background="LightCoral">Text B</TextBlock>
</Grid>
我明白了:
答案 1 :(得分:1)
我认为你想在其他非固定长度的列上使用“*”
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="6" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
答案 2 :(得分:0)
如何制作中间列6?有解决方法吗?
通过在MaxWidth
内设置ScrollViewer
来解决(我使用了最大的双倍值)。
为什么会这样?是预期的行为还是错误?
在ScrollViewer(或设计器)中,没有最大宽度。在布局计算中的某处,它将列宽指定为6 + *。
我认为最终这是一个错误,因为可以在不需要最大宽度的情况下计算列宽(它被指定为固定值,甚至不需要计算)。
<ScrollViewer HorizontalScrollBarVisibility="Auto">
<Grid MaxWidth="1.79769E308">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="6" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="Auto" />
<RowDefinition Height="6" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
<TextBlock Grid.ColumnSpan="4">xxxxxxxxxxxxxxxxxxxxxxxxxxxx</TextBlock>
<TextBlock Grid.Row="2">Text A</TextBlock>
<Rectangle Fill="YellowGreen" Grid.Column="1" Grid.Row="2" />
<TextBlock Grid.Row="2" Grid.Column="2" Background="LightCoral">Text B</TextBlock>
</Grid>
</ScrollViewer>