如何使用GridSplitter检索WPF网格中的列宽?

时间:2011-12-13 20:39:55

标签: wpf caliburn.micro gridsplitter

我需要向用户显示两个列表框 - 窗口两侧各一个 - 并允许用户选择每个列表空间的显示空间。我用以下代码实现了这么多:

<Grid VerticalAlignment="Stretch" HorizontalAlignment="Stretch">
    <Grid.ColumnDefinitions>
        <ColumnDefinition Width="{Binding FirstColumnWidth}" />
        <ColumnDefinition Width="Auto" />
        <ColumnDefinition Width="*" />
    </Grid.ColumnDefinitions>
    <Grid.RowDefinitions>
        <RowDefinition Height="*" />
    </Grid.RowDefinitions>
    <ListBox Name="FirstColumn" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Grid.Row="0" Grid.Column="0" />
    <GridSplitter Name="gridSplitter1" Width="3" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Grid.Row="0" Grid.Column="1" />
    <ListBox Name="SecondColumn" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Grid.Row="0" Grid.Column="2" />
</Grid>

然而,虽然绑定将检索第一列的初始宽度并相应地调整它们的大小,但使用GridSplitter调整它们的大小只是用新值替换绑定。如何检索新值以便我可以保留它?

理想情况下,解决方案需要与MVVM很好地协作 - 我正在使用Caliburn并尽可能保持代码尽可能干净(我的视图模型包含当前绑定的FirstColumnWidth属性)。

1 个答案:

答案 0 :(得分:0)

我能想到两种解决方案。

1。使用不同的binding modes可用内容以及WidthActualWidth属性。

示例

<Grid VerticalAlignment="Stretch" HorizontalAlignment="Stretch">
    <Grid.ColumnDefinitions>
        <ColumnDefinition Width="{Binding Path=FirstColumnWidth, Mode=OneTime}" />
        <ColumnDefinition Width="3" />
        <ColumnDefinition Width="{Binding Path=SecondColumnWidth, Mode=OneTime}" />
    </Grid.ColumnDefinitions>
    <Grid.RowDefinitions>
        <RowDefinition Height="*" />
    </Grid.RowDefinitions>
    <Grid Grid.Column="0" ActualWidth="{Binding Path=FirstColumnWidth, Mode=OneWayToSource}">
        <ListBox HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/>
    </Grid>
    <GridSplitter Grid.Column="1" Width="3" HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/>
    <Grid Grid.Column="2" ActualWidth="{Binding Path=SecondColumnWidth, Mode=OneWayToSource}">
        <ListBox HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/>
    </Grid>
</Grid>

2. 使用附加的行为模式(tutorial on CodeProject)覆盖网格拆分器的当前/默认行为。当我在办公桌前时,我将在明天发布代码示例。