WPF常见容器全方位介绍

在这里插入图片描述

Windows Presentation Foundation (WPF) 是微软的一种用于构建Windows桌面应用程序的UI框架。WPF的布局系统基于容器,帮助开发者以灵活、响应的方式组织用户界面 (UI) 元素。本篇文章将详细介绍WPF中几种常见的容器,包括GridStackPanelWrapPanelDockPanelCanvasUniformGrid,并结合代码举例进行说明。

1. WPF布局基础

在这里插入图片描述

WPF布局系统通过安排子元素来进行尺寸调整和排列。布局由两个步骤组成:

  1. 测量阶段:确定子元素的所需尺寸。
  2. 排列阶段:确定每个子元素的位置和实际呈现尺寸。

了解WPF的布局过程对于高效使用容器和优化性能至关重要。

2. Grid

在这里插入图片描述

Grid是WPF中最强大的布局容器之一。它允许布局通过行和列进行结构化划分,类似于HTML中的表格。

特点

  • 支持行和列的定义。
  • 可以通过RowSpanColumnSpan属性跨行跨列。

示例

<Grid><Grid.RowDefinitions><RowDefinition Height="Auto"/><RowDefinition Height="*"/></Grid.RowDefinitions><Grid.ColumnDefinitions><ColumnDefinition Width="*"/><ColumnDefinition Width="2*"/></Grid.ColumnDefinitions><Button Grid.Row="0" Grid.Column="0" Content="Button 1"/><Button Grid.Row="0" Grid.Column="1" Content="Button 2"/><Button Grid.Row="1" Grid.Column="0" Grid.ColumnSpan="2" Content="Button 3"/>
</Grid>

在这个例子中,网格有两个行和两列,第三个按钮在两列上跨越。

3. StackPanel

StackPanel是一个简单的面板,它将子元素按照单一方向(水平或垂直)排列。
在这里插入图片描述

特点

  • 子元素的方向可以是水平或垂直。
  • 子元素在指定方向上按顺序排列。

示例

<StackPanel Orientation="Vertical"><TextBlock Text="First line" /><TextBlock Text="Second line" /><TextBlock Text="Third line" />
</StackPanel>

此示例中,文本块被竖直堆叠。

4. WrapPanel

在这里插入图片描述

WrapPanel类似于StackPanel,但它的子元素如果在一行中排列不下就会自动换行。

特点

  • 自动换行。
  • 可以指定方向(水平或垂直)。

示例

<WrapPanel Orientation="Horizontal"><Button Content="Button 1" Width="100" /><Button Content="Button 2" Width="100" /><Button Content="Button 3" Width="100" /><Button Content="Button 4" Width="100" /><Button Content="Button 5" Width="100" />
</WrapPanel>

在这里,按钮水平排列,当窗体宽度不足时会换到下一行。

5. DockPanel

DockPanel允许将子元素“停靠”到面板的边缘,未标记Dock的元素将占据剩余的空间。
在这里插入图片描述

特点

  • 可以设置Dock属性(如LeftRightTopBottom)。
  • 最后一个子元素默认会填充剩余空间。

示例

<DockPanel><TextBlock DockPanel.Dock="Top" Text="Header" /><Button DockPanel.Dock="Bottom" Content="Footer" /><TextBlock Text="Main Content" />
</DockPanel>

文本块和按钮停靠在顶部和底部,中间的文本块填满剩余空间。

6. Canvas

在这里插入图片描述

Canvas是WPF中最简单但灵活性极高的容器,它允许绝对定位子元素。

特点

  • 允许直接设置每个元素的坐标。
  • 不会自动调整子元素的尺寸和位置。

示例

<Canvas><Button Canvas.Left="50" Canvas.Top="20" Content="Absolute Positioned" />
</Canvas>

此例中,按钮被放置在距左50、距上20的位置。

7. UniformGrid

UniformGrid类似于Grid,但它将所有单元格的大小设置为相同。

特点

  • 所有单元格大小相同。
  • 根据设置的行和列自动排列子元素。

示例

<UniformGrid Rows="2" Columns="2"><Button Content="1" /><Button Content="2" /><Button Content="3" /><Button Content="4" />
</UniformGrid>

此示例创建一个2x2的网格,每个单元格大小相同。

8. 综合实例

下面是一个更复杂的结合多种容器的示例:

<Grid><Grid.RowDefinitions><RowDefinition Height="Auto"/><RowDefinition Height="*"/><RowDefinition Height="Auto"/></Grid.RowDefinitions><DockPanel Grid.Row="0"><TextBlock DockPanel.Dock="Left" Text="Menu" Margin="5" /><TextBlock Text="Title" Margin="5" HorizontalAlignment="Center"/></DockPanel><WrapPanel Grid.Row="1" Margin="10"><Button Content="Home" Width="100" /><Button Content="Profile" Width="100" /><Button Content="Settings" Width="100" /></WrapPanel><StatusBar Grid.Row="2"><StatusBarItem Content="Ready" /><StatusBarItem Content="{Binding CurrentTime, UpdateSourceTrigger=PropertyChanged}" /></StatusBar>
</Grid>

该示例展示了如何使用Grid布局整个窗口,并使用DockPanel创建一个标题栏,WrapPanel放置在中间用于主导航,StatusBar则放在底部。

9. 布局优化建议

  • 尽量减少嵌套:过多的嵌套会增加布局计算复杂度。
  • 使用虚拟化:在显示大量数据时,启用虚拟化有助于提高性能。
  • 自动布局:尽量使用自动布局而非绝对定位以保障响应式。

10. 结束语

通过对这些WPF容器的深入理解和实践,开发者可以创建灵活、美观的UI,适应不同尺寸、分辨率的设备。WPF的强大之处在于它不仅提供了多种布局选择,还能通过XAML实现高度可定制化的界面设计。

希望本文的详细介绍能帮助您更好地理解和应用WPF布局容器,在项目中构建出色的用户界面。

print("拥抱新技术才是王道!")

关注我,不迷路,共学习,同进步

关注我,不迷路,共学习,同进步

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/56849.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Aspose.PDF功能演示:使用 JavaScript 从 PDF 中提取文本

在数据提取、业务文档自动化和文本挖掘方面&#xff0c;使用 JavaScript 从PDF中提取文本非常有用。它允许开发人员自动执行从 PDF 收集信息的过程&#xff0c;从而显著提高处理大量文档的生产力和效率。在这篇博文中&#xff0c;我们将学习如何使用 JavaScript 从 PDF 中提取文…

python-django-mysql原生sql增删改查搭建搭建web项目

先看我本地的项目结构 1 设置虚拟环境 python -m venv venv .\venv\Scripts\activate 2 在虚拟环境中安装Django 执行 pip install -r requirements.txt asgiref3.8.1 backports.zoneinfo0.2.1 Django3.2 mysqlclient2.2.4 pytz2024.2 sqlparse0.5.1 typing-extensions4.1…

数据结构--二叉树随记

二叉树主要分为四类&#xff1a;满二叉树、完全二叉树、二叉搜索树、平衡二叉搜索树。 高度,深度,层 满二叉树 满二叉树就是每一层节点都是满的&#xff0c;整棵树像一个正三角形&#xff1a; 满二叉树有个优势&#xff0c;就是它的节点个数很好算。假设深度为 h&#xff0c;那…

讲一讲Redis五大数据类型的底层实现

讲一讲Redis五大数据类型的底层实现 Redis五大数据类型的底层实现 Redis的五大数据类型分别是字符串&#xff08;String&#xff09;、列表&#xff08;List&#xff09;、哈希&#xff08;Hash&#xff09;、集合&#xff08;Set&#xff09;和有序集合&#xff08;Zset&…

Fake Location 限制解除(运动世界校园,keep......)

一觉起来成绩还是正常的&#xff0c;运动世界校园的审核是非常严格的&#xff0c;因为在这之前&#xff0c;我帮助同学登入别的账号进行跑步&#xff0c;发现过来几天全被检测到了异常,成绩也是直接无效了哈&#xff0c;我们今天再搞一个关于keep的&#xff0c;因为当时关于kee…

pikachu靶场SSRF-curl测试报告

目录 一、测试环境 1、系统环境 2、使用工具/软件 二、测试目的 三、操作过程 1、实现ssrf攻击 四、源代码分析 五、结论 一、测试环境 1、系统环境 渗透机&#xff1a;本机(127.0.0.1) 靶 机&#xff1a;本机(127.0.0.1) 2、使用工具/软件 测试网址&#xff1a;…

DNS 与 ICMP

DNS(Domain Name System)快速了解 DNS 是一整套从域名映射到 IP 的系统 DNS 背景 TCP/IP 中使用 IP 地址和端口号来确定网络上的一台主机的一个程序. 但是 IP 地址不方便记忆 于是人们发明了一种叫主机名的东西, 是一个字符串, 并且使用 hosts 文件来描述主机 名和 IP 地…

微信开发者工具:音乐小程序报错

报错信息 GET http://localhost:3000/1.mp3 net::ERR CONNECTION REFUSED (env: Windows,mp,1.06.2303220;lib:3.6.0) 原因&#xff1a;小程序没有直接获取本地文件&#xff0c;为了提高访问速度&#xff0c;而采用放到网络服务器中网络访问的方式获取文件内容 解决办法&#…

JMeter如何设置HTTP代理服务器?

1、 2、添加线程组 3、设置HTTP代理服务器&#xff0c;目标控制器选择“测试计划>线程组” 过滤掉不需要的信息 4、设置电脑手动代理 5、点击启动&#xff0c;在浏览器操作就可以了

OpenCV-物体跟踪

文章目录 一、物体跟踪的定义二、OpenCV中的物体跟踪算法三、OpenCV物体跟踪的实现步骤四、代码实现五、注意事项 OpenCV是一个开源的计算机视觉和机器学习软件库&#xff0c;它提供了丰富的功能来实现物体跟踪。以下是对OpenCV中物体跟踪的详细解释&#xff1a; 一、物体跟踪的…

Ubuntu16.04安装openssl库

Ubuntu16.04安装openssl库 Chapter1 Ubuntu16.04安装openssl库 Chapter1 Ubuntu16.04安装openssl库 原文链接&#xff1a;https://blog.csdn.net/weixin_36584476/article/details/107321893 记录一下省得忘了 1.首先去openssl官网下载源码www.openssl.org/source/&#xff0…

进程同步、互斥

进程同步、互斥的基本概念 系统中的某些资源&#xff0c;虽然可以提供给多个进程使用&#xff0c;但一个时间段内只允许一个进程访问该资源。 我们把一个时间段内只允许一个进程使用的资源称为临界资源。许多物理设备&#xff08;比如摄像头、打印机&#xff09;都属于临界资源…

python爬虫加解密分析及实现

第一种&#xff1a; 1、找到加密的接口地址&#xff0c;通过加密的接口地址全局搜索 2、通过打断点的方式&#xff0c;操作页面&#xff0c;跑到断点处时&#xff0c;即可找到加密串&#xff0c;如图二&#xff1b; 3、找到用的是哪种加密方式&#xff0c;如&#xff1a; cr…

Unity Apple Vision Pro 保姆级开发教程-准备阶段

视频教程&#xff1a; Unity PolySpatial 开发Apple Vision Pro教程, 三十分钟快速了解 Unity Vision Pro 中文课堂教程地址&#xff1a; Unity3D Vision Pro 开发教程【保姆级】 | Unity 中文课堂 开发Apple Vision Pro 使用原生开发和unity 开发有什么区别 如果你的项目需要…

LSTM反向传播及公式推导

先回顾一下正向传播的公式: 化简一下: 反向传播从下到上逐步求偏导: 对zt求偏导(预测值和标签值相减): zt对未知数wt,ht,bt分别求偏导: ht对ot,Ct求偏导: ot对Net0求偏导: Net0对w0,b0求偏导: .... 总体的思路就是那个公式从下到上逐步对未知数求偏导: 下面是总体的流程…

【AIGC】ChatGPT与人类理解力的共鸣:人机交互中的心智理论(ToM)探索

博客主页&#xff1a; [小ᶻZ࿆] 本文专栏: AIGC | ChatGPT 文章目录 &#x1f4af;前言&#x1f4af;心智理论(Theory of Mind,ToM)心智理论在心理学与神经科学中的重要性心智理论对理解同理心、道德判断和社交技能的重要性结论 &#x1f4af;乌得勒支大学研究对ChatGPT-4…

【C++篇】类与对象深度解析(六):全面剖析拷贝省略、RVO、NRVO优化策略

文章目录 前言 &#x1f4ac; 欢迎讨论&#xff1a;如果你在学习过程中有任何问题或想法&#xff0c;欢迎在评论区留言&#xff0c;我们一起交流学习。你的支持是我继续创作的动力&#xff01; &#x1f44d; 点赞、收藏与分享&#xff1a;觉得这篇文章对你有帮助吗&#xff1…

软件设计模式------工厂方法模式

工厂方法模式&#xff08;Factory Method Pattern&#xff09;&#xff0c;又称工厂模式&#xff0c;也叫虚拟构造器模式&#xff08;Virtual Constructor Pattern&#xff09;或多态工厂模式&#xff08;Polymorphic Pactory Pattern&#xff09;,属于类创建型模式。 我们知道…

WIFI实现透传+接线图

单片机通过TX接WIFI模块的RX将设置的AT代码写入WIFI模块&#xff08;连接WIFI调为设备模式&#xff08;有设备&#xff0c;路由&#xff0c;双模等模式&#xff09;&#xff09; WIFI模块将响应信号通过TX通过CH340发给PC的RX 通过STC-ISP或安信可串口调试助手查看响应信息 …

Golang | Leetcode Golang题解之第495题提莫攻击

题目&#xff1a; 题解&#xff1a; func findPoisonedDuration(timeSeries []int, duration int) (ans int) {expired : 0for _, t : range timeSeries {if t > expired {ans duration} else {ans t duration - expired}expired t duration}return }