UWP 新手教程2——怎样实现自适应用户界面
系列文章
如上文所说的,布局面板依据可用的屏幕空间。指定界面元素的大小和位置。
比如StackPanel 会水平或垂直排列界面元素。Grid 布局与CSS 中的表格控件相似。可将各元素按单元排列。
新提供的 RelativePanel 即相对布局。各个元素之间存在相对关系,可用来创建自适应界面。当用户设备发生变化时,用户界面也会又一次排列又一次组织,而有了RelativePanel就省去了界面元素又一次排列。
如图所看到的,不管用户使用哪种设备。蓝色button始终放在文本框右側,并排放在黄色button顶部。

XAML 代码例如以下:
<RelativePanel>
<TextBox x:Name="textBox1" Text="textbox" Margin="5"/>
<Button x:Name="blueButton" Margin="5" Background="LightBlue" Content="ButtonRight"RelativePanel.RightOf="textBox1"/>
<Button x:Name="orangeButton" Margin="5" Background="Orange" Content="ButtonBelow"RelativePanel.RightOf="textBox1" RelativePanel.Below="blueButton"/>
</RelativePanel>
使用可视化状态触发器创建自适应UI
UWP 提供自适应可视化状态,可依据窗体大小来调整状态值。StateTriggers定义了一个阈值,达到阈值则触发可视化状态。下面演示样例了。当窗体大于720像素。wideView 状态则被触发,游戏面板又一次排列,如图所看到的:

当窗体小于720px。则narrowView视态被触发,由于wideView 触发器无法满足条件,NarrowView 状态则将Best-rated games 置于最底端。而且向左对齐,效果图例如以下:
XAML 代码例如以下:
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<VisualStateManager.VisualStateGroups>
<VisualStateGroup>
<VisualState x:Name="wideView">
<VisualState.StateTriggers>
<AdaptiveTrigger MinWindowWidth="720" />
</VisualState.StateTriggers>
<VisualState.Setters>
<Setter Target="best.(RelativePanel.RightOf)" Value="free"/>
<Setter Target="best.(RelativePanel.AlignTopWidth)" Value="free"/>
</VisualState.Setters>
</VisualState>
<VisualState x:Name="narrowView">
<VisualState.Setters>
<Setter Target="best.(RelativePanel.Below)" Value="paid"/>
<Setter Target="best.(RelativePanel.AlignLeftWithPanel)" Value="true"/>
</VisualState.Setters>
<VisualState.StateTriggers>
<AdaptiveTrigger MinWindowWidth="0" />
</VisualState.StateTriggers>
</VisualState>
</VisualStateGroup>
</VisualStateManager.VisualStateGroups>
...
</Grid>
创建UWP可使用的工具
创建App时。一般会明白目标设备,当须要在设备中预览App,能够使用VS中的Preview toolbar(预览工具箱)查看App,能够模拟不同的设备。如PC。TV,智能手机等。

自适应扩展
Windows 10 引入“缩放模型”的升级版,除了缩放矢量图之外。有一个统一的缩放因子集合,能够保证UI元素在不同的屏幕尺寸和分辨率下。界面元素大小的一致性。缩放因子能够兼容多种操作系统如iOS,Android等,资源科跨多平台共享。
通用输入处理
可使用通用控件创建通用Windows App来管理控制不同的输入模式,如鼠标,键盘。触摸笔,控制器等。
本文列举了下面API 来訪问输入:
CoreIndependentInputSource:是新添加的API。可将源输入,迁移到主线程或后台线程。
PointerPoint:统一了触摸,鼠标,笔数据。具有一致的接口和事件。
PointerDevice:是设备API,可支持查询设备支持的输入能力。
新的 InkCanvas XAML 控件和InkPresenter API 可訪问Stroke 数据
编写代码
VS中开发Windows10 项目支持多种开发语言。如C++,C#,VB以及JavaScript。也能够使用XAML,开发原生UI 用户体验。
调用API来实现目标设备族群
不管须要调用哪种API。你须要了解API适应的设备族群,是否满足您App开发的须要。例如以下面代码所看到的,设备族群是Universal:
Windows.UI.Core.SystemNavigationManager.GetForCurrentView().BackRequested += TestView_BackRequested;
当然也能够调用API ,在App中不实现。
这样的情况通常指当你的目标设备族群未在文档中标明,你能够调用此api,改动一些代码就可以。
使用ApiInformation 类编写自适应代码
编写自适应代码仅仅须要两步,一。确定须要调用的API。二,使用Windows.Foundation.Metadata.ApiInformation 类来測试API 。
可用于评估App是否执行良好。
假设想同一时候调用非常多API,能够使用ApiInformation.IsTypePresent 方法,例如以下:
// Note: Cache the value instead of querying it more than once.
bool isHardwareButtonsAPIPresent =
Windows.Foundation.Metadata.ApiInformation.IsTypePresent("Windows.Phone.UI.Input.HardwareButtons");
if (isHardwareButtonsAPIPresent)
{
Windows.Phone.UI.Input.HardwareButtons.CameraPressed +=
HardwareButtons_CameraPressed;
}
上述演示样例中HardwareButtons类实现了CameraPressed事件。由于该类成员有同样的信息需求。
用户体验
通用Windows App 可利用全部设备特征来呈现App.App可充分利用桌面设备的处理能力,平板电脑的自然交互方式,以及智能手机的便捷性和移动性等。
良好的设计从确定用户交互方式開始,同一时候满足App的功能性和外观。
用户体验非常重要直接影响了用户是否喜欢你的App,使用过程中是否愉悦或始终保持积极的情绪。而不受阻碍。
设计通用App更加须要注意影响用户体验的不同设备因素。

除了设备的交互方式不同,还须要利用跨平台的长处,如:
- 使用云计算来訪问不同设备资源
- 考虑如何支持从一种设备迁移到还有一种设备之上,并保持一致性。
- 使用导航设计指南来设计工作流程,使得App可兼容移动设备,较小的屏幕或较大的屏幕设备。
- 考虑特殊情况,较小的移动设备屏幕失效,也可能有一些功能区在固定式台式机上不起作用,而需在移动设备上才干执行。
- 考虑如何兼容多种输入形式
通过Dashboard提交通用 Windows 应用
利用新的通用的 Windows 开发者中心仪表板。能够在同一位置管理和提交全部面向 Windows 设备的应用。新功能简化了流程。并具有很多其它的控制权限。
在进行UWP开发时,还能够借助一些开发工具,有效提高开发效率。
ComponentOne Studio for UWP 是一套能够编写全部 UWP 平台应用的控件集,包含表格、报表、图表、仪表盘、组织图、地图、PDF、Excel、Word、日程安排、输入、导航等多个控件,有效的帮助开发过程。
UWP 新手教程2——怎样实现自适应用户界面的更多相关文章
- UWP 入门教程2——如何实现自适应用户界面
系列文章 UWP入门教程1——UWP的前世今生 如上文所说的,布局面板根据可用的屏幕空间,指定界面元素的大小和位置.例如StackPanel 会水平或垂直排列界面元素.Grid 布局与CSS 中的表格 ...
- UWP 新手教程1——UWP的前世今生
文件夹 引言 设备族群 UI 和通用输入模式 通用控件和布局面板 工具 自适应扩展 通用输入处理 引言 在本篇文章中,可以掌握下面知识: 设备族群,怎样决定目标设备 新的UI控件和新面板帮助你适应不同 ...
- 【OpenCV十六新手教程】OpenCV角检测Harris角点检测
本系列文章由@浅墨_毛星云 出品.转载请注明出处. 文章链接:http://blog.csdn.net/poem_qianmo/article/details/29356187 作者:毛星云(浅墨) ...
- Android基础新手教程——3.1 基于监听的事件处理机制
Android基础新手教程--3.1.1 基于监听的事件处理机制 标签(空格分隔): Android基础新手教程 本节引言: 第二章我们学习的是Android的UI控件,我们能够利用这些控件构成一个精 ...
- Android基础新手教程——4.1.1 Activity初学乍练
Android基础新手教程--4.1.1 Activity初学乍练 标签(空格分隔): Android基础新手教程 本节引言: 本节開始解说Android的四大组件之中的一个的Activity(活动) ...
- Android基础新手教程——1.2.1 使用Eclipse + ADT + SDK开发Android APP
Android基础新手教程--1.2.1 使用Eclipse + ADT + SDK开发Android APP 标签(空格分隔): Android基础新手教程 1.前言 这里我们有两条路能够选,直接使 ...
- Web项目的发布新手教程
ASP.NET服务器发布新手教程 ——本文仅赠予第一次做Web项目,需要发布的新手们,转载的请注明出处. 首先我们说一下我们的需要的一个环境.我使用的是Visual Studio 2010,版本.NE ...
- APP设计尺寸规范大全,APP界面设计新手教程【官方版】(转)
正值25学堂一周年之际,同时站长和APP设计同仁们在群里(APP界面设计 UI设计交流群,APP界面设计⑥群 APPUI设计③群58946771 APP设计资源⑤群 386032923欢迎大家加入交流 ...
- ROS探索总结(三)——ROS新手教程【转】
转自:http://blog.csdn.net/hcx25909/article/details/8811313 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] 一ROS的 ...
随机推荐
- 安装elk,日志采集系统
#elasticsearch安装 wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.0.0-linux ...
- Java使用Robot完成QQ轰炸机
效果 网上吵架吵不过别人怎么办?女朋友让你从1数到10000怎么办?想恶搞朋友怎么办?QQ轰炸机你值得拥有!(注:为了更好的学习编程,敲的练手项目,仅作学习使用) 自定义发送内容,自定义发送条数,&q ...
- Struts 2 动作注释 配置动作扩展 全局开关
动作注释package com.yiibai.user.action; import org.apache.struts2.convention.annotation.Action; import o ...
- SQL server游标基本结构
简单游标遍历数据: BEGIN DECLARE QZ_cursor CURSOR SCROLL FOR /*创建游标*/ SELECT NAME FROM USERINFO/*要遍历的数据*/ OPE ...
- div的显示隐藏方法汇总
JQuery DIV 动态隐藏和显示的方法 1. 如果在载入是隐藏: <head> <script language="javascript"> funct ...
- [BZOJ1663] [Usaco2006 Open]赶集(spfa最长路)
传送门 按照时间t排序 如果 t[i] + map[i][j] <= t[j],就在i和j之间连一条边 然后spfa找最长路 #include <queue> #include &l ...
- 【noip】noip201503求和(题解可能不完美,但绝对详细)
3. 求和 难度级别:B: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 题目描述 一条狭长的纸带被均匀划分出了n个格子,格子编号从1到n.每个格子 ...
- ArrayList构造函数有哪些
ArrayList 构造函数有(三种): public ArrayList(int initialCapacity) public ArrayList() public ArrayList(Colle ...
- Java中NIO、BIO、AIO相关概念及应用场景
1.同步阻塞IO(JAVA BIO):同步并阻塞,服务器实现模式为一个连接一个线程,即客户端有连接请求时,服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销,当然可以通 ...
- 软件包管理器(bzoj 4196)
Description Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖( ...