老周在上一篇文章中介绍过了自适应磁贴的基本结构,以及给大家演示了一些例子。

本文老周给大伙伴们说说自适应磁贴的另一个特点——分组呈现。

当磁贴的内容被分组后,每个组中的内容就会被视为一个整体。比如某磁贴在更新时定义了其内容包含有两个组,有些设备(比如手机、上世纪70年代的电脑、小霸王学习机等)的分辨率较低,磁贴不能显示两个组的信息,于是就会把第一组的内容整个显示出来,第二组信息就被忽略。就算空间不够,连第一组的内容都显示不全,然而一个组会被视为一个整体,不管空间够不够,第一组都要全部呈现。如果空间相当充足,当然两个分组的内容都会显示出来。

分组的方法是在binding元素下使用1个或n个group元素,每个group元素代表一组。对于单个group元素而言,它的子元素必须是subgroup(子组)元素,数量可以为n个,但至少你得有一个subgroup元素。正因为如此,group元素下面最少最少都会有一个subgroup元素。

先给大伙看一个例子。

<tile>
<visual>
<binding template="TileMedium">
<group>
<subgroup>
<text hint-style="subtitle">第一组</text>
<text>今天天气真好。</text>
</subgroup>
</group>
<group>
<subgroup>
<text hint-style="subtitle">第二组</text>
<text>天上的白云真白。</text>
</subgroup>
</group>
</binding>
</visual>
</tile>

上面定义的这个磁贴,分为两个组,每个组中都有两个text元素来呈现文本,虽然group中不打算设置子分组,但必须有一个subgroup,因为group元素的子元素必须为subgroup

得到的磁贴如下图所示。

在一个group中,实际上一个subgroup可以理解为一列,因为subgroup元素有一个hint-weight属性,这个属性用来定义该subgroup的比重,这个比重实际上是该subgroup的宽度所占的比例。所以说,subgroup其实是用来定义列的。

大家应该会用XAML中的Grid控件,大家不妨想想,Grid在划分行和列的时候,是不是有一个按比例划分的方法。比如第一行为1*,第二行为2*,那就是把行的所有空间均分为3等份,第一行占1/3,第二行占2/3。

hint-weight的原理是一样的,但是,它不用写“*”,比如,一个组中有两个subgroup,每个subgroup的hint-weight的值都为1,那么每个subgroup的宽度将相等,各占50%。

再如,三个subgroup,设置它们的hint-weight属性。第一个为2,第二个为1,第三个为3,即把所有空间平均分为6份,第一列占2/6,第二列占1/6,第三列占3/6。

请看下面的例子:

<tile>
<visual>
<binding template="TileWide">
<group>
<subgroup hint-weight="1">
<image src="ms-appx:///Assets/images/关羽.png" hint-removeMargin="true"/>
<text hint-align="center" hint-style="body">关羽</text>
</subgroup>
<subgroup hint-weight="1">
<image src="ms-appx:///Assets/images/张飞.png" hint-removeMargin="true"/>
<text hint-align="center" hint-style="body">张飞</text>
</subgroup>
<subgroup hint-weight="1">
<image src="ms-appx:///Assets/images/曹操.png" hint-removeMargin="true"/>
<text hint-align="center" hint-style="body">曹操</text>
</subgroup>
<subgroup hint-weight="1">
<image src="ms-appx:///Assets/images/孙坚.png" hint-removeMargin="true"/>
<text hint-align="center" hint-style="body">孙坚</text>
</subgroup>
<subgroup hint-weight="1">
<image src="ms-appx:///Assets/images/袁绍.png" hint-removeMargin="true"/>
<text hint-align="center" hint-style="body">袁绍</text>
</subgroup>
</group>
</binding>
</visual>
</tile>

每个subgroup的hint-weight的值都为1,表明磁贴将一个组的水平空间平分为5列,每列显示图像和文本。
大家注意到,这里image元素设置了一个hint-removeMargin属性为true,表示删除图像的边距。如果为false,表示保留边距。默认情况下,图像周围的边距为8,由于这个磁贴内容多,比较拥挤,所以要去掉图像默认的边距。

磁贴更新后如下图所示。

再看下面一例:

<tile>
<visual>
<binding template="TileWide">
<group>
<subgroup hint-weight="1">
<image src="ms-appx:///Assets/images/曹操.png" hint-removeMargin="true" />
</subgroup>
<subgroup hint-weight="5">
<image src="ms-appx:///Assets/images/袁绍.png" hint-removeMargin="true" />
</subgroup>
<subgroup hint-weight="3">
<image src="ms-appx:///Assets/images/孙坚.png" hint-removeMargin="true" />
</subgroup>
</group>
</binding>
</visual>
</tile>

一个分组中有三个subgroup,即三列,所有空间被划分为9等份,第一列占其中1份,第二列占5份,第三列占3份。
磁贴更新后如下图。

另外,hint-weight属性还可以使用百分比来划分列,方法是指定的所有subgroup的weight值加起来刚好等于100,这时候就会被识别为百分比。

看例子。

<tile>
<visual>
<binding template="TileWide">
<group>
<subgroup hint-weight="70">
<image src="ms-appx:///Assets/images/张飞.png" hint-removeMargin="true" />
</subgroup>
<subgroup hint-weight="30">
<image src="ms-appx:///Assets/images/袁绍.png" hint-removeMargin="true" />
</subgroup>
</group>
</binding>
</visual>
</tile>

第一列的比重为70,第二列的比重为30,加起来正好是100,所以识别为百分比。
磁贴更新后的结果如下图:

好了,本文的牛皮就吹到这里。

示例源代码下载

【Win10应用开发】自适应磁贴中的分组的更多相关文章

  1. Win 10 开发中Adaptive磁贴模板的XML文档结构,Win10 应用开发中自适应Toast通知的XML文档结构

    分享两篇Win 10应用开发的XML文档结构:Win 10 开发中Adaptive磁贴模板的XML文档结构,Win10 应用开发中自适应Toast通知的XML文档结构. Win 10 开发中Adapt ...

  2. Win10 UWP开发系列:使用VS2015 Update2+ionic开发第一个Cordova App

    安装VS2015 Update2的过程是非常曲折的.还好经过不懈的努力,终于折腾成功了. 如果开发Cordova项目的话,推荐大家用一下ionic这个框架,效果还不错.对于Cordova.PhoneG ...

  3. Win10 UWP开发系列:实现Master/Detail布局

    在开发XX新闻的过程中,UI部分使用了Master/Detail(大纲/细节)布局样式.Win10系统中的邮件App就是这种样式,左侧一个列表,右侧是详情页面.关于这种 样式的说明可参看MSDN文档: ...

  4. 分享 Ionic 开发 Hybrid App 中遇到的问题以及后期发布 iOS/Android 的方方面面

    此篇文章主要整理了最近在使用 Ionic 开发 Hybrid App 过程中遇到的一些疑难点以及后期发布生成 iOS 和 Android 版本过程中的种种问题. 文章目录 Ionic 简介和项目需求介 ...

  5. Win10/UWP开发—使用Cortana语音与App后台Service交互

    上篇文章中我们介绍了使用Cortana调用前台App,不熟悉的移步到:Win10/UWP开发—使用Cortana语音指令与App的前台交互,这篇我们讲讲如何使用Cortana调用App的后台任务,相比 ...

  6. C#-MVC开发微信应用(6)--用户分组信息管理

    让我们继续深入探索这方面的技术,为了更好的应用起来,专心做好底层的技术开发.本篇继续上一篇的介绍,主要介绍分组管理方面的开发应用,这篇的内容和上一篇,作为一个完整的用户信息和分组信息管理的组合. 1. ...

  7. UWP Windows10开发更新磁贴和动态更新磁贴

    下面将介绍两种方式如何在windows10 uwp开发中如何更新应用磁贴: 实际上windows的磁贴就是用xml实现的,你只需要创建相应格式的xml就可以实现动态磁贴了 一,手动更新磁贴 二,轮询更 ...

  8. openresty开发系列24--openresty中lua的引入及使用

    openresty开发系列24--openresty中lua的引入及使用 openresty 引入 lua 一)openresty中nginx引入lua方式 1)xxx_by_lua   ---> ...

  9. 前端开发:Javascript中的数组,常用方法解析

    前端开发:Javascript中的数组,常用方法解析 前言 Array是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array ...

随机推荐

  1. RNN求解过程推导与实现

    RNN求解过程推导与实现 RNN LSTM BPTT matlab code opencv code BPTT,Back Propagation Through Time. 首先来看看怎么处理RNN. ...

  2. Codeforces 721E Road to Home

    题意 输入第一行有4个数,分别为\(L,n,p,t\),分别表示总长度为\(L\)的路,中间有\(n\)个互不相交的区间,现在要用长度为\(p\)的小木棒从左往右铺路(木棒不能被折断,也不能有重叠,且 ...

  3. android 开发 gradle 自己会容易混淆的东西

    使用intellij idea 开发android ,关于 gradle 和 android gradle plugin 容易混淆地方,做下记录: 一. build.gradle 文件有两个地方存在, ...

  4. 大BOSS随时都会到来

    郑昀(微博:http://weibo.com/yunzheng) 去年在上市前后,我不止一次跟大家说过如下内容: 我们这帮兄弟第一精通业务,第二有丰富的战斗经验和规范,你们都是中流砥柱,都要带兵打仗. ...

  5. php和ajax 服务器端做轮询推送(定义)

    基于HTTP的长连接,是一种通过长轮询方式实现"服务器推"的技术,它弥补了HTTP简单的请求应答模式的不足,极大地增强了程序的实时性和交互性. 一.什么是长连接.长轮询? 用通俗易 ...

  6. 通读AFN②--AFN的上传和下载功能分析、SessionTask及相应的session代理方法的使用细节

    这一部分主要研究AFN的上传和下载功能,中间涉及到各种NSURLSessionTask的一些创建的解析和HTTPSessionManager对RESTful风格的web应用的支持,同时会穿插一点NSU ...

  7. codeforces 360 D - Remainders Game

    D - Remainders Game Description Today Pari and Arya are playing a game called Remainders. Pari choos ...

  8. thrift 服务端linux C ++ 与客户端 windows python 环境配置(thrift 自带tutorial为例)

    关于Thrift文档化的确是做的不好.摸索了很久才终于把跨linux与windows跨C++与python语言的配置成功完成.以下是步骤: 1)                 Linux下环境配置 ...

  9. [译]Modern Core Graphics with Swift系列

    第一篇 想象一下你已经完成了你的app并且运行的很好,但是界面看上去太土,你可以在PS里面画好多不同尺寸的自定义控件,Apple并没有4x的retina屏幕. 或者你已经未雨绸缪,在代码中使用Core ...

  10. PHP DOS漏洞的新利用:CVE-2015-4024 Reviewed

    1.     背景介绍 今天我们想从2015.04.03的一个PHP远程dos漏洞(CVE-2015-4024)说起.技术细节见如下链接,https://bugs.php.net/bug.php?id ...