【问题标题】:WPF DataGrid ColumnHeader Style: Can't make text bold in ControlTemplateWPF DataGrid ColumnHeader 样式:无法在 ControlTemplate 中使文本变为粗体
【发布时间】:2012-04-17 02:41:18
【问题描述】:

我正在使用 WpfToolkit 中的 DataGrid。我已经为它使用了 Style 资源字典并对其进行了一些调整。我想要完成的是当数据绑定对象上的某个属性为 True 时使标题变为粗体。列标题不一定是 TextBlock,它的控制模板重新定义如下:

数据网格样式:

<Style x:Key="ModificationsDataGridStyle"  TargetType="{x:Type compCtrls:ModDataGrid}">
    <Setter Property="ColumnHeaderStyle" Value="{StaticResource DatagridColumnHeaderCustomTemplateStyle}" />
</Style>

列标题样式:

<Style x:Key="DatagridColumnHeaderCustomTemplateStyle" 
       TargetType="{x:Type primitives:DataGridColumnHeader}">
    <Setter Property="SnapsToDevicePixels" Value="True" />
    <Setter Property="MinWidth" Value="0" />
    <Setter Property="MinHeight" Value="28" />
    <Setter Property="Foreground" Value="White" />
    <Setter Property="FontWeight" Value="Normal" />
    <Setter Property="Cursor" Value="Hand" />
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type primitives:DataGridColumnHeader}">
                <Grid>
                    <Grid.ColumnDefinitions>
                        <ColumnDefinition Width="*" />
                        <ColumnDefinition Width="Auto" />
                    </Grid.ColumnDefinitions>
                    <Border x:Name="BackgroundBorder" BorderThickness="0,1,0,1" 
                            Background="{StaticResource DataGridHeaderBackgroundBrush}" 
                            BorderBrush="{StaticResource DataGridHeaderBorderBrush}" 
                            Grid.ColumnSpan="2" />
                    <ContentPresenter x:Name="ContentPres" Margin="6,3,6,3" VerticalAlignment="Center" />
                    <Path x:Name="SortArrow" Visibility="Hidden" Data="M0,0 L1,0 0.5,1 z" Stretch="Fill" 
                          Grid.Column="1" Width="10" Height="7" Fill="White" Margin="0,0,7,0" 
                          VerticalAlignment="Center" RenderTransformOrigin="0.5,0.4" />
                    <Rectangle Width="1" Fill="#AAC377" HorizontalAlignment="Right" Grid.ColumnSpan="2" />

                    <Rectangle Width="1" Margin="0,0,1,0" Fill="#425B10" 
                               HorizontalAlignment="Right" Grid.ColumnSpan="2" />
                    <Thumb x:Name="PART_LeftHeaderGripper" HorizontalAlignment="Left" 
                           Style="{StaticResource ColumnHeaderGripperStyle}"/>
                    <Thumb x:Name="PART_RightHeaderGripper" HorizontalAlignment="Right" 
                           Style="{StaticResource ColumnHeaderGripperStyle}"/>
                </Grid>
                <ControlTemplate.Triggers>
                    <Trigger Property="SortDirection" Value="{x:Null}">
                        <Setter TargetName="SortArrow" Property="Visibility" Value="Collapsed" />
                    </Trigger>
                    <Trigger Property="IsMouseOver" Value="True">
                        <Setter Property="Background" TargetName="BackgroundBorder" 
                                Value="{StaticResource DataGridHeaderMouseOverBackgroundBrush}" />
                        <Setter Property="BorderBrush" TargetName="BackgroundBorder" 
                                Value="{StaticResource DataGridHeaderBorderBrush}" />
                    </Trigger>
                    <Trigger Property="SortDirection" Value="Ascending">
                        <Setter TargetName="SortArrow" Property="Visibility" Value="Visible" />
                        <Setter TargetName="SortArrow" Property="Fill" Value="Goldenrod" />
                        <Setter TargetName="SortArrow" Property="RenderTransform">
                            <Setter.Value>
                                <RotateTransform Angle="180" />
                            </Setter.Value>
                        </Setter>
                    </Trigger>
                    <Trigger Property="SortDirection" Value="Descending">
                        <Setter TargetName="SortArrow" Property="Visibility" Value="Visible" />
                        <Setter TargetName="SortArrow" Property="Fill" Value="Brown" />
                    </Trigger>
                    <Trigger Property="DisplayIndex" Value="0">
                        <Setter Property="Visibility" Value="Collapsed" 
                                TargetName="PART_LeftHeaderGripper"></Setter>
                    </Trigger>
                    <DataTrigger Binding="{Binding IsRevisedSummableField}" Value="True">
                        <Setter TargetName="ContentPres" Property="Control.FontWeight" Value="Bold" />
                    </DataTrigger>
                </ControlTemplate.Triggers>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

我认为在模板中使用 DataTrigger(绑定到给定属性)会起作用。要么我错了,要么没有走正确的道路来实现这一点。我还应该提到,这些列是自动生成的,一旦生成了列,我将每个 DataGridColumn 的数据上下文设置为:

    protected override void OnAutoGeneratedColumns(EventArgs e)
    {
        var dataTable = pivotMod.DataTable;
        foreach (DataGridColumn gridCol in Columns)
        {
            var colName = gridCol.Header.ToString();
            DataColumn col = dataTable.Columns[colName];

            // give the column headers a pretty name
            gridCol.Header = col.Caption;

            // set the datacontext of the gridcolumn to the modfield ...
            ModFieldGUIWrapper modField = col.ExtendedProperties["ModField"] as ModFieldGUIWrapper;
            gridCol.SetValue(FrameworkElement.DataContextProperty, modField);
        }
        base.OnAutoGeneratedColumns(e);
    }

我们一如既往地非常感谢任何帮助。

干杯, 肖恩

【问题讨论】:

  • 您说您已经尝试过数据触发器?你绑定到正确的部分了吗?您是否尝试用文本块替换您的内容,然后将文本块绑定到您的内容模板绑定,然后使用它作为您的元素绑定?据我所知,DataTrigger 将是您正在寻找的。​​span>

标签: c# wpf datagrid controltemplate datatrigger


【解决方案1】:

找到原因:

我应该将 DataGridColumn.Header 设置为包含 DataTrigger 中指定的属性的数据对象,以便正常运行。然后,我只是重写了我的数据类的 ToString() 方法来显示我想要的漂亮名称。

protected override void OnAutoGeneratedColumns(EventArgs e)
    {
        var dataTable = pivotMod.DataTable;
        foreach (DataGridColumn gridCol in Columns)
        {
            var colName = gridCol.Header.ToString();
            DataColumn col = dataTable.Columns[colName];

            // set the datacontext of the gridcolumn to the modfield ...
            ModFieldGUIWrapper modField = col.ExtendedProperties["ModField"] as ModFieldGUIWrapper;
            gridCol.SetValue(FrameworkElement.DataContextProperty, modField);

            // set the header to the data object so that the datatrigger's binding works!!
            gridCol.Header = modField;

        }
        base.OnAutoGeneratedColumns(e);
    }

感谢 Chris W。您的评论让我走上了正确的道路! :)

【讨论】:

    猜你喜欢
    • 2021-12-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2010-12-11
    • 2017-02-06
    • 1970-01-01
    • 2015-02-28
    • 1970-01-01
    相关资源
    最近更新 更多