Avalonia笔记3-样式

学习笔记:

最基本的样式由选择器(selector)和设置器(setters)的集合组成。

1. OfType选择器

应用于所有button控件

 <Window.Styles>
    <Style Selector="Button" >
        <Setter Property="Background" Value="Orange" ></Setter>
    </Style>
</Window.Styles>

<Style Selector="local | Button"> 如果控件没有在默认的avalonia命名空间下,需要加上其命名空间,竖线分割;

2. Is选择器

Selector=“Button” 控件需要精确匹配,并不会对其派生控件起作用,如果需要对其派生控件也有效的话,使用<Style Selector="is(Button)">就可以了,比如ToggleButton;

3.  Name选择器

 <Window.Styles>
    <Style Selector="Button#test" >
        <Setter Property="Background" Value="Orange" ></Setter>
    </Style>
</Window.Styles>
<Button Grid.Row="7" x:Name="test1">test1</Button>
<Button Grid.Row="8" Name="test2">test2</Button>

4:PropertyEquals选择器

使用<Style Selector="Button[isDefault=true]">,

如果是附加属性的话,使用<Style Selector="Button[(Grid.Row)=0]"> ;

5. Class选择器

<Button Grid.Row="7" Classes="Test2">dfudbhuidf</Button>
<Style Selector="Button.Test2">
    <Setter Property="BorderBrush" Value="Blue"></Setter>
</Style>

Classes的值可以有多个;且可以增加条件,比如:

<Button Grid.Row="7" Classes="Test2 Test3">dfudbhuidf</Button>
<Style Selector="Button.Test2.Test3">
    <Setter Property="BorderBrush" Value="Blue"></Setter>
</Style>

6. Child选择器

<Style Selector="StackPanel > Button"/>

对直接位于StackPanel下的button起作用,对于隔着一层的button不起作用;

7. Descendant选择器

<Style Selector="StackPanel Button" />

对所有位于StackPanel下的button起作用,对于隔着一层的button也起作用;

8. Template选择器

<Style Selector="Button /template/ ContentPresenter"/>

匹配控件模板中的控件。这里列出的所有其他选择器都作用在逻辑树上。如果要在控件模板中选择控件,则必须使用此选择器。

这个比较重要,实际应用示例:

<StackPanel Margin="20" HorizontalAlignment="Left">
    <Expander  Header="HEADER">
        <TextBlock Text="Hello Avalonia"></TextBlock>
    </Expander>
</StackPanel>

 想要将这个控件背景改为红色,给StackPanel添加background属性为红色,或者给Expander添加background属性为红色,都是不可行的,要么是超出了expander范围,或者只有下拉菜单为红色,实现办法:

<Style Selector="Expander /template/ ToggleButton">
    <Setter Property="Background" Value="Red"></Setter>
</Style>

这样就可以了。 

再举一示例:

实现button点击时背景为橙色:

<Style Selector="Button:pressed" >
    <Setter Property="Background" Value="Orange" ></Setter>
</Style>

这样是行不通的,需要改为:

<Style Selector="Button:pressed /template/ ContentPresenter" >
    <Setter Property="Background" Value="Orange" ></Setter>
</Style>

9. Not选择器

<Style Selector="TextBlock:not(.h1)">

取反内部选择器。

10. Or选择器

<Style Selector="TextBlock, Button">

查找任意一个与这些选择器中匹配的元素。每个选择器用,分开。

  • 23
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Avalonia是一个**跨平台的UI框架,用于创建桌面应用程序**。 以下是一些关于Avalonia的基本信息和学习资源: 1. **什么是Avalonia?**:Avalonia是一个基于WPF XAML的开源UI框架,它允许开发者使用.NET构建跨平台的桌面应用程序。Avalonia支持多种操作系统,包括Windows、Linux和macOS。 2. **准备工作**:在开始使用Avalonia之前,你需要安装相应的开发环境,并配置项目。这通常包括安装.NET SDK和Avalonia工具包。 3. **创建第一个Avalonia应用程序**:你可以通过官方文档或相关教程来创建你的第一个Avalonia应用,这将帮助你理解基本的应用程序结构和开发流程。 4. **XAML基础**:XAML是一种用于定义用户界面的语言,你可以学习如何使用XAML来创建界面布局和实现数据绑定。 5. **控件和样式**:Avalonia提供了丰富的控件库,你可以学习如何使用这些控件以及如何通过样式和模板来自定义它们的外观。 6. **MVVM模式**:MVVM(Model-View-ViewModel)是一种设计模式,用于分离应用程序的业务逻辑和界面表示。学习MVVM将有助于你构建可维护和可测试的应用程序。 7. **导航和多窗口**:了解如何在Avalonia中进行窗口导航和管理多个窗口,这对于构建复杂的桌面应用程序非常重要。 8. **打包和发布应用程序**:最后,你需要学习如何将你的Avalonia应用程序打包和发布,以便用户可以在他们的计算机上安装和使用你的应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值