C# 访问控制模板属性
我有以下控件模板:C# 访问控制模板属性,c#,wpf,C#,Wpf,我有以下控件模板: <ControlTemplate x:Key="GlassButton" TargetType="{x:Type Button}"> <ControlTemplate.Resources> <Storyboard x:Key="Timeline1"> <DoubleAnimationUsingKeyFrames BeginTime="00:00:00" Story
<ControlTemplate x:Key="GlassButton" TargetType="{x:Type Button}">
<ControlTemplate.Resources>
<Storyboard x:Key="Timeline1">
<DoubleAnimationUsingKeyFrames BeginTime="00:00:00" Storyboard.TargetName="glow" Storyboard.TargetProperty="(UIElement.Opacity)">
<SplineDoubleKeyFrame KeyTime="00:00:00.3000000" Value="1"/>
</DoubleAnimationUsingKeyFrames>
</Storyboard>
<Storyboard x:Key="Timeline2">
<DoubleAnimationUsingKeyFrames BeginTime="00:00:00" Storyboard.TargetName="glow" Storyboard.TargetProperty="(UIElement.Opacity)">
<SplineDoubleKeyFrame KeyTime="00:00:00.3000000" Value="0"/>
</DoubleAnimationUsingKeyFrames>
</Storyboard>
</ControlTemplate.Resources>
<Border BorderBrush="#FFFFFF" BorderThickness="1,1,1,1" CornerRadius="4,4,4,4">
<Border x:Name="border" Background="#7F0000" BorderBrush="#FF000000" BorderThickness="1,1,1,1" CornerRadius="4,4,4,4">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="0.507*"/>
<RowDefinition Height="0.493*"/>
</Grid.RowDefinitions>
<Border Opacity="0" HorizontalAlignment="Stretch" x:Name="glow" Width="Auto" Grid.RowSpan="2" CornerRadius="4,4,4,4">
<Border.Background>
<RadialGradientBrush>
<RadialGradientBrush.RelativeTransform>
<TransformGroup>
<ScaleTransform ScaleX="1.702" ScaleY="2.243"/>
<SkewTransform AngleX="0" AngleY="0"/>
<RotateTransform Angle="0"/>
<TranslateTransform X="-0.368" Y="-0.152"/>
</TransformGroup>
</RadialGradientBrush.RelativeTransform>
<GradientStop Color="#B28DBDFF" Offset="0"/>
<GradientStop Color="#008DBDFF" Offset="1"/>
</RadialGradientBrush>
</Border.Background>
</Border>
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" Width="Auto" Grid.RowSpan="2"/>
<Border HorizontalAlignment="Stretch" Margin="0,0,0,0" x:Name="shine" Width="Auto" CornerRadius="4,4,0,0">
<Border.Background>
<LinearGradientBrush EndPoint="0.494,0.889" StartPoint="0.494,0.028">
<GradientStop Color="#99FFFFFF" Offset="0"/>
<GradientStop Color="#33FFFFFF" Offset="1"/>
</LinearGradientBrush>
</Border.Background>
</Border>
</Grid>
</Border>
</Border>
<ControlTemplate.Triggers>
<Trigger Property="IsPressed" Value="True">
<Setter Property="Opacity" TargetName="shine" Value="0.4"/>
<Setter Property="Background" TargetName="border" Value="#CC000000"/>
<Setter Property="Visibility" TargetName="glow" Value="Hidden"/>
</Trigger>
<Trigger Property="IsMouseOver" Value="True">
<Trigger.EnterActions>
<BeginStoryboard Storyboard="{StaticResource Timeline1}"/>
</Trigger.EnterActions>
<Trigger.ExitActions>
<BeginStoryboard x:Name="Timeline2_BeginStoryboard" Storyboard="{StaticResource Timeline2}"/>
</Trigger.ExitActions>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
现在,我想将此模板应用于许多不同的按钮。但是,我希望每个按钮的背景颜色都不同。我希望为每个按钮更改的控件模板的属性是边框的背景
<Border x:Name="border" Background="#7F0000">
我需要能够为该背景设置不同的值。设置为
<Button Background="Yellow" Template="{DynamicResource GlassButton}">
不起作用
有什么想法吗
谢谢。在要应用背景的
边框
元素上,按如下方式进行绑定:
<Border x:Name="border" Background="{TemplateBinding Background}"...
在要应用背景的边框
元素上,按如下方式绑定它:
<Border x:Name="border" Background="{TemplateBinding Background}"...
太好了,这很有魅力。在一个相关的注释中,是否可以对发光和发光边界的渐变停止颜色进行类似的操作?我的意思是,这个模板应用到的单个按钮也可以控制吗?渐变停止点等基本上是另一个笔刷,您希望在模板中的另一个元素上使用它(我们已经看到的边界除外)。由于在按钮上没有两个背景
属性
,因此没有可用的笔刷类型属性来绑定其他元素的背景。您需要创建一个从按钮派生的自定义控件,并声明一些额外的依赖属性。太好了,这就像一个符咒。在一个相关的注释中,是否可以对发光和发光边界的渐变停止颜色进行类似的操作?我的意思是,这个模板应用到的单个按钮也可以控制吗?渐变停止点等基本上是另一个笔刷,您希望在模板中的另一个元素上使用它(我们已经看到的边界除外)。由于在按钮上没有两个背景
属性
,因此没有可用的笔刷类型属性来绑定其他元素的背景。您需要创建一个从按钮派生的自定义控件,并声明一些额外的依赖属性。