DataFrid列标题中的WPF右对齐按钮

时间:2017-01-11 11:09:01

标签: c# wpf xaml datagrid

我正在考虑在datagrid列标题的右侧添加一个过滤器按钮。我已经成功添加了按钮并实现了我需要的所有功能,我似乎无法让按钮在标题中正确对齐。

这是我目前的XAML:

<DataGridTextColumn Width="2*" IsReadOnly="True" Binding="{Binding Load}" x:Name="temp">
    <DataGridTextColumn.Header>
        <Grid Margin="0">
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="*"/>
                <ColumnDefinition Width="16"/>
            </Grid.ColumnDefinitions>
            <TextBlock Grid.Column="0" Text="Load" />
            <Button Grid.Column="1" x:Name="btnFilter" Content="+" Margin="3,0,0,0" Click="btnFilter_Click"></Button>
        </Grid>
    </DataGridTextColumn.Header>
</DataGridTextColumn>

这就是它当前的样子以及我想要按钮的位置。

example

我认为使用网格可以解决问题,但是当我选择网格并查看设计器时,它的宽度不是列的整个宽度,而只是文本块和按钮的宽度。

为了让标题中的按钮右对齐,我缺少什么?

2 个答案:

答案 0 :(得分:5)

使用列的HeaderStyle将DataGridColumnHeader的Horizo​​ntalContentAlignment属性设置为Stretch:

<DataGridTextColumn ...>
    <DataGridTextColumn.HeaderStyle>
        <Style TargetType="{x:Type DataGridColumnHeader}">
            <Setter Property="HorizontalContentAlignment" Value="Stretch" />
        </Style>
    </DataGridTextColumn.HeaderStyle>
    <DataGridTextColumn.Header>
        <Grid Margin="0">
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="*"/>
                <ColumnDefinition Width="16"/>
            </Grid.ColumnDefinitions>
            <TextBlock Grid.Column="0" Text="Load" />
            <Button Grid.Column="1" x:Name="btnFilter" Content="+" Margin="3,0,0,0" HorizontalAlignment="Right"></Button>
        </Grid>
    </DataGridTextColumn.Header>
</DataGridTextColumn>

答案 1 :(得分:0)

虽然mm8的答案是完全正确的,但(我认为)使用DockPanel的效率会更高一些,当然也更简洁:

<DataGridTextColumn ...>
    <DataGridTextColumn.HeaderStyle>
        <Style TargetType="{x:Type DataGridColumnHeader}">
            <Setter Property="HorizontalContentAlignment" Value="Stretch" />
        </Style>
    </DataGridTextColumn.HeaderStyle>
    <DataGridTextColumn.Header>
        <DockPanel>
            <Button DockPanel.Dock="Right" x:Name="btnFilter" Content="+" Margin="3,0,0,0"></Button>
            <TextBlock Text="Load" />
        </DockPanel>
    </DataGridTextColumn.Header>
</DataGridTextColumn>