gpt4 book ai didi

wpf - 在 XAML(带边框)中聚焦/拖动时如何更改 GridSplitter 的背景?

转载 作者:行者123 更新时间:2023-12-03 21:34:53 24 4
gpt4 key购买 nike

我发现没有像“DragBackground”之类的 GridSplitter 属性很奇怪。

不过,这似乎有效:

<UserControl.Resources>
<Style x:Key="CustomGridSplitterStyle" TargetType="GridSplitter">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="GridSplitter">
<Grid x:Name="Root" >
<!-- Background -->
<Rectangle Fill="White" StrokeThickness="0" />
<!-- Focus Visual -->
<Rectangle x:Name="FocusVisual" Stroke="White" StrokeThickness="1" Opacity="0" IsHitTestVisible="false" />
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</UserControl.Resources>
  GridSplitter Style="{StaticResource CustomGridSplitterStyle}" Grid.Column="1" Width="6" HorizontalAlignment="Stretch" 
BorderThickness="2,0,0,0" BorderBrush="Blue" />

然而,我对这个解决方案的问题是我想在 GridSplitter 的左侧设置一个边框(见上文),这在使用自定义 GridSplitter 样式时不起作用。
有谁知道如何让这个工作?

最佳答案

如果您想使用 BorderBrushBorderThickness在您的 Template您可以使用 TemplateBinding在一些 Border .您也可以使用 Setter在您的 Style定义一些默认值。

<Style x:Key="CustomGridSplitterStyle" TargetType="{x:Type GridSplitter}">
<Setter Property="Background" Value="White"/>
<Setter Property="BorderBrush" Value="White"/>
<Setter Property="BorderThickness" Value="0"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="GridSplitter">
<Border
x:Name="FocusVisual"
Background="{TemplateBinding Background}"
BorderBrush="{TemplateBinding BorderBrush}"
BorderThickness="{TemplateBinding BorderThickness}"/>
<ControlTemplate.Triggers>
<Trigger Property="IsDragging" Value="True">
<Setter TargetName="FocusVisual" Property="..." Value="..." />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>

也因为 GridSplitterThumb因此有 IsDragging 属性,以便您可以创建 Trigger如上例所示,在正确时做某事

关于wpf - 在 XAML(带边框)中聚焦/拖动时如何更改 GridSplitter 的背景?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26421817/

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