首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > .NET > C# >

[WPF]DataGrid 列中的单元格编辑状态解决办法

2013-10-21 
[WPF]DataGrid列中的单元格编辑状态WPF一个DataGrid中有 5行数据其中有一列数据我会根据数据源中的Bool值

[WPF]DataGrid 列中的单元格编辑状态
WPF一个DataGrid中有 5行数据其中有一列数据我会根据数据源中的Bool值来判断是否编辑和不能编辑,换句话说就是怎么实现对某行数据的某列值开启是否编辑状态。

例如:
第一行的   第一列为可编辑
第二行的   第一列为不可编辑
[解决办法]

第一行为不可编辑
 DataGridRow row = (DataGridRow)dataGrid1.ItemContainerGenerator.ContainerFromIndex(0);
            if (row == null)
            {
                dataGrid1.UpdateLayout();
                row = (DataGridRow)dataGrid1.ItemContainerGenerator.ContainerFromIndex(0);
                
         }
         row.IsEnabled = false;
        public static T GetVisualChild<T>(Visual parent) where T : Visual
        {
            T childContent = default(T);
            int numVisuals = VisualTreeHelper.GetChildrenCount(parent);
            for (int i = 0; i < numVisuals; i++)
            {
                Visual v = (Visual)VisualTreeHelper.GetChild(parent, i);
                childContent = v as T;
                if (childContent == null)
                {
                    childContent = GetVisualChild<T>(v);
                }
                if (childContent != null)
                {
                    break;
                }
            }
            return childContent;
        }
 
 
//第二行第一列不可编辑
                 DataGridRow rowContainer = GetDataGridRow(dataGrid1, 1);


 
                if (rowContainer != null)
                {
                    DataGridCellsPresenter presenter = GetVisualChild<DataGridCellsPresenter>(rowContainer);
                    DataGridCell cell = (DataGridCell)presenter.ItemContainerGenerator.ContainerFromIndex(1);
                    if (cell == null)
                    {
                        dataGrid1.ScrollIntoView(rowContainer, dataGrid1.Columns[0]);
                        cell = (DataGridCell)presenter.ItemContainerGenerator.ContainerFromIndex(0);
                       
                    }
 
                    cell.IsEnabled = false;
                }

热点排行