如何在datagrid wpf中设置Column的位置

时间:2010-09-17 11:18:13

标签: c# wpf datagrid

我有一个问题我正在制作一个wpf应用程序并使用数据网格控件来显示表格数据即时通过Xaml和我的所有其他列添加单个Coloum数据网格将添加动态我的固定列来自网格我的第一个位置想要成为它的最后

我怎么能实现呢?

我的Xaml代码如下

先谢谢 shashank`

            <my:DataGrid.Columns>
                <my:DataGridTemplateColumn Header="Edit" Width="110" IsReadOnly="True" >
                    <my:DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <Image Source="file:///D:\Projects\ChadCarpenter\AARFID\AARFID\Images\boardicon.png" />
                        </DataTemplate>
                   </my:DataGridTemplateColumn.CellTemplate> 
                    </my:DataGridTemplateColumn> 
           </my:DataGrid.Columns>
  

下面是我的C#`   public void CreateDataTableheader()           {

        if (Utility.CheckGroupFamily == "Group")
        {
            dtAdultinfo.Columns.Add("Group Name", typeof(String));
        }
        dtAdultinfo.Columns.Add("Last Name", typeof(String));
        dtAdultinfo.Columns.Add("First Name", typeof(String));
        dtAdultinfo.Columns.Add("Phone", typeof(String));
        dtAdultinfo.Columns.Add("CellPhone", typeof(String));
        dtAdultinfo.Columns.Add("TowerID", typeof(String));
        dtAdultinfo.Columns.Add("Room #", typeof(String));
        dtAdultinfo.Columns.Add("IS primary", typeof(int));

        Lst.ItemsSource = dtAdultinfo.DefaultView;

        //DataGridColumn dc;
        //DataGridTemplateColumn  dgColumn = new DataGridTemplateColumn();

        //DataTemplate dt = new DataTemplate();

        //dgColumn.Header="Edit";
        //dgColumn.Width = 110;
        //dgColumn.IsReadOnly= true;


        //dgColumn.CellTemplate = dt;
        //Image img = new Image();
        //BitmapImage logo=new BitmapImage();

        //logo.UriSource =new Uri("file:///D:/Projects/ChadCarpenter/AARFID/AARFID/Images/boardicon.png");


        DataGridTemplateColumn dgColumn = new DataGridTemplateColumn();
        dgColumn.Header = "Edit";
        FrameworkElementFactory factory1 = new FrameworkElementFactory(typeof(Image));
        Binding b1 = new Binding("Picture");
        b1.Mode = BindingMode.TwoWay;
        factory1.SetValue(Image.SourceProperty, b1);
        DataTemplate cellTemplate1 = new DataTemplate();
        cellTemplate1.VisualTree = factory1;
        dgColumn.CellTemplate = cellTemplate1;
        Lst.Columns.Add(dgColumn);`

1 个答案:

答案 0 :(得分:3)

可能会迟到,但为了帮助处理类似问题的其他人,在DatagridColumn.DisplayIndex事件中设置AutoGeneratedColumns可以解决问题。

假设Header = "Edit"的列是您的固定列,而您的DataGrid是这样的:

<DataGrid AutoGeneratedColumns="DataGrid_AutoGeneratedColumns">
    <DataGrid.Columns>
        <my:DataGrid.Columns>
            <my:DataGridTemplateColumn Header="Edit">
                <my:DataGridTemplateColumn.CellTemplate>
                    <DataTemplate>
                        <... />
                    </DataTemplate>
                </my:DataGridTemplateColumn.CellTemplate> 
            </my:DataGridTemplateColumn> 
        </my:DataGrid.Columns>
    </DataGrid.Columns>
</DataGrid>

然后您可以通过它的标题找到所需的列并将其发送到最后一个位置:

private void DataGrid_AutoGeneratedColumns(object sender, EventArgs e)
{
    var grid = (DataGrid)sender;
    foreach (var item in grid.Columns)
    {
        if (item.Header.ToString() == "Edit")
        {
            item.DisplayIndex = grid.Columns.Count - 1;
            break;
        }
    }
}