在滑块控件样式中绑定到依赖项属性不起作用

时间:2017-06-13 15:07:08

标签: c# wpf slider dependency-properties

所有默认属性绑定都正常工作,但我的自定义属性使用了回退值。特别是ColorThumb和ColorThumbBorder。顾名思义,这两个属性使用画笔为滑块拇指的各个部分着色。

我过去没有遇到任何问题让我的样式为其他控件使用自定义属性。滑块控件有什么独特之处吗?

样式Xaml

<Style TargetType="{x:Type local:DMSlider}">
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type Slider}">
                <Border>
                    <Grid>
                        <Grid.RowDefinitions>
                            <RowDefinition Height="Auto"/>
                            <RowDefinition Height="Auto" MinHeight="{TemplateBinding MinHeight}"/>
                            <RowDefinition Height="Auto"/>
                        </Grid.RowDefinitions>
                        <TickBar x:Name="TopTick" Visibility="{TemplateBinding TickPlacement}" Fill="{TemplateBinding Foreground}" Placement="Top" Height="4" Grid.Row="0"/>
                        <TickBar x:Name="BottomTick" Visibility="{TemplateBinding TickPlacement}" Fill="{TemplateBinding Foreground}" Placement="Bottom" Height="4" Grid.Row="0"/>
                        <Border x:Name="TrackBackground" BorderThickness="1" CornerRadius="0" Margin="5,0" VerticalAlignment="Center" Height="4.0" Grid.Row="1"
                                Background="{Binding Background, RelativeSource={RelativeSource Mode=TemplatedParent}}"
                                BorderBrush="{Binding BorderBrush, RelativeSource={RelativeSource Mode=TemplatedParent}}">
                            <Canvas Margin="-6,-1">
                                <Rectangle Visibility="Hidden" x:Name="PART_SelectionRange" Height="4.0" StrokeThickness="1.0"/>
                            </Canvas>
                        </Border>
                        <Track x:Name="PART_Track" Grid.Row="1">
                            <Track.DecreaseRepeatButton>
                                <RepeatButton Command="{x:Static Slider.DecreaseLarge}" Style="{StaticResource DMSliderRepeatButton}"/>
                            </Track.DecreaseRepeatButton>
                            <Track.IncreaseRepeatButton>
                                <RepeatButton Command="{x:Static Slider.IncreaseLarge}" Style="{StaticResource DMSliderRepeatButton}"/>
                            </Track.IncreaseRepeatButton>
                            <Track.Thumb>
                                <Thumb x:Name="Thumb">
                                    <Thumb.Style>
                                        <Style TargetType="{x:Type Thumb}">
                                            <Setter Property="SnapsToDevicePixels" Value="true" />
                                            <Setter Property="OverridesDefaultStyle" Value="true" />
                                            <Setter Property="Template">
                                                <Setter.Value>
                                                    <ControlTemplate TargetType="{x:Type Thumb}">
                                                        <Border x:Name="gripBorder" BorderThickness="1"
                                                                Background="{Binding ColorThumb, 
                                                                            RelativeSource={RelativeSource TemplatedParent}, Mode=TwoWay, FallbackValue=Red}"
                                                                BorderBrush="{Binding ColorThumbBorder, 
                                                                            RelativeSource={RelativeSource TemplatedParent}, Mode=TwoWay, FallbackValue=Green}" >
                                                            <Rectangle x:Name="grip" Height="15" Width="10" />
                                                        </Border>
                                                    </ControlTemplate>
                                                </Setter.Value>
                                            </Setter>
                                        </Style>
                                    </Thumb.Style>
                                </Thumb>
                            </Track.Thumb>
                        </Track>
                    </Grid>
                </Border>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

属性CS

public partial class DMSlider : Slider
{
    public static readonly DependencyProperty ColorSliderLeftProperty =
        DependencyProperty.Register("ColorSliderLeft", typeof(Brush), typeof(DMSlider));

    public static readonly DependencyProperty ColorSliderRightProperty =
        DependencyProperty.Register("ColorSliderRight", typeof(Brush), typeof(DMSlider));

    public static readonly DependencyProperty ColorSliderThumbProperty =
        DependencyProperty.Register("ColorThumb", typeof(Brush), typeof(DMSlider), new FrameworkPropertyMetadata(Brushes.Orange));

    public static readonly DependencyProperty ColorSliderThumbHoverProperty =
        DependencyProperty.Register("ColorThumbHover", typeof(Brush), typeof(DMSlider));

    public static readonly DependencyProperty ColorSliderThumbBorderProperty =
        DependencyProperty.Register("ColorThumbBorder", typeof(Brush), typeof(DMSlider));

    public Brush ColorSliderLeft
    {
        get { return (Brush)GetValue(ColorSliderLeftProperty); }
        set { SetValue(ColorSliderLeftProperty, value); }
    }

    public Brush ColorSliderRight
    {
        get { return (Brush)GetValue(ColorSliderRightProperty); }
        set { SetValue(ColorSliderRightProperty, value); }
    }

    public Brush ColorThumb
    {
        get { return (Brush)GetValue(ColorSliderThumbProperty); }
        set { SetValue(ColorSliderThumbProperty, value); }
    }

    public Brush ColorThumbHover
    {
        get { return (Brush)GetValue(ColorSliderThumbHoverProperty); }
        set { SetValue(ColorSliderThumbHoverProperty, value); }
    }

    public Brush ColorThumbBorder
    {
        get { return (Brush)GetValue(ColorSliderThumbProperty); }
        set { SetValue(ColorSliderThumbBorderProperty, value); }
    }
}

2 个答案:

答案 0 :(得分:0)

感谢@Clemens告诉我我做错了什么。我需要引用滑块而不是拇指。

我应该像这样瞄准一个祖先:

Background="{Binding ColorThumb, RelativeSource={RelativeSource AncestorType=local:DMSlider}, Mode=TwoWay, FallbackValue=Red}"
BorderBrush="{Binding ColorThumbBorder, RelativeSource={RelativeSource AncestorType=local:DMSlider}, Mode=TwoWay, FallbackValue=Green}"

完整的拇指风格

<Thumb x:Name="Thumb">
<Thumb.Style>
    <Style TargetType="{x:Type Thumb}">
        <Setter Property="SnapsToDevicePixels" Value="true" />
        <Setter Property="OverridesDefaultStyle" Value="true" />
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type Thumb}">
                    <Border x:Name="gripBorder" BorderThickness="1"
                            Background="{Binding ColorThumb, 
                                        RelativeSource={RelativeSource AncestorType=local:DMSlider}, Mode=TwoWay, FallbackValue=Red}"
                            BorderBrush="{Binding ColorThumbBorder, 
                                        RelativeSource={RelativeSource AncestorType=local:DMSlider}, Mode=TwoWay, FallbackValue=Green}">
                        <Rectangle x:Name="grip" Height="15" Width="10" />
                    </Border>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>
</Thumb.Style>

答案 1 :(得分:-1)

您的ColorThumbBorder属性在其getter中使用ColorSliderThumbProperty。