0

0

[UWP]XAML中的响应式布局技术

雪夜

雪夜

发布时间:2025-09-10 08:14:06

|

809人浏览过

|

来源于php中文网

原创

响应式布局的概念是一个页面适配多个终端及不同分辨率。在针对特定屏幕宽度优化应用 ui 时,我们将此称为创建响应式设计。wpf设计之初响应式设计的概念并不流行,那时候大部分网页设计师都按着宽度960像素的标准设计。到了uwp诞生的时候响应式布局已经很流行了,所以uwp提供了很多响应式布局的技术,这篇文章简单总结了一些响应式布局常用的技术,更完整的内容请看文章最后给出的参考网站。

1. 传统的XAML如何适配不同分辨率

所谓的传统,是指在响应式设计没流行前XAML就已经存在的应对不同分辨率的技术,毕竟桌面客户端常常也调整窗体的大小,有些人还同时使用两个不同分辨率的屏幕。以我的经验来说以下这些做法可以使UI有效应对分辨率改变:

使用相对定位代替决定定位使用
*
Auto
代替具体尺寸(除了间距)使用WrapPanel代替StackPanel不要忘记使用ScrollViewer

不同的DPI设定、不同的本地化字符串长度都可能使整个页面布局乱掉。而且和网页不同,WPF窗体默认没有提供ScrollViewer,所以千万不能忘记。在桌面客户端合理使用以上技术可以避免客户投诉。但UWP主打跨平台,它需要更先进(或者说,更激进)的技术。

2. 响应式设计技术

微软的官方文档介绍了UWP中响应式设计常用的6个技术,包括重新定位、调整大小、重新排列、显示/隐藏、替换和重新构建,具体可见以下网站:

[UWP]XAML中的响应式布局技术

响应式设计技术 - UWP apps Microsoft Docs

3. AdaptiveTrigger

AdaptiveTrigger是UWP中一种最常用的响应式布局技术。VisualStateManager用于管理UI的视觉状态,可以在UI上设置多个视觉状态,然后用

VisualStateManager.GoToState
在这些状态间切换,了解自定义控件的开发者对这点应该都不陌生。UWP提供了
AdaptiveTrigger
这个状态触发器,它以
MinWindowWidth
MinWindowHeight
未条件,根据页面宽度或高度进入设定好的不同状态(通常来说只使用
MinWindowWidth
,同时使用Height和Width做条件很容易产生混乱,而且大部分情况下响应式布局都会使用垂直滚动条所以对高度不关心。)在下面的示例中StackPanel默认使用垂直排列,当页面的宽度超过720像素时改为水平排列。

代码语言:javascript代码运行次数:0运行复制
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">    <VisualStateManager.VisualStateGroups>        <VisualStateGroup>            <VisualState>                <VisualState.StateTriggers>                    <!--VisualState to be triggered when window width is >=720 effective pixels.-->                    <AdaptiveTrigger MinWindowWidth="720" />                </VisualState.StateTriggers>                <VisualState.Setters>                    <Setter Target="myPanel.Orientation"                            Value="Horizontal" />                </VisualState.Setters>            </VisualState>        </VisualStateGroup>    </VisualStateManager.VisualStateGroups>    <StackPanel x:Name="myPanel"                Orientation="Vertical">        <TextBlock Text="This is a block of text. It is text block 1. "                   Style="{ThemeResource BodyTextBlockStyle}" />        <TextBlock Text="This is a block of text. It is text block 2. "                   Style="{ThemeResource BodyTextBlockStyle}" />        <TextBlock Text="This is a block of text. It is text block 3. "                   Style="{ThemeResource BodyTextBlockStyle}" />    </StackPanel></Grid>
[UWP]XAML中的响应式布局技术

使用AdaptiveTrigger可以做到前一节中提到的UWP中响应式设计常用的6个技术,除了UWP自带的AdaptiveTrigger,也可以自定义

StateTriggerBase
,这将在下一篇文章中介绍。

4. NavigationView

UWP中部分控件已经实现了响应式行为, 最典型的就是NavigationView。可以使用 PaneDisplayMode 属性配置不同的导航样式或显示模式。默认情况下,PaneDisplayMode 设置为 Auto。在 Auto 模式下,导航视图会进行自适应,在窗口狭窄时为 LeftMinimal,接下来为 LeftCompact,随后在窗口变宽时为 Left。

[UWP]XAML中的响应式布局技术

XAML Controls Gallery就是一个很好的结合

NavigationView
的响应式布局示例:

[UWP]XAML中的响应式布局技术
5. 定制布局

如果

AdaptiveTrigger
需要设置的属性太多,倒不如直接切换UI,最简单的做法是整个显示/隐藏,例如这样:

代码语言:javascript代码运行次数:0运行复制
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">    <VisualStateManager.VisualStateGroups>        <VisualStateGroup>            <VisualState>                <VisualState.StateTriggers>                    <AdaptiveTrigger MinWindowWidth="720" />                </VisualState.StateTriggers>                <VisualState.Setters>                    <Setter Target="NormalView.Visibility"                            Value="Collapsed" />                    <Setter Target="LargelView.Visibility"                            Value="Visible" />                </VisualState.Setters>            </VisualState>        </VisualStateGroup>    </VisualStateManager.VisualStateGroups>    <Grid x:Name="NormalView">        <!--some xmal-->    </Grid>    <Grid x:Name="LargelView"          Visibility="Collapsed">        <!--some xmal-->    </Grid></Grid>

这种时候MVVM的优势就体现出来了,因为VIEW和VIEWMODEL解耦了,VIEW随便换,而且整个UI显示隐藏说不定比多个小模块独自改变性能更好。说到性能,UWP的很多场景都为已经死了多年的WindowsWobile考虑了性能,更不用说现在的桌面平台,所以做UWP不需要太过介意性能,尤其是已经在WPF上培养出小心翼翼的习惯的开发者,UWP的性能问题等真的出现了再说。

除了使用显示隐藏,UWP还可以使用限定符名称指定CodeBehind对应的XAML文件,这有点像是自适应应用的话题。使用格式如下:

[pageName] .DeviceFamily- [qualifierString] .xaml

AI Web Designer
AI Web Designer

AI网页设计师,快速生成个性化的网站设计

下载
[UWP]XAML中的响应式布局技术

如果要用在文件夹,格式如下:

DeviceFamily- [qualifierString]

[UWP]XAML中的响应式布局技术

要更灵活些,可以根据条件跳转到不同的页面:

代码语言:javascript代码运行次数:0运行复制
if (Windows.System.Profile.AnalyticsInfo.VersionInfo.DeviceFamily == "Windows.Tablet"){    rootFrame.Navigate(typeof(MainPage_Tablet), e.Arguments);}else{    rootFrame.Navigate(typeof(MainPage), e.Arguments);}

虽然示例代码这样写,其实现在除了桌面几乎没有其它平台了,所以大部分情况下还是根据当前尺寸跳转。

6. compact size

正如前面所说,既然已经不需要其它平台,那UWP的响应式布局大部分情况都是为了应对尺寸问题,Windows UI Library还提供了一个紧凑的主题用于小尺寸UI(需要安装Microsoft.UI.Xaml的Nuget包):

代码语言:javascript代码运行次数:0运行复制
<Page.Resources>    <ResourceDictionary Source="ms-appx:///Microsoft.UI.Xaml/DensityStyles/Compact.xaml" /></Page.Resources>
代码语言:javascript代码运行次数:0运行复制
private void Standard_Checked(object sender, RoutedEventArgs e){    ContentFrame.Navigate(typeof(SampleStandardSizingPage), null, new SuppressNavigationTransitionInfo());}private void Compact_Checked(object sender, RoutedEventArgs e){    ContentFrame.Navigate(typeof(SampleCompactSizingPage), null, new SuppressNavigationTransitionInfo());}
[UWP]XAML中的响应式布局技术
7. ViewBox

ViewBox可以根据自身大小放大或缩小它的Content元素,某些情况下它是WPF和UWP平台的终极响应式设计解决方案,因为WPF/UWP元素都是矢量元素所以大部分元素都可以无损缩放(当然会有像素对不齐的情况),所以偷懒的话就可以使用ViewBox:

[UWP]XAML中的响应式布局技术
8. 参考

采用 XAML 的响应式布局 - UWP apps Microsoft Docs

响应式设计技术 - UWP apps Microsoft Docs

响应式设计的屏幕大小和断点 - UWP apps Microsoft Docs

导航视图 - UWP apps Microsoft Docs

AdaptiveTrigger Class (Windows.UI.Xaml) - Windows UWP applications Microsoft Docs

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1568

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

651

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1228

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1204

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

193

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

131

2025.08.07

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号