gpt4 book ai didi

c# - WPF - 使用样式更改滚动条的文本框边距

转载 作者:行者123 更新时间:2023-11-30 23:02:45 24 4
gpt4 key购买 nike

我为 Scrollbar 定义了一个隐式样式并设置了一些属性,我将它用于大多数 ScrollViewrs。部分样式是:

<Style x:Key="{x:Type ScrollBar}" TargetType="{x:Type ScrollBar}">
<Setter Property="Background" Value="#FF283542" />
<Setter Property="Margin" Value="0,-32,0,0" />
<Setter Property="Width" Value="5" />
</Style>

但我有一些文本框,我希望它们的滚动条具有相同的隐式滚动条样式,但边距不同。

我可以通过向每个 TextBox 添加 Resources 并覆盖隐式 ScrollBar 样式来实现,例如:

    <TextBox Style="{StaticResource big-text-style}">
<TextBox.Resources>
<Style TargetType="{x:Type ScrollBar}"
BasedOn="{StaticResource {x:Type ScrollBar}}">
<Setter Property="Margin" Value="0"/>
</Style>
</TextBox.Resources>
</TextBox>

这段代码提供了我想要的功能。但是这种方法的问题是我必须为每个 TextBox 编写这些代码行!如果我可以将它作为 TextBox 样式本身的一部分,那就更好了。

我想知道有没有办法将它放在 TextBox 的样式中,以便每个具有大文本样式(例如)的 TextBox 都具有覆盖的 ScrollBar ?

或者有没有更好的方法来实现这种事情?

谢谢你的帮助!

最佳答案

您可以将覆盖的 ScrollBar 样式添加到 TextBox 样式本身的 Resources 中:

<Style x:Key="big-text-style" TargetType="TextBox">
<Style.Resources>
<Style TargetType="{x:Type ScrollBar}" BasedOn="{StaticResource {x:Type ScrollBar}}">
<Setter Property="Margin" Value="0"/>
</Style>
</Style.Resources>
</Style>

关于c# - WPF - 使用样式更改滚动条的文本框边距,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50315574/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com