如何在wpf c#中编程隐藏DataGrid的单元格?

时间:2016-09-18 21:47:59

标签: c# wpf xaml datatable datagrid

是否有任何方法可以在代码隐藏中隐藏/折叠特定的dataGrid单元格?由于我的数据表列是在运行时创建的,因此我无法指定属性(在XAML中)来正确设置这些数据触发器,模板选择器等。 但是,我能够通过循环遍历数据表来找到我想要折叠的确切单元格,以将行/列索引添加到List(下面)。

我知道这是非正统的,但我已经读了好几个星期试图解决这个问题并没有让我在那里。这似乎是最简单的解决方案(如果可能的话)。

private static List<KeyValuePair<int, int>> GetCellsToHide(DataTable pivotTable)
{
    var noCellValueList = new List<KeyValuePair<int, int>>();
    foreach (DataRow row in pivotTable.Rows)
    {
        foreach (DataColumn col in pivotTable.Columns)
        {
            if (row[col].ToString() == "HideMe")
            {
                int rowIndex = pivotTable.Rows.IndexOf(row);
                int colIndex = pivotTable.Columns.IndexOf(col);

                noCellValueList.Add(new KeyValuePair<int, int>(rowIndex, colIndex));

            }
        }
    }

    return noCellValueList;
}

编辑:datatemplate&amp;转换器信息

我目前正在通过autogeneratingcolumns构建数据网格。我知道所有其他列的名称,所以我可以缩小到动态生成的列。我的动态列是DataTemplate5,例如(下面简化版):

private void DataGrid_AutoGeneratingColumn(object sender, DataGridAutoGeneratingColumnEventArgs e)
{
    if (e.Column.Header.ToString() == "Name")
        e.Column.Header = "File Name";

    else
    {
        string origHeader = e.Column.Header.ToString();

        DataGridTemplateColumn templateColumn = new DataGridTemplateColumn    //create new template column
        {
             Header = origHeader,
             CellTemplate = (DataTemplate)Resources["DataTemplate5"]

        }; 

        e.Column = templateColumn; // Replace the auto-generated column with the templateColumn.    
    }
}

但由于我没有要绑定的属性(列)名称,因此我无法正确绑定它。这是我最近通过datatemplate&amp; amp;隐藏细胞的尝试。的IValueConverter:

<DataTemplate x:Key="DataTemplate5">
    <DataTemplate.Resources>
        <local:StringToVisibilityConvertor x:Key="VisibilityConvertor" />
    </DataTemplate.Resources>
    <StackPanel Visibility="{Binding BindsDirectlyToSource=True, Converter={StaticResource VisibilityConvertor}}">
        <Button Name="Button1" Click="ButtonClick">
            <Button.Style>
                <Style  TargetType="Button">
                    <Style.Setters>
                        <Setter Property="Background" Value="Orange"/>
                    </Style.Setters>
                </Style>
            </Button.Style>
        </Button>
    </StackPanel>
</DataTemplate>

转换器:

public class StringToVisibilityConvertor : IValueConverter
{
    public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
    {
        if (value.ToString() != "HideMe")
            return Visibility.Visible;
        return Visibility.Collapsed;
    }

2 个答案:

答案 0 :(得分:3)

由于动态列,我无法使绑定工作。最后,我偶然发现了Paul Stovell关于如何使用列索引作为绑定路径创建网格的精彩文章。执行此操作后,我为所有列创建了一个datatemplate,并使用datatrigger隐藏了单元格:

http://paulstovell.com/blog/dynamic-datagrid

答案 1 :(得分:0)

必须承认,我在调整列的自动生成方面从未走得这么远 - 我很少使用自动生成的列,但我想你必须知道列,直到运行时间。

如果是我,我会调整模板:

<DataTemplate x:Key="DataTemplate5">
    <Button Name="Button1" Click="ButtonClick" Background="Orange" Content="{Binding ???}" >
    <DataTemplate.Triggers>
        <DataTrigger Binding="{Binding ???}" Value="HideMe">
            <Setter Property="Visibility" Value="Collapsed"/>
        </DataTrigger>
    </DataTemplate.Triggers>
</DataTemplate>

节省了对转换器的需求。现在的问题虽然是什么,为???。什么也不做 - 也就是{Binding}。

您可能还需要在后面添加一些代码:

                 DataGridTemplateColumn templateColumn = new DataGridTemplateColumn    //create new template column
                 {
                     Header = origHeader,
                     CellTemplate = (DataTemplate)Resources["DataTemplate5"],
                     SortMemberPath = e.Column.SortMemberPath
                 };  

实际上,首先尝试一下 - 它可能就足够了,并且在您的值转换器中进行一些调试。