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

Sha*_*ank 4 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>
Run Code Online (Sandbox Code Playgroud)

下面是我的 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);`
Run Code Online (Sandbox Code Playgroud)

Bah*_*ies 5

这可能是晚了,但为了帮助其他处于类似的问题,设置DatagridColumn.DisplayIndexAutoGeneratedColumns事件会做的伎俩。

假设 Column withHeader = "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>
Run Code Online (Sandbox Code Playgroud)

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

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;
        }
    }
} 
Run Code Online (Sandbox Code Playgroud)