在XAML中,样式、模板、画笔和动画等都被看做是资源,它们最终的作用都是相同的,就是让设计人员可以使用这些资源创建更好的视觉效果,对其设计的产品外观进行标准化统一,那么如何使用这些资源并组织和重用呢,本节就来讲解样式、模板、画笔和动画的概念,以及它们的使用方法。

3.3.1 样式

在开发应用程序过程中,添加一个控件时可以通过设置控件的属性来控制它的显示外观。例如,对于TextBox文本框,可以通过设置字体属性得到不同的文本显示效果,这些属性包括FontFamily(字体类型)、FontSize(字体大小)、FontStyle(字形)和Foreground(字体颜色)等。尽管设计人员可以对应用程序的外观逐个进行大量的自定义操作,但他们还是需要一个功能强大的样式设置,以便在应用程序内部和应用程序之间共享和维护外观。

1.样式的定义及引用

在XAML中,任何派生自FrameworkElementFrameworkContentElement的元素下都可以定义样式。通常情况是将样式作为资源定义在元素的Resources属性元素下,语法格式如下所示:

<object.Resources>

<Style TargetType="ControlTypeName" x:Key="StyleKey">

<Setter Property="AttributeName" Value="AttributeValue">

</Setter>

...

</Style>

</object.Resources>

在上述语法格式中:

  • TargetType属性,用于指定要设置样式的控件类型,属性值是派生自FrameworkElement或FrameworkContentElement的类型,如果试图将样式应用到与TargetType属性值不匹配的控件,就会发生异常。

例如,在Page.Resources属性元素下定义一个页面级别的按钮样式资源,样式资源的键为ButtonStyle,并在Setter元素中设置按钮的FontFamily属性、FontStyle属性和FontSize属性的值分别为楷体、Italic和10像素,对应的XAML代码片段如下所示:

<Page.Resources>

<Style TargetType="Button" x:Key="ButtonStyle">

<Setter Property="FontFamily" Value="楷体"/>

<Setter Property="FontStyle" Value="Italic"/>

<Setter Property="FontSize" Value="10"/>

</Style>

</Page.Resources>

在前面章节中提到,资源的定义位置不同,其有效使用范围也会不同,当把样式定义为资源时,它同样遵循这样的规则。在XAML应用程序中,样式作为资源时的作用范围包括如下情况:

  • 如果在Application.Resource属性元素中定义样式,则该样式可在应用程序中的任何位置使用。
  • 如果在Page.Resource属性元素中定义样式,则该样式只可在当前页面中使用。
  • 如果在控件的Resource属性元素中定义,则只对该控件的子孙控件有效,如Canvas控件。
  • 如果在Application.Resource属性元素和Page.Resource属性元素中同时定义了相同的样式,则在页面中定义的样式将覆盖Application.Resource属性元素中定义的样式。
  • 在Application.Resource属性元素中定义的样式将覆盖在单独的资源字典文件中定义的相同样式。

除了引用已经定义好的样式资源外,还可以在添加控件时通过定义Style属性元素直接为其定义样式,这时的样式仅作用于该控件本身。例如在向一个页面中添加一个按钮时,在Button.Style属性元素中定义Style元素,并在Style元素中设置按钮的文本颜色为红色,相应的XAML代码片段如下所示:

<Button Content="按钮" Width="100" Height="40">

<Button.Style>

<Style TargetType="Button">

<Setter Property="Foreground" Value="Red"/>

</Style>

</Button.Style>

</Button>

样式被定义成资源后,像其他资源一样,可以根据样式资源的键使用StaticResource标记扩展来引用相应的样式,然后赋值给元素的Style属性,语法格式如下所示:

<object Style="{StaticResource StyleKey}" ...> ... </object>

Win10系列:UWP界面布局基础9的更多相关文章

  1. Win10系列:UWP界面布局基础1

    随着技术的不断发展,使用者对应用程序的界面体验提出了更高的要求,为了应对越来越复杂的界面设计需求和有效的简化界面开发过程,微软公司在其应用程序的开发技术当中引入一套新的应用程序界面描述语言,这就是XA ...

  2. Win10系列:UWP界面布局基础8

    路由事件 XAML不仅继承了传统的事件处理方式,还引入了一个增强型事件处理机制:路由事件(RoutedEvent).路由事件和传统事件的不同是:路由事件允许一个对象触发事件后,可以同时拥有多个事件接收 ...

  3. Win10系列:UWP界面布局基础7

    2.附加属性 有一些XAML元素,其自身的属性大多是在其它的元素中声明和使用的,该元素本身却很少使用,这些在其他元素中声明和使用的属性被称为附加属性(Attached Properties).附加属性 ...

  4. Win10系列:UWP界面布局基础4

    类型转换 前面讲到过,在定义元素时可以通过Attributes特性方式为其设置属性并为属性赋值,在实际开发中所赋予的值可能和属性本身的数据类型不相符,这时XAML解析器就会使用类型转换器(Type C ...

  5. Win10系列:UWP界面布局基础2

    属性设置 在面向对象程序开发中,所提及的属性通常指的是对象的属性.在XAML代码中,定义元素时也可以为其设置属性,例如对于一个TextBox元素,有背景属性.宽度属性和高度属性等.为了满足实际应用的需 ...

  6. Win10系列:UWP界面布局基础12

    画刷 画刷(Brush)用于为图形元素填充颜色.在XAML中,画刷有许多属性,其中较常使用的是Fill属性和Stroke属性,Fill用于填充图形的背景色,而Stroke用于设置图形的线条颜色. 在实 ...

  7. Win10系列:UWP界面布局基础11

    样式继承 为了使样式便于维护及重复使用,可以在一个样式上引用其他的样式,这就是样式继承.样式继承的方法是:在Style元素的BasedOn属性上使用StaticResource标记扩展来引用被继承的样 ...

  8. Win10系列:UWP界面布局基础5

    (2)编写后台代码访问资源 下面通过一个例子来演示如何编写后台代码引用资源.新建一个Windows应用商店的空白应用程序项目,将其命名为AccessResourceApplication,打开项目下的 ...

  9. Win10系列:UWP界面布局基础3

    在实际项目开发中,为控件属性赋值时经常会遇到属性值在设计时处于未知状态,而只有在应用程序运行时才能获取到.这种情况下,直接赋值方法是无法满足的,可以使用XAML标记扩展(Markup Extensio ...

随机推荐

  1. python web.py实现简单的get和post请求

    使用web.py框架,实现简单的get和post请求: py文件名:mytest.py import web urls = ( '/', 'hello' ) app = web.application ...

  2. XML.libXml2_ZC

    1.字符串比较函数: xmlStrcmp(...) 这是大小写敏感的比较 xmlStrcasecmp(...) 这是大小写不敏感的比较(忽略字符串里面字符的大小写) 2.查找节点 2.1.循环 2.2 ...

  3. [osg][osgEarth][原]基于OE自定义自由飞行漫游器(第二版)

    在初级版上,进行新的漫游方式调整 头文件: #pragma once //南水之源 20180101 #include <osgGA/CameraManipulator> #include ...

  4. 2019热门JAVA面试问题

    收到不少读者反馈,说自己在应聘一些中大型互联网公司的Java工程师岗位时遇到了不少困惑. 这些同学说自己也做了精心准备,网上搜集了不少Java面试题,然而实际去互联网公司面试才发现,人家问的,和你准备 ...

  5. Linux性能测试工具-UnixBench

    ■下载路径: unixbench-5.1.2.tar.gz :http://soft.vpser.net/test/unixbench/ unixbench-5.1.3.tar.gz :http:// ...

  6. Mac python Tesseract 验证码识别

    Tesseract 简介 Tesseract(/'tesərækt/) 这个词的意思是"超立方体",指的是几何学里的四维标准方体,又称"正八胞体".不过这里要讲 ...

  7. 如何下载一个物种的全部EST序列 | NCBI | 表达序列标签

    EST:表达序列标签,expressed sequence tags . 顾名思义,很好理解,就是表达出来的序列,即从基因组DNA上表达出来的RNA,但是我们没法测序RNA,所以我们最终测的是表达序列 ...

  8. JS获取系统时间--JavaScript基础

    1.网页中实时显示当前时间 <!DOCTYPE html><html lang="en"><head> <meta charset=&qu ...

  9. 结合canvas和jquery.Jcrop.js裁切图像上传图片

    1.引入的外部资源: jquery.Jcrop.css.jquery.Jcrop.js.upimg.js 2.使用的页面元素 @* 选择照片 *@ <div class="line&q ...

  10. hihocoder-1415 后缀数组三·重复旋律3 两个字符串的最长公共子串

    把s1,s2拼接,求Height.相邻的Height判断左右串起点是否在两个串中,另外对Height和s1.length()-SA[i-1]取min. #include <iostream> ...