是否有任何方法可以在代码隐藏中隐藏/折叠特定的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;
}
答案 0 :(得分:3)
由于动态列,我无法使绑定工作。最后,我偶然发现了Paul Stovell关于如何使用列索引作为绑定路径创建网格的精彩文章。执行此操作后,我为所有列创建了一个datatemplate,并使用datatrigger隐藏了单元格:
答案 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
};
实际上,首先尝试一下 - 它可能就足够了,并且在您的值转换器中进行一些调试。