WPF - 从组头样式中绑定到当前项

时间:2010-01-27 14:42:14

标签: wpf xaml datagrid binding grouping

我是一个WPF菜鸟,所以请放轻松一下; - )

我正在尝试创建一个分组的DataGrid(WPF工具包版本)。 我已经成功创建了数据源,DataGrid本身,所需的CollectionViewSource和组头的样式(使用扩展器)。

我希望按名为“Assign_To”的属性进行分组,并在标题中显示相关值(分组项共享的值)。但是,我无法弄清楚如何绑定到当前组/项以返回其Assign_To属性。

我得到的最接近的(如下所示)绑定到整个CollectionViewSource,它返回Assign_To的固定值。绑定到当前项目/组的正确方法是什么,以便为“Assign_To”返回正确的值?

希望有人可以提供帮助。谢谢!

Andy T。

这是来源......

<Window DataContext="{Binding Source={StaticResource SampleDataSource}}"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:dg="http://schemas.microsoft.com/wpf/2008/toolkit"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    x:Class="DataGridTest.MainWindow"
    x:Name="Window"
    Title="MainWindow"
    Width="640" Height="480" mc:Ignorable="d">

    <Window.Resources>
        <CollectionViewSource x:Key="CVS" Source="{Binding MyData}">
            <CollectionViewSource.GroupDescriptions>
                <PropertyGroupDescription PropertyName="Assign_To"/>
            </CollectionViewSource.GroupDescriptions>
        </CollectionViewSource>

        <Style x:Key="GroupHeaderStyle" TargetType="{x:Type GroupItem}">
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="{x:Type GroupItem}">
                        <Expander IsExpanded="True">
                            <Expander.Header>
                                <StackPanel Orientation="Horizontal">
                                    <TextBlock Text="Assign To: "/>
                                    <TextBlock Text="{Binding Source={StaticResource CVS}, Path=Assign_To}"/>
                                </StackPanel>                               
                            </Expander.Header>
                            <ItemsPresenter/>
                        </Expander>
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>

    </Window.Resources>


    <Grid x:Name="LayoutRoot">
        <dg:DataGrid
         ItemsSource="{Binding Source={StaticResource CVS}}"
         SelectionUnit="CellOrRowHeader" 
         CanUserAddRows="False" 
         CanUserDeleteRows="False" 
         CanUserResizeRows="False">
         <dg:DataGrid.GroupStyle>
            <GroupStyle ContainerStyle="{StaticResource GroupHeaderStyle}">
                <GroupStyle.Panel>
                    <ItemsPanelTemplate>
                        <dg:DataGridRowsPresenter/>
                    </ItemsPanelTemplate>
                </GroupStyle.Panel>
            </GroupStyle>
         </dg:DataGrid.GroupStyle>          
        </dg:DataGrid>   
    </Grid> 
</Window>

2 个答案:

答案 0 :(得分:19)

感谢您的回复。我真的很感激,并会检查它是否有效。

无论如何,事实证明,经过一些戳戳和刺激,我只使用XAML进行了解决。我遗漏的是,组头绑定的每个项目都是 GroupItem ,而 GroupItem 的默认DataContext是 CollectionViewGroup 。反过来, CollectionViewGroup 有一个 Items 属性,这是一个集合,因此我可以获得集合中第一个项目的 Assign_To 值并在我的标题文本中使用它。像这样:

<Style x:Key="GroupHeaderStyle" TargetType="{x:Type GroupItem}">
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="{x:Type GroupItem}">
                        <Expander IsExpanded="True">
                            <Expander.Header>
                                <StackPanel Orientation="Horizontal">
                                    <TextBlock Text="Assign To: "/>
                                    <TextBlock Text="{Binding Items[0].Assign_To}"/>
                                </StackPanel>       
                            </Expander.Header>
                            <ItemsPresenter/>
                        </Expander>
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>

答案 1 :(得分:6)

绑定设置取决于Assign_To属性的类型。可能对您有用的最简单的设置是:

<TextBlock Text="Assign To: "/>
<TextBlock Text="{Binding Name}"/>

请检查以下示例是否对您有用;此链接WPF Toolkit DataGrid Part IV: TemplateColumns and Row Grouping也可能对您有所帮助

代码:

public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();

        var dataProvider = (CollectionViewSource)FindResource("CVS");
        dataProvider.Source = Test.GetTests();
    }
}

public class Test
{
    public string   Assign_To { get; set; }
    public string   Test0 { get; set; }
    public int      Test1 { get; set; }

    public static List<Test> GetTests()
    {
        List<Test> tests = new List<Test>();

        tests.Add(new Test { Assign_To = "a", Test0 = "aaaa", Test1 = 1 });
        tests.Add(new Test { Assign_To = "a", Test0 = "bbbb", Test1 = 1 });
        tests.Add(new Test { Assign_To = "b", Test0 = "cccc", Test1 = 2 });

        return tests;
    }
}

XAML:

<Window.Resources>    
    <CollectionViewSource x:Key="CVS" >
        <CollectionViewSource.GroupDescriptions>
            <PropertyGroupDescription PropertyName="Assign_To"/>
        </CollectionViewSource.GroupDescriptions>
    </CollectionViewSource>

    <Style x:Key="GroupHeaderStyle" TargetType="{x:Type GroupItem}">
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type GroupItem}">
                    <Expander IsExpanded="True">
                        <Expander.Header>
                            <StackPanel Orientation="Horizontal">
                                <TextBlock Text="Assign To: "/>
                                <TextBlock Text="{Binding Name}"/>
                            </StackPanel>
                        </Expander.Header>
                        <ItemsPresenter />
                    </Expander>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>    
</Window.Resources>

<Grid>        
    <DataGrid 
        ItemsSource="{Binding Source={StaticResource CVS}}"            
        HorizontalScrollBarVisibility="Hidden" SelectionMode="Extended"
        AutoGenerateColumns="False"  
        Name="dataGrid1">    
        <DataGrid.GroupStyle>
            <GroupStyle ContainerStyle="{StaticResource GroupHeaderStyle}">
                <GroupStyle.Panel>
                    <ItemsPanelTemplate>
                        <DataGridRowsPresenter/>
                    </ItemsPanelTemplate>
                </GroupStyle.Panel>
            </GroupStyle>
        </DataGrid.GroupStyle>    
        <DataGrid.Columns>
            <DataGridTextColumn Header="Test0" Binding="{Binding Path=Test0}" />
            <DataGridTextColumn Header="Test1" Binding="{Binding Path=Test1}" />
        </DataGrid.Columns>
    </DataGrid>
</Grid>