Avalonia的样式快速入门

前言

不同于WPF。Avalonia的样式是Styles。属于Windows.Styles。下面是用一段示例代码来快速入门
 	<Window.Styles>
		<StyleInclude Source='/Styles/Button.axaml'/>
		<StyleInclude Source='/Styles/TextBox.axaml'/>

		<Style Selector="TextBlock.Label">
			<Setter Property="FontSize" Value="14"/>
			<Setter Property="Foreground" Value="#FF999999"/>
			<Setter Property="VerticalAlignment" Value="Center"/>
		</Style>

		<Style Selector="TextBlock.ShowText">
			<Setter Property="FontSize" Value="14"/>
			<Setter Property="Foreground" Value="#FF333333"/>
			<Setter Property="VerticalAlignment" Value="Center"/>
			<Setter Property="Margin" Value="8,0,15,0"/>
			<Setter Property="TextTrimming" Value="CharacterEllipsis"/>

		</Style>
	</Window.Styles>

下面来分析整个代码

一、如何导入资源?

导入资源在需要的地方如Window.Styles、Application.Styles等这些地方导入。
通常写法为<StyleInclude>的方式 如<StyleInclude Source='/Styles/Button.axaml'/> 即可导入资源文件。

二、如何使用Style

1定义Style

Style的设置和WPF类似,但是又有细微差别。WPF通常采用TargetType和key来确定和使用资源。上面代码Selector="TextBlock.ShowText"中等效的WPF代码如下。

    <Style TargetType="TextBlock" x:Key="Label">
        <Setter Property="FontSize" Value="14"/>
        <Setter Property="Foreground" Value="#FF999999"/>
        <Setter Property="VerticalAlignment" Value="Center"/>
    </Style>

Avalonia使用Selector 的形式。

		<Style Selector="TextBlock.Label">
			<Setter Property="FontSize" Value="14"/>
			<Setter Property="Foreground" Value="#FF999999"/>
			<Setter Property="VerticalAlignment" Value="Center"/>
		</Style>

2.使用Style

代码如下(示例):

	<TextBlock Classes="Label" Text="123"/>

使用Classes寻找定义的Selector

3.Style接入自定义控件

自定义控件采用<Style Selector="local|Button">这种形式。下面定义一个CornerRadiusButton的圆角按钮。

自定义控件
样式写法如下
引入命名空间

xmlns:controls="clr-namespace:AvaloniaApplication1.Controls;assembly=AvaloniaApplication1"

简单样式

		<Style  Selector="controls|CornerRadiusButton.CorButton">
			<Setter Property="VerticalAlignment" Value="Center"/>
			<Setter Property="HorizontalAlignment" Value="Right"/>
		</Style>

详细样式(实现圆角按钮)

<Style  Selector="controls|CornerRadiusButton.CorButton">
	<Setter Property="VerticalAlignment" Value="Center"/>
	<Setter Property="HorizontalAlignment" Value="Right"/>
	<Setter Property="Template">
		<ControlTemplate>
			<Border Width="{TemplateBinding Width}" Height="{TemplateBinding Height}" Background="{TemplateBinding Background}" CornerRadius="{TemplateBinding CornerRadius}">
				<TextBlock Text="{TemplateBinding Content}"
						   Margin="{TemplateBinding Padding}"
						   Foreground="{TemplateBinding Foreground}"
						   FontSize="{TemplateBinding FontSize}"
						   VerticalAlignment="Center"
						   HorizontalAlignment="Center"/>
			</Border>
		</ControlTemplate>
	</Setter>
</Style>

关于Style的Avalonia触发器是通过伪类来实现的。下面一篇文章将详细介绍Avalonia的style的一些高级功能
参考Demo下载

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Avalonia是一个跨平台的用户界面框架,可以用于构建现代化的、具有吸引力的客户端应用程序。它给开发者提供了一套丰富的工具和API,使得开发定制化的UI变得更加简单和高效。 Avalonia的文档是一个完整指南,可以帮助开发者了解和学习如何使用Avalonia框架来构建应用程序。文档分为几个部分,包括入门指南、概念和架构、框架特性、控件库和示例。通过这些文档,开发者可以掌握Avalonia的基本概念和工作原理,了解如何使用不同的工具和API来开发具有吸引力的界面。 入门指南部分提供了安装和配置Avalonia框架的详细说明,包括使用命令行和包管理器安装、创建新项目和设置开发环境等。概念和架构部分解释了Avalonia的核心概念,例如界面元素、布局和事件系统,并介绍了Avalonia的整体架构和组件。 框架特性部分介绍了Avalonia提供的各种功能和特性,例如样式和主题、绑定和命令系统、动画和动态布局等。控件库部分详细介绍了Avalonia内置的各种控件类型和自定义控件的开发方法。示例部分提供了一些完整的示例代码,帮助开发者更好地理解和应用Avalonia框架的各种功能。 总之,Avalonia的文档是一个非常有价值的资源,可以帮助开发者快速入门和提高使用Avalonia框架的能力。无论是初学者还是有经验的开发者,都可以从这些文档中获得有关Avalonia框架的宝贵知识。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值