如何在DataGrid中支持重新调整DataGridRowHeader列的大小

时间:2012-03-06 11:33:06

标签: wpf wpfdatagrid styling resize datagridrowheader

我想允许重新调整dataGrid的第0列,包含SelectAll按钮和行标题的列 -

enter image description here

图片取自 - WPF Toolkit DataGrid, Part II – Custom styling

2 个答案:

答案 0 :(得分:1)

试试这个......

<强> XAML:

   <tk:DataGrid x:Name="MyDataGrid"
                RowHeaderWidth="15"
                ItemsSource="{StaticResource MyData}"
                AutoGenerateColumns="False">
        <tk:DataGrid.Columns>
            <tk:DataGridTextColumn Binding="{Binding ID}">
                <tk:DataGridTextColumn.HeaderTemplate>
                    <DataTemplate>
                        <DockPanel>
                            <GridSplitter
                                DockPanel.Dock="Left"
                                VerticalAlignment="Stretch"
                                HorizontalAlignment="Left" Width="2"
                                DragDelta="GridSplitter_DragDelta"/>
                            <TextBlock Text="ID" DockPanel.Dock="Right"/>
                        </DockPanel>
                    </DataTemplate>
                </tk:DataGridTextColumn.HeaderTemplate>
            </tk:DataGridTextColumn>
            <tk:DataGridTextColumn Header="Name"
                                   Binding="{Binding Name}">
            </tk:DataGridTextColumn>
        </tk:DataGrid.Columns>
    </tk:DataGrid>

代码背后:

     private void GridSplitter_DragDelta
        (object sender,
         System.Windows.Controls.Primitives.DragDeltaEventArgs e)
    {
        if (MyDataGrid.RowHeaderWidth + e.HorizontalChange >= 15)
        {
            MyDataGrid.RowHeaderWidth = MyDataGrid.RowHeaderWidth + e.HorizontalChange;
        }
    }

您可以覆盖RowHeaderTemplate并将此精确的网格分割器停靠在右侧。但对我来说,将它停靠在第一列标题左侧效果最好!

答案 1 :(得分:0)

                <GridViewColumn Header="Name" Width="150">
                     <GridViewColumn.CellTemplate>
                         <DataTemplate>
                            <TextBlock Width="Auto" TextTrimming="CharacterEllipsis"/>
                        </DataTemplate>
                    </GridViewColumn.CellTemplate>
                </GridViewColumn>

试试这个