你能建议一个在wpf中在水平和垂直分割之间切换的好方法吗?我的界面中有两个区域。希望它们被可拖动的分隔符划分,并有一个按钮在水平和垂直分割之间切换。我尝试用AvalonDock做到这一点,但由于某些原因,它没有用。这是我的问题,没有人回答。 prev. question
也许是另一个库,或者使用标准GridSplitter的简单方法?
答案 0 :(得分:1)
我遇到了类似的问题。这是我解决它的方式,感谢一些好主意here:
WHERE
item_id = @ item
BoolConverter是IValueConverter。而背后的代码:
<ContentControl>
<ContentControl.Resources>
<BoolConverter x:Key="BoolToLayoutConverter" TrueValue="templateHorizontal" FalseValue="templateVertical"/>
<BoolConverter x:Key="BoolToLayoutCharacterConverter" TrueValue="—" FalseValue="|"/>
<DataTemplate x:Key="mainTable">
<StackPanel>
<Label Content="MainTable goes here"/>
<ToggleButton Content="{Binding LayoutHorizontal, Converter={StaticResource BoolToLayoutCharacterConverter}}"
IsChecked="{Binding LayoutHorizontal}"/>
</StackPanel>
</DataTemplate>
<DataTemplate x:Key="childTables">
<Label Content="ChildTables go here"/>
</DataTemplate>
</ContentControl.Resources>
<ContentControl.Style>
<Style TargetType="ContentControl">
<Style.Triggers>
<DataTrigger Binding="{Binding LayoutHorizontal}" Value="False">
<Setter Property="ContentTemplate">
<Setter.Value>
<DataTemplate>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition/>
<ColumnDefinition Width="10"/>
<ColumnDefinition/>
</Grid.ColumnDefinitions>
<ContentPresenter Grid.Column="0" ContentTemplate="{StaticResource mainTable}"/>
<GridSplitter Grid.Column="1" HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/>
<ContentPresenter Grid.Column="2" ContentTemplate="{StaticResource childTables}"/>
</Grid>
</DataTemplate>
</Setter.Value>
</Setter>
</DataTrigger>
<DataTrigger Binding="{Binding LayoutHorizontal}" Value="True">
<Setter Property="ContentTemplate">
<Setter.Value>
<DataTemplate>
<Grid>
<Grid.RowDefinitions>
<RowDefinition/>
<RowDefinition Height="5"/>
<RowDefinition/>
</Grid.RowDefinitions>
<ContentPresenter Grid.Row="0" ContentTemplate="{StaticResource mainTable}"/>
<GridSplitter Grid.Row="1" Height="10" VerticalAlignment="Stretch" HorizontalAlignment="Stretch"/>
<ContentPresenter Grid.Row="2" ContentTemplate="{StaticResource childTables}"/>
</Grid>
</DataTemplate>
</Setter.Value>
</Setter>
</DataTrigger>
</Style.Triggers>
</Style>
</ContentControl.Style>
</ContentControl>
答案 1 :(得分:0)
我不知道在运行时重新定义网格的行和列的任何合理干净的方法。您需要一些代码来重新定义RowDefinitions和ColumnDefinitions,以及可能更新网格子节点的Grid.Row和Grid.Column附加属性。我不确定网格如何响应这种重新配置。您可能需要手动使某些内容无效。我怀疑你试图使用的库没有实现重新配置网格所需的所有步骤,或者他们尝试过并发现它不起作用。
但是,将一个预先配置的网格换成另一个网格应该相对简单。将两个网格放在同一个位置,并将当前未使用的网格的可见性设置为折叠。