How to set column position in datagrid wpf

I have im problem creating wpf application and using data grid. Management to display tabular data. im Adding a single column to the data. Grid through Xaml. And my whole other column. A dynamic my fixed column will be added. When you first place in the Grid, I want it to be at last.

how can i achieve it

my xaml code is as below

Thanks in Advance 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>

And below my 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);`
+3
source share
1 answer

It may be late, but in order to help others with similar problems, setting DatagridColumn.DisplayIndexup an AutoGeneratedColumnsevent will do the trick.

, 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;
        }
    }
} 
+2

Source: https://habr.com/ru/post/1765273/


All Articles