我有一个baseButtonStyle,它应该应用于所有Button和所有派生类型。它适用于所有Button(不包括衍生按钮)。
<Style x:Key="BaseButtonStyle" Selector="is Button" >
<Setter Property="BorderThickness" Value="1"/>
<Setter Property="Foreground" Value="{StaticResource SecondaryFontBrush}"/>
<Setter Property="BorderBrush" Value="{StaticResource BlueButtonNormalBorderBrush}"/>
<Setter Property="Background" Value="{StaticResource BlueButtonNormalBackgroundBrush}"/>
<Setter Property="UseLayoutRounding" Value="True"/>
<Setter Property="Padding" Value="10"/>
<Setter Property="Margin" Value="10"/>
</Style>
现在我有一个从Button派生的AdditionalTextButton。
using Avalonia;
using Avalonia.Controls;
using Avalonia.Media;
using System;
namespace VW7OrbMachineAvalonia1.Components.Controls
{
public class AdditionalTextButton : Button
{
Type IStyleable.StyleKey => typeof(AdditionalTextButton);
/// <summary>
/// Bottom left displayed Text
/// </summary>
public string BottomLeftText
{
get { return (string)GetValue(BottomLeftTextProperty); }
set { SetValue(BottomLeftTextProperty, value); }
}
public static readonly StyledProperty<String> BottomLeftTextProperty =
AvaloniaProperty.Register<AdditionalTextButton, String>("BottomLeftText");
}
}
我对Avalonia的样式行为的理解是,由于is Button
选择器,BaseButtonStyle应该应用于AdditionalTextButton。但这不会发生。
除此之外,我还有另一种样式应适用于所有AdditionaltextButtons。这也很好。
<Style x:Key="additionalTextButtonStyle" Selector="is vwaui:Additionaltextbutton">
<Setter Property="FontSize" Value="22"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate>
<Grid Width="{TemplateBinding Width}" Height="{TemplateBinding Height}">
<TextBlock HorizontalAlignment="Left" VerticalAlignment="Bottom" TextWrapping="Wrap" Text="{TemplateBinding BottomLeftText}"/>
<TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" TextWrapping="Wrap" Text="{TemplateBinding Content}"/>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
如何获得结果,即AdditionalTextButton由BaseButtonStyle设置样式,并由AdditionalTextButtonStyle设置样式?来自AdditionalTextButtonStyle的设置器应覆盖BaseButtonStyle中的设置器。
答案 0 :(得分:1)
问题是您的is
选择器语法错误。如果将其更改为:
Selector=":is(Button)"
和
Selector=":is(vwaui|Additionaltextbutton)"
这应该可以按预期工作。
答案 1 :(得分:0)
Avalonia没有直接继承样式的概念。 Avalonia与WPF,UWP等区别最大的地方是其样式系统。 Avalonia的样式系统更类似于CSS。
因此,您可以使用类。
例如说您在XAML 3按钮中声明:
<Button />
<Button Classes="buttonStyle1" />
<Button Classes="buttonStyle1 buttonStyle2" />
然后您可以添加以下样式:
<Style Selector="Button">
<Setter Property="FontSize" Value="12" />
</Style>
<Style Selector="Button.buttonStyle1">
<Setter Property="FontWeight" Value="Bold" />
</Style>
<Style Selector="Button.buttonStyle2">
<Setter Property="Foreground" Value="Red" />
</Style>
这样,您可以一次组合或继承多种样式。
如果您想显着改变外观,还可以用样式覆盖模板。