我有一个窗口,其中包含一个带有可变文本的文本 block 和一个包含可变数量按钮的堆栈面板。 当堆栈面板的宽度增加但让文本始终适应可用宽度时,如何让窗口的宽度(水平)增加(当文本变长时不增加窗口的宽度)。
我已经尝试了一些有和没有 Width="Auto"/VerticalAlign="Stretch"/TextWrapping 等的组合,但只有当其中一个(文本长度/堆栈面板子项)的宽度增加时,我才会让窗口增加。
我希望文本根据窗口的宽度换行,窗口宽度应基于堆栈面板的宽度。只有 XAML 会更好。
编辑
根据要求使用一些精简标记来重现问题:
<Window
Width="500"
Height="225"
MinWidth="500"
MinHeight="225"
HorizontalAlignment="Stretch"
SizeToContent="WidthAndHeight"
ResizeMode="NoResize">
<Grid HorizontalAlignment="Stretch" Width="Auto">
<Grid.RowDefinitions>
<RowDefinition Height="*"/>
<RowDefinition Height="35"/>
</Grid.RowDefinitions>
<!-- Text should adapt to the available width but not grow the window. Instead it should scroll vertically -->
<ScrollViewer Grid.Row="0" Margin="15" VerticalScrollBarVisibility="Auto">
<TextBlock TextWrapping="Wrap" Height="Auto">...Some Binding...</TextBlock>
</ScrollViewer>
<!-- Should be as wide as it needs to be, growing the window in width if neccessary -->
<StackPanel x:Name="ButtonStackPanel" Grid.Row="1" FlowDirection="RightToLeft" Orientation="Horizontal" Width="Auto">
...Some Buttons...
</StackPanel>
</Grid>
</Window>
编辑 2 窗口的 MinWidth 应为 500,如果堆栈面板中只有一个按钮,它仍应拉伸(stretch)整个宽度 (500px)。
编辑 3 - 更多图片
正确 - 文本很短,只有一个按钮 -> MinWidth 500 错误 - 文本很长并且应该在 MinWidth 500 处换行,因为应该只允许 Stackpanel 增加窗口的宽度 正确 - 文本较短但堆栈面板会增大窗口
最佳答案
您必须将 Window
的 Width
绑定(bind)到外部 Grid
的 Width
(如 Mighty Badaboom 建议)和 ScrollViewer
的 Width
到 StackPanel
的 ActualWidth
。
实现方法如下:
<Window SizeChanged="MainWindow_OnSizeChanged" Height="225" SizeToContent="Width" ResizeMode="NoResize">
<Grid Name="OuterGrid" MinWidth="500">
<Grid.RowDefinitions>
<RowDefinition Height="*"/>
<RowDefinition Height="35"/>
</Grid.RowDefinitions>
<ScrollViewer Grid.Row="0" Margin="15" VerticalScrollBarVisibility="Auto">
<TextBlock TextWrapping="Wrap" Height="Auto">...Some Binding...</TextBlock>
</ScrollViewer>
<StackPanel Grid.Row="1" HorizontalAlignment="Stretch" Background="Blue">
<StackPanel x:Name="ButtonStackPanel" HorizontalAlignment="Center" Grid.Row="1" FlowDirection="RightToLeft" Orientation="Horizontal" Width="Auto">
...Some Buttons...
</StackPanel>
</StackPanel>
</Grid>
</Window>
后面的代码:
private void MainWindow_OnSizeChanged(object sender, SizeChangedEventArgs e)
{
if (e.WidthChanged)
OuterGrid.Width = Panel.ActualWidth;
}
编辑:添加了一个外部 StackPanel
以支持拉伸(stretch)和蓝色背景要求。
编辑 2:您似乎无法仅使用 XAML 来实现您所描述的行为。尽管只需几行代码即可完成修复。
关于c# - 让窗口根据一个控件的大小而不是另一个控件的大小增长,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44844780/