WPF 解决 SelectionTextBrush 设置无效问题
本文经原作者授权以原创方式二次分享,欢迎转载、分享。
原文作者:lindexi
原文地址:https://www.cnblogs.com/lindexi/p/18109748
如以下的代码,设置被选择的文本的字符颜色为红色。
<Grid>
<TextBox Text="Test" FontSize="100" SelectionTextBrush="Red"/>
</Grid>
运行项目,你将发现 SelectionTextBrush
属性设置是完全没有效果的,被选择的文本依然是黑色的
可以在 App
构造函数添加开关让 SelectionTextBrush
属性生效,代码如下:
public App()
{
AppContext.SetSwitch("Switch.System.Windows.Controls.Text.UseAdornerForTextboxSelectionRendering", false);
}
加上如上代码之后,再次运行项目,选择文本,你将发现选择的文本的颜色变为红色
根据微软的官方文档,这是因为在 .NET Framework 4.7.1
以及更早的版本里面,在 System.Windows.Controls.TextBox
和 System.Windows.Controls.PasswordBox
底层将在 Adorner
层绘制文本选择范围。这将会在某些系统主题下,导致文本蒙层的颜色影响文本的阅读。为了 WPF
提出新的 Switch.System.Windows.Controls.Text.UseAdornerForTextboxSelectionRendering
开关,用于控制 WPF
的文本选择是否采用 Adorner
层实现。当采用在 .NET Framework 4.7.2
引入的禁用 Adorner
层绘制文本选择范围时,由于底层机制的变更,能够支持在 .NET Framework 4.8
引入的 SelectionTextBrush
属性。这就是为什么设置开关能够让此属性工作的原因,一旦没有设置开关,则因为 WPF
保持兼容性,依然走 Adorner
层绘制文本选择范围而不能支持 SelectionTextBrush
属性,导致设置无效
相关文档:
WPF TextBox/PasswordBox Text Selection Does Not Follow System Colors[1] Add SelectionTextBrush public property to TextBox/PasswordBox non-adorner selection[2]
以上代码放在 github[3] 和 gitee[4] 上,可以使用如下命令行拉取代码
先创建一个空文件夹,接着使用命令行 cd 命令进入此空文件夹,在命令行里面输入以下代码,即可获取到本文的代码
git init
git remote add origin https://gitee.com/lindexi/lindexi_gd.git
git pull origin 15ab047a99f4327e21ce406430651bc79a950a7a
以上使用的是 gitee 的源,如果 gitee 不能访问,请替换为 github 的源。请在命令行继续输入以下代码,将 gitee 源换成 github 源进行拉取代码
git remote remove origin
git remote add origin https://github.com/lindexi/lindexi_gd.git
git pull origin 15ab047a99f4327e21ce406430651bc79a950a7a
获取代码之后,进入 BikallnawyeWhereluwecunu
文件夹,即可获取到源代码
WPF TextBox/PasswordBox Text Selection Does Not Follow System Colors: https://github.com/Microsoft/dotnet/blob/main/Documentation/compatibility/wpf-TextBox-PasswordBox-text-selection-does-not-follow-system-colors.md
[2]Add SelectionTextBrush public property to TextBox/PasswordBox non-adorner selection: https://github.com/microsoft/dotnet/blob/main/Documentation/compatibility/wpf-SelectionTextBrush-property-for-non-adorner-selection.md
[3]github: https://github.com/lindexi/lindexi_gd/tree/15ab047a99f4327e21ce406430651bc79a950a7a/BikallnawyeWhereluwecunu
[4]gitee: https://gitee.com/lindexi/lindexi_gd/tree/15ab047a99f4327e21ce406430651bc79a950a7a/BikallnawyeWhereluwecunu