wpf dataGrid 选中行 失去焦点时 的背景颜色的更改 4.0及4.5差异

在.net 4.5时直接使用如下方式修改即可

关于 wpf dataGrid 选中行 失去焦点时 的背景颜色的更改。很简单的方式,在datagrid的resource中更改InactiveSelectionHighlightBrushKey属性的值即可。

关键代码如下:

            <DataGrid.Resources>
                <SolidColorBrush x:Key="{x:Static SystemColors.InactiveSelectionHighlightBrushKey}" Color="Yellow"/>
            </DataGrid.Resources>

 

完整的简单代码如下:

        <DataGrid Name="grid1" HorizontalAlignment="Left" Height="120" Margin="75,86,0,0" VerticalAlignment="Top" Width="282">
            <DataGrid.Columns>
                <DataGridTextColumn Header="编号" Binding="{Binding compan.ID}"></DataGridTextColumn>
                <DataGridTextColumn Header="公司" Binding="{Binding CompanyName}"></DataGridTextColumn>
                <DataGridTextColumn Header="固定资产" Binding="{Binding FixedAssets}" Width ="*"></DataGridTextColumn>
            </DataGrid.Columns>
            <DataGrid.Resources>
                <SolidColorBrush x:Key="{x:Static SystemColors.InactiveSelectionHighlightBrushKey}" Color="Yellow"/>
            </DataGrid.Resources>
        </DataGrid>

在.net 4.0 时需使用如下方式修改,否则窗口在设计时无法预览

                <DataGrid.CellStyle>
                    <!--Override Highlighting so that its easy to see what is selected even when the control is not focused-->
                    <Style TargetType="{x:Type DataGridCell}">
                        <Style.Triggers>
                            <Trigger  Property="IsSelected" Value="true">
                                <Setter Property="Background" Value="#FF72DBE0" />
                                <Setter Property="BorderBrush" Value="#FF72DBE0" />
                            </Trigger>
                            <MultiDataTrigger>
                                <MultiDataTrigger.Conditions>
                                    <Condition Binding="{Binding RelativeSource={RelativeSource Self}, Path=IsSelected}" Value="True" />
                                    <Condition Binding="{Binding RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=DataGrid}, Path=IsKeyboardFocusWithin}" Value="False" />
                                </MultiDataTrigger.Conditions>
                                <MultiDataTrigger.Setters>
                                    <Setter Property="Background" Value="#FF7ECB7E" />
                                    <Setter Property="BorderBrush" Value="#FF7ECB7E" />
                                </MultiDataTrigger.Setters>
                            </MultiDataTrigger>
                        </Style.Triggers>
                    </Style>
                </DataGrid.CellStyle>

 Setter 的赋值方式也可使用已指定的系统颜色

<Setter Property="Background" Value="{DynamicResource {x:Static SystemColors.HighlightBrushKey}}" />

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以通过在`TreeView`的`Style`中设置`ItemContainerStyle`来实现失去焦点后修改选中背景颜色。具体步骤如下: 1. 在`TreeView`的`Style`中添加`ItemContainerStyle`: ```xml <Style TargetType="{x:Type TreeViewItem}"> <Style.Triggers> <Trigger Property="IsSelected" Value="True"> <Setter Property="Background" Value="LightBlue"/> <Setter Property="Foreground" Value="White"/> </Trigger> <Trigger Property="IsSelected" Value="False"> <Setter Property="Background" Value="Transparent"/> <Setter Property="Foreground" Value="Black"/> </Trigger> <Trigger Property="IsMouseOver" Value="True"> <Setter Property="Background" Value="LightGray"/> <Setter Property="Foreground" Value="Black"/> </Trigger> <MultiTrigger> <MultiTrigger.Conditions> <Condition Property="IsSelected" Value="True"/> <Condition Property="IsFocused" Value="False"/> </MultiTrigger.Conditions> <Setter Property="Background" Value="Gray"/> </MultiTrigger> </Style.Triggers> </Style> ``` 2. 在`Style`中的`ItemContainerStyle`中添加`MultiTrigger`,当`IsSelected`为`True`且`IsFocused`为`False`设置背景颜色。 ```xml <MultiTrigger> <MultiTrigger.Conditions> <Condition Property="IsSelected" Value="True"/> <Condition Property="IsFocused" Value="False"/> </MultiTrigger.Conditions> <Setter Property="Background" Value="Gray"/> </MultiTrigger> ``` 这段代码的含义是,当`TreeViewItem`被选中并且失去焦点,设置背景颜色为灰色。 注意:上面的代码中的颜色值只是示例,可以根据需要进修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@David Liu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值