WPF - прокрутка с помощью колеса мыши останавливает DataGrid с пользовательским Expander

Я изменил стиль для Expander, чтобы иметь возможность растягивать содержимое в заголовке группы в DataGrid. Стиль основан на примере шаблона MSDN. Это работает нормально, но когда я прокручиваю колесо мыши, программа зависает. Прокрутка с помощью полосы прокрутки работает отлично! Кто-нибудь может увидеть, что не так?

<ControlTemplate x:Key="ExpanderToggleButton"
             TargetType="{x:Type ToggleButton}">
    <Border x:Name="Border"
      CornerRadius="0"
      BorderThickness="0">
        <VisualStateManager.VisualStateGroups>

            <VisualStateGroup x:Name="CheckStates">
                <VisualState x:Name="Checked">
                    <Storyboard>
                        <ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.Visibility)"
                                       Storyboard.TargetName="CollapsedArrow">
                            <DiscreteObjectKeyFrame KeyTime="0"
                                  Value="{x:Static Visibility.Hidden}" />
                        </ObjectAnimationUsingKeyFrames>
                        <ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.Visibility)"
                                       Storyboard.TargetName="ExpandededArrow">
                            <DiscreteObjectKeyFrame KeyTime="0"
                                  Value="{x:Static Visibility.Visible}" />
                        </ObjectAnimationUsingKeyFrames>
                    </Storyboard>
                </VisualState>
                <VisualState x:Name="Unchecked" />
                <VisualState x:Name="Indeterminate" />
            </VisualStateGroup>
        </VisualStateManager.VisualStateGroups>
        <Grid>
            <Path x:Name="CollapsedArrow"
        HorizontalAlignment="Center"
        VerticalAlignment="Center"
        Data="M 0 0 L 4 4 L 8 0 Z">
                <Path.Fill>
                    <SolidColorBrush Color="{StaticResource ForegroundColor}" />
                </Path.Fill>
            </Path>
            <Path x:Name="ExpandededArrow"
        HorizontalAlignment="Center"
        VerticalAlignment="Center"
        Visibility="Collapsed"
        Data="M 0 4 L 4 0 L 8 4 Z">
                <Path.Fill>
                    <SolidColorBrush Color="{StaticResource ForegroundColor}" />
                </Path.Fill>
            </Path>
        </Grid>
    </Border>
</ControlTemplate>

<Style TargetType="{x:Type Expander}">
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type Expander}">
                <StackPanel>
                    <VisualStateManager.VisualStateGroups>
                        <VisualStateGroup x:Name="CommonStates">
                            <VisualState x:Name="Normal" />
                            <VisualState x:Name="MouseOver" />
                            <VisualState x:Name="Disabled" />
                        </VisualStateGroup>
                    </VisualStateManager.VisualStateGroups>

                    <Border x:Name="Border" Grid.Row="0" BorderThickness="0" CornerRadius="0">
                        <Grid>
                            <Grid.ColumnDefinitions>
                                <ColumnDefinition Width="20" />
                                <ColumnDefinition Width="*" />
                            </Grid.ColumnDefinitions>
                            <ToggleButton OverridesDefaultStyle="True" Template="{StaticResource ExpanderToggleButton}" 
                                        IsChecked="{Binding IsExpanded, Mode=TwoWay, 
                                        RelativeSource={RelativeSource TemplatedParent}}">

                            </ToggleButton>
                            <ContentPresenter  Grid.Column="1" ContentSource="Header" RecognizesAccessKey="True" />
                        </Grid>
                    </Border>
                    <Border x:Name="Content"
                          BorderThickness="0"
                          CornerRadius="0" Visibility="Collapsed">

                        <ContentPresenter />
                    </Border>
                </StackPanel>
                <ControlTemplate.Triggers>
                    <Trigger Property="IsExpanded" Value="True">
                        <Setter TargetName="Content" Property="Visibility" Value="Visible" />
                    </Trigger>
                </ControlTemplate.Triggers>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

В xaml я использую DataGrid с VirtualizingPanel.IsVirtualizingWhenGrouping="True" для производительности.

<DataGrid Margin="10, 5, 10, 10" 
    VirtualizingPanel.IsVirtualizingWhenGrouping="True" >
<DataGrid.GroupStyle>
    <GroupStyle>
        <GroupStyle.HeaderTemplate>
            <DataTemplate>
                <Grid>
                    <Label HorizontalAlignment="Left">Label to the left</Label>
                    <Button HorizontalAlignment="Right">Button to the right</Button>
                </Grid>
            </DataTemplate>
        </GroupStyle.HeaderTemplate>
        <GroupStyle.Panel>
            <ItemsPanelTemplate>
                <DataGridRowsPresenter/>
            </ItemsPanelTemplate>
        </GroupStyle.Panel>
        <GroupStyle.ContainerStyle>
            <Style TargetType="{x:Type GroupItem}">
                <Setter Property="Margin" Value="0,0,0,15"/>
                <Setter Property="HorizontalContentAlignment" Value="Stretch"/>
                <Setter Property="Template">
                    <Setter.Value>
                        <ControlTemplate TargetType="{x:Type GroupItem}">
                            <Expander Background="Transparent" IsExpanded="True" HorizontalAlignment="Stretch" BorderThickness="0" >
                                <Expander.Header>
                                    <ContentPresenter HorizontalAlignment="Stretch" />
                                </Expander.Header>
                                <Expander.Content>
                                    <ItemsPresenter />
                                </Expander.Content>
                            </Expander>
                        </ControlTemplate>
                    </Setter.Value>
                </Setter>
            </Style>
        </GroupStyle.ContainerStyle>
    </GroupStyle>
</DataGrid.GroupStyle>
</DataGrid>

1 ответ

Поздно на это отвечаю, но я наткнулся на этот вопрос, когда искал ответ на похожую проблему с ListBox, который использовал IsVirtualizingWhenGrouping. Вот мое решение.

Моя проблема заключалась в том, что GroupStyle.ContainerStyle имел запас, который изменял размер по вертикали:

<GroupStyle.ContainerStyle>
  <Style TargetType="GroupItem">
    <Setter Property="Margin" Value="0,10,0,0" />
  </Style>
</GroupStyle.ContainerStyle>

Для меня я просто удалил ContainerStyle все вместе и переместил поле в шаблон HeaderTemplate.

Я вижу, что XAML в вопросе также имеет поле в стиле GroupItem, которое изменит его высоту. Возможно, это виновник?

Надеюсь, это поможет следующему человеку.

Другие вопросы по тегам