如何从滚动修复datagrid groupheader

时间:2011-01-08 07:25:26

标签: wpf datagrid styles wpfdatagrid wpftoolkit

您好我想要水平对齐我的组标题。我已成功完成此操作但现在问题是如果我水平滚动我的组标题也是滚动。如何修复此问题。我想要修复我的组标题并且只有我要滚动的内容

我的代码如下。

的Xaml

<Window.Resources>
    <local:Animals x:Key="animals"/>       

    <CollectionViewSource x:Key="cvs" Source="{Binding Source={StaticResource animals}, Path=AnimalList}">
        <CollectionViewSource.SortDescriptions>
            <scm:SortDescription PropertyName="Category" />
            <scm:SortDescription PropertyName="Name" />
        </CollectionViewSource.SortDescriptions>
        <CollectionViewSource.GroupDescriptions>
            <PropertyGroupDescription PropertyName="Category"/>
        </CollectionViewSource.GroupDescriptions>
    </CollectionViewSource>

    <DataTemplate x:Key="animalTemplate">
        <TextBlock Text="{Binding Path=Name}" Foreground="MediumSeaGreen"/>
    </DataTemplate>
    <Style TargetType="{x:Type HeaderedContentControl}">
        <Setter Property="Control.Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type HeaderedContentControl}">
                    <Grid>
                        <Grid.RowDefinitions>
                            <RowDefinition Height="*"/>
                            <RowDefinition Height="Auto"/>
                        </Grid.RowDefinitions>
                        <StackPanel Orientation="Horizontal">
                            <ContentPresenter
                            Content="{TemplateBinding HeaderedContentControl.Header}"
                            ContentTemplate="{TemplateBinding HeaderedContentControl.HeaderTemplate}"
                            ContentSource="Header" VerticalAlignment="Center">
                            </ContentPresenter>
                            <ContentPresenter                             
                            Content="{TemplateBinding ContentControl.Content}"
                            ContentTemplate="{TemplateBinding ContentControl.ContentTemplate}" />
                        </StackPanel>

                        <Separator HorizontalAlignment="Stretch" Grid.Row="1" Margin="-1"/>
                    </Grid>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>
</Window.Resources>

<Border Margin="30" BorderBrush="Blue" BorderThickness="2" Padding="10">
    <Controls:DataGrid ItemsSource="{Binding Source={StaticResource cvs}}" 
       ItemTemplate="{StaticResource animalTemplate}" Name="ic" Width="200" >

        <Controls:DataGrid.GroupStyle>
            <GroupStyle>
                <GroupStyle.ContainerStyle>
                    <Style TargetType="{x:Type GroupItem}">
                        <Setter Property="Margin" Value="0,0,0,5"/>
                        <Setter Property="Template">
                            <Setter.Value>
                                <ControlTemplate TargetType="{x:Type GroupItem}">
                                    <HeaderedContentControl BorderBrush="#FFA4B97F" BorderThickness="0,0,0,1" Margin="0,0,0,5" >
                                        <HeaderedContentControl.Header>
                                            <TextBlock FontSize="12" FontWeight="Bold" Width="100"
                                                                Text="{Binding Name}" Margin="5,0,0,0"/>
                                        </HeaderedContentControl.Header>
                                        <HeaderedContentControl.Content>
                                            <ItemsPresenter/>
                                        </HeaderedContentControl.Content>
                                    </HeaderedContentControl>
                                </ControlTemplate>
                            </Setter.Value>
                        </Setter>
                    </Style>
                </GroupStyle.ContainerStyle>
            </GroupStyle>
        </Controls:DataGrid.GroupStyle>
    </Controls:DataGrid>
</Border>

代码

  public class Animal
{
    private string name;

    public string Name
    {
        get { return name; }
        set { name = value; }
    }

    private Category category;

    public Category Category
    {
        get { return category; }
        set { category = value; }
    }

    public Animal(string name, Category category)
    {
        this.name = name;
        this.category = category;
    }
}

public enum Category
{
    Amphibians,
    Bears,
    BigCats,
    Canines,
    Primates,
    Spiders,
}

public class Animals
{
    private List<Animal> animalList;

    public IEnumerable<Animal> AnimalList
    {
        get { return animalList; }
    }

    public Animals()
    {
        animalList = new List<Animal>();
        animalList.Add(new Animal("California Newt", Category.Amphibians));
        animalList.Add(new Animal("Giant Panda", Category.Bears));
        animalList.Add(new Animal("Coyote", Category.Canines));
        animalList.Add(new Animal("Golden Silk Spider", Category.Spiders));
        animalList.Add(new Animal("Mandrill", Category.Primates));
        animalList.Add(new Animal("Black Bear", Category.Bears));
        animalList.Add(new Animal("Jaguar", Category.BigCats));
        animalList.Add(new Animal("Bornean Gibbon", Category.Primates));
        animalList.Add(new Animal("African Wildcat", Category.BigCats));
        animalList.Add(new Animal("Arctic Fox", Category.Canines));
        animalList.Add(new Animal("Tomato Frog", Category.Amphibians));
        animalList.Add(new Animal("Grizzly Bear", Category.Bears));
        animalList.Add(new Animal("Dingo", Category.Canines));
        animalList.Add(new Animal("Gorilla", Category.Primates));
        animalList.Add(new Animal("Green Tree Frog", Category.Amphibians));
        animalList.Add(new Animal("Bald Uakari", Category.Primates));
        animalList.Add(new Animal("Polar Bear", Category.Bears));
        animalList.Add(new Animal("Black Widow Spider", Category.Spiders));
        animalList.Add(new Animal("Bat-Eared Fox", Category.Canines));
        animalList.Add(new Animal("Cheetah", Category.BigCats));
        animalList.Add(new Animal("Cheetah", Category.Spiders));
    }
}

请帮助这方面..

2 个答案:

答案 0 :(得分:1)

将ScrollViewer放在DataGrid周围 我还从DataGrid中删除了Width。

<Border Margin="30" BorderBrush="Blue" BorderThickness="2" Padding="10">
 <ScrollViewer HorizontalScrollBarVisibility="Auto" 
               VerticalScrollBarVisibility="Auto">
     <DataGrid ItemsSource="{Binding Source={StaticResource cvs}}"         
               ItemTemplate="{StaticResource animalTemplate}" 
               Name="ic" >
     </DataGrid>
   </ScrollViewer>
</Border>

答案 1 :(得分:1)

我已经提出了一个解决方案,正是我正在寻找的东西。尽管Zamboni的解决方案帮助我解决了我的问题,但我正在寻找更好的解决方案。我们讨论了here,但我正在为感兴趣的人分享代码。

<Window.Resources>
    <local:Animals x:Key="animals"/>

    <CollectionViewSource x:Key="cvs" Source="{Binding AnimalList, Source={StaticResource animals}}">
      <CollectionViewSource.SortDescriptions>
        <scm:SortDescription PropertyName="Category" />
        <scm:SortDescription PropertyName="Name" />
      </CollectionViewSource.SortDescriptions>
      <CollectionViewSource.GroupDescriptions>
        <PropertyGroupDescription PropertyName="Category"/>
      </CollectionViewSource.GroupDescriptions>
    </CollectionViewSource>

    <DataTemplate x:Key="animalTemplate">
      <TextBlock Text="{Binding Name}" Foreground="MediumSeaGreen"/>
    </DataTemplate>

  </Window.Resources>
  <Grid>
    <Controls:DataGrid ItemsSource="{Binding Source={StaticResource cvs}}"             
    ItemTemplate="{StaticResource animalTemplate}" x:Name="ic">
      <Controls:DataGrid.GroupStyle>
        <GroupStyle>
          <GroupStyle.ContainerStyle>
            <Style TargetType="{x:Type GroupItem}">
              <Setter Property="Margin" Value="0,0,0,5"/>
              <Setter Property="Template">
                <Setter.Value>
                  <ControlTemplate TargetType="{x:Type GroupItem}">
                    <Grid>
                      <Grid.RowDefinitions>
                        <RowDefinition Height="*"/>
                        <RowDefinition Height="Auto"/>
                      </Grid.RowDefinitions>
                      <local:DynamicCanvas HorizontalAlignment="Stretch" Height="{Binding ElementName=items, Path=ActualHeight}" x:Name="myCanvas">
                        <ItemsPresenter x:Name="items" Canvas.Left="{Binding ElementName=frezenBorder, Path=ActualWidth}"/>
                        <Grid Background="White" Height="{Binding ElementName=items, Path=ActualHeight}" VerticalAlignment="Stretch" x:Name="frezenBorder"
                           Canvas.Left="{Binding HorizontalOffset, Mode=OneWay, RelativeSource={RelativeSource Mode=FindAncestor,AncestorType={x:Type ScrollViewer}}}">
                          <TextBlock VerticalAlignment="Stretch" MinWidth="100" FontSize="12" FontWeight="Bold" Width="100"
                                Text="{Binding Name}" Margin="5,0,0,0"/>
                        </Grid>
                      </local:DynamicCanvas>
                      <Separator HorizontalAlignment="Stretch" Grid.Row="1" Margin="-1"/>
                    </Grid>
                  </ControlTemplate>
                </Setter.Value>
              </Setter>
            </Style>
          </GroupStyle.ContainerStyle>
        </GroupStyle>
      </Controls:DataGrid.GroupStyle>
    </Controls:DataGrid>
  </Grid>