3

我有一个网格,其中一个列宽定义为*. 其他列定义为Auto*具有-definition的列包含从 Panel 派生的用户控件,该控件也实现了IScrollInfo. 在此控件的MeasureOverride可见性设置为RepeatButton在另一列中RepeatButton可见(否则将可见性设置为折叠)。

这不会导致列扩展。这只会在我调整窗口大小时发生。一个简化的例子:

<DockPanel LastChildFill="True">
    <Grid DockPanel.Dock="Left">
        <Grid.ColumnDefinitions>
            <ColumnDefinition x:Name="TabItemColumn"/>
            <ColumnDefinition x:Name="ScrollRightColumn" Width="Auto"/>
        </Grid.ColumnDefinitions>
        <ScrollViewer x:Name="PART_ScrollViewer" 
                Grid.Column="0" 
                Margin="-1,0,0,0" 
                Height="32" 
                CanContentScroll="True" 
                VerticalScrollBarVisibility="Hidden" 
                HorizontalScrollBarVisibility="Hidden" 
                HorizontalAlignment="Left">
            <local:TabPanel 
                    x:Name="tabPanel" 
                    HorizontalAlignment="Left" 
                    IsItemsHost="True" />
        </ScrollViewer>

        <RepeatButton Style="{StaticResource RepeatButtonScrollRight}"
            Visibility="{Binding ElementName=tabPanel, Path=CanScrollRight, Converter={StaticResource _localBooleanConverter}}"
            Grid.Column="1">
        </RepeatButton>

的可见性RepeatButton被正确触发,据我所知,它实际上是渲染的,但ActualWidth包含列的 是零,直到调整大小。

有任何想法吗?

4

2 回答 2

0

InvalidateArrange是一个很好的答案,但不幸的是,在实际安排控件的过程中,它会被默默地忽略。所以诀窍是在安排完成后调用它。

这可能有效(我没有尝试过):

Dispatcher.BeginInvoke(DispatcherPriority.Normal, new Action(() =>
{
  grid.InvalidateArrange();
}));

如果这不起作用,您可以尝试在重复按钮上调用 InvalidateArrange 和/或 InvalidateMeasure,也在 Dispatcher.BeginInvoke 回调中。

于 2010-03-03T18:23:17.263 回答
0

您需要在更改列宽后触发布局更改。在正确的父元素上使用InvalidateArrange() 。注意避免无限循环。

于 2010-01-25T10:25:50.440 回答