文档章节

Xamarin XAML语言教程构建ControlTemplate控件模板

大学霸
 大学霸
发布于 2017/07/12 13:31
字数 675
阅读 15
收藏 0

Xamarin XAML语言教程构建ControlTemplate控件模板

控件模板ControlTemplate

ControlTemplate是从Xamarin.Forms 2.1.0开始被引入的。ControlTemplate被称为控件模板,它将页面的外观和内容进行了分离,从而让开发者可以更方便的创建基于主题的页面。本节将讲解控件模板相关的内容,其中包括构建控件模板以及控件模板的模板绑定等内容。

构建控件模板

控件模板可以在应用程序级别中构建,也可以在页面级别中构建。以下将对这两个构建方式进行讲解。

1.应用程序级别构建

如果开发者要在应用程序级别构建控件模板,首先必须将ResourceDictionary添加到App类中,然后在ResourceDictionary中实现模板的构建。其语法形式如下:

 

  • <Application>
  • <Application.Resources>
  • <ResourceDictionary>
  • <ControlTemplate x:Key="KeyName">
  • ……
  • </ControlTemplate>
  • </ResourceDictionary>
  • </Application.Resources>
  • </Application>

其中,KeyName指定一个字典键,用来指代控件模板。

构建好模板后,我们需要将这个模板控件显示出来,此时就需要可以模板化的视图。在这些视图中都会存在一个ControlTemplate属性。将此属性设置为创建的控件模板后,控件模板就可以进行显示了。在Xamarin.Forms目前只有4个视图包含ControlTemplate属性,这4个视图如下:

 

  • ContentPage:内容页面
  • ContentView:内容视图
  • TemplatedPage:模板页面
  • TemplatedView:模板视图

【示例14-3:ControlTemplateDemo】下面将在应用程序级别中构建控件模板,实现应用程序主题的切换。具体的操作步骤如下:

(1)打开App.xaml文件,编写代码,实现在应用程序级别中构建控件模板,代码如下:

 

  • <?xml version="1.0" encoding="utf-8" ?>
  • <Application xmlns="http://xamarin.com/schemas/2014/forms"
  •              xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
  •              x:Class="ControlTemplateDemo.App">
  •   <Application.Resources>
  • <ResourceDictionary>
  • <!--构建控件模板-->
  •       <ControlTemplate x:Key="TealTemplate">
  •         <Grid>
  •           <Grid.RowDefinitions>
  •             <RowDefinition Height="0.1*" />
  •             <RowDefinition Height="0.8*" />
  •             <RowDefinition Height="0.1*" />
  •           </Grid.RowDefinitions>
  •           <Grid.ColumnDefinitions>
  •             <ColumnDefinition Width="0.05*" />
  •             <ColumnDefinition Width="0.95*" />
  •           </Grid.ColumnDefinitions>
  •           <BoxView Grid.ColumnSpan="2"
  •                    Color="Teal" />
  •           <Label Grid.Column="1"
  •                  Text="Knowledge is power."
  •                  TextColor="White"
  •                  FontSize="18"
  •                  VerticalOptions="Center" />
  •           <ContentPresenter Grid.Row="1"
  •                             Grid.ColumnSpan="2" />
  •           <BoxView Grid.Row="2"
  •                    Grid.ColumnSpan="2"
  •                    Color="Teal" />
  •           <Label Grid.Row="2"
  •                  Grid.Column="1"
  •                  Text="Xamarin.Froms XAML"
  •                  TextColor="White"
  •                  FontSize="18"
  •                 VerticalOptions="Center" />
  •         </Grid>
  •       </ControlTemplate>
  • <!--构建控件模板-->
  •       <ControlTemplate x:Key="AquaTemplate">
  •                    <Grid>
  •                             <Grid.RowDefinitions>
  •                                      <RowDefinition Height="0.1*" />
  •                                      <RowDefinition Height="0.8*" />
  •                                      <RowDefinition Height="0.1*" />
  •                             </Grid.RowDefinitions>
  •                             <Grid.ColumnDefinitions>
  •                                      <ColumnDefinition Width="0.05*" />
  •                                      <ColumnDefinition Width="0.95*" />
  •                             </Grid.ColumnDefinitions>
  •                             <BoxView Grid.ColumnSpan="2"
  •                        Color="Aqua" />
  •                             <Label Grid.Column="1"
  •                     Text="Knowledge is power."
  •                     TextColor="Blue"
  •                     FontSize="18"
  •                     VerticalOptions="Center" />
  •                             <ContentPresenter Grid.Row="1"
  •                               Grid.ColumnSpan="2" />
  •                             <BoxView Grid.Row="2"
  •                         Grid.ColumnSpan="2"
  •                         Color="Aqua" />
  •                             <Label Grid.Row="2"
  •                      Grid.Column="1"
  •                      Text="Xamarin.Froms XAML"
  •                      TextColor="Blue"
  •                      FontSize="18"
  •                      VerticalOptions="Center" />
  •                    </Grid>
  •            </ControlTemplate>
  •     </ResourceDictionary>
  •   </Application.Resources>
  • </Application>

在此代码中,我们构建了两个控件模板,一个为TealTemplate控件模板,另一为AquaTemplate控件模板。

© 著作权归作者所有

共有 人打赏支持
大学霸
粉丝 257
博文 872
码字总数 544782
作品 0
东城
程序员
私信 提问
XamarinForms教程构建XamarinForms开发环境

构建XamarinForms开发环境 所谓Xamarin.Forms的开发环境,就是指在基本硬件和数字软件的基础上,为支持系统软件和应用软件的工程化开发和维护而使用的一组软件,简称SDE。对于任何的程序来说...

大学霸
2016/01/21
41
0
WPF -- 控件模板 (ItemsPanelTemplate)(二)

前面介绍了控件模板的应用和Style的差异,并以ControlTemplate举例,接下来举一个ItemsPanelTemplate的例子: 比如我现在要写一个自定义MessageBox自定义控件,当不同的message类型时会显示不...

qq_23018459
04/11
0
0
2015年值得关注的8款用户界面新品

1.Qt 下载地址 | 中文教程连载 Qt 是目前最先进、最完整的跨平台C++开发工具。它不仅完全实现了一次编写,所有平台无差别运行,更提供了几乎所有开发过程中需要用到的工具。如今,Qt已被运用...

百mumu
2015/12/23
99
0
Xamarin 学习笔记 - Page(页面)

本文翻译自CodeProject文章:https://www.codeproject.com/Articles/1226447/Xamarin-Notes-Xamarin-Forms-Pages 转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和...

葡萄城技术团队
08/02
0
0
盘点2015年值得关注的8款跨平台开发工具(界面类)

1.Qt 下载地址 | 中文教程连载 Qt 是目前最先进、最完整的跨平台C++开发工具。它不仅完全实现了一次编写,所有平台无差别运行,更提供了几乎所有开发过程中需要用到的工具。如今,Qt已被运用...

百mumu
2016/01/20
109
0

没有更多内容

加载失败,请刷新页面

加载更多

Redis分布式锁的实现原理看这篇就够了~

一、写在前面 现在面试,一般都会聊聊分布式系统这块的东西。通常面试官都会从服务框架(Spring Cloud、Dubbo)聊起,一路聊到分布式事务、分布式锁、ZooKeeper等知识。 所以咱们这篇文章就来...

Java干货分享
23分钟前
2
0
Actor并发编程模型浅析

一.Actor模型介绍 在单核 CPU 发展已经达到一个瓶颈的今天,要增加硬件的速度更多的是增加 CPU 核的数目。而针对这种情况,要使我们的程序运行效率提高,那么也应该从并发方面入手。传统的多...

终日而思一
23分钟前
1
0
利用arthas实时定位线上性能问题

0. 场景及需求 我们线上5台solr读服务器,配置一样,但是相同的请求,其中一台响应时间明显比其他4台慢,我们想通过arthas来定位具体哪里执行慢。 1. arthas介绍 阿里开源的java调试工具,能...

andersChow
24分钟前
2
0
docker 启动策略

Docker run的时候使用--restart参数 no - Container不重启 on-failure - container推出状态非0时重启 always - 始终重启 例如: docker run --restart=always -itd -p 2222:22 -p 3306:3306......

colin_86
25分钟前
1
0
Thinkphp5开发OA办公系统之招聘申请

开发运行环境: 神舟笔记本K650D-G6D1 i5-6400 GTX950M Windows 10 专业版 Nginx 或 Apache Web 服务器软件 MySQL5.7.x 数据库 PHP7.1.0 PHPStrom 2017 PowerDesigner 16.5 Axure RP8 原型设......

乐兔CRM
27分钟前
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部