当前位置: 首页 > article >正文

【上位机——WPF】布局控件

布局控件

  • 常用布局控件
  • Panel基类
  • Grid(网格)
  • UniformGrid(均匀分布)
  • StackPanel(堆积面板)
  • WrapPanel(换行面板)
  • DockerPanel(停靠面板)
  • Canvas(画布布局)
  • Border(边框)
  • GridSplitter(分割窗口)

常用布局控件

  1. Grid:网格,根据自定义行和列来设置控件的布局
  2. StackPanel:栈式面板,包含的元素在竖直或水平方向排成一条直线
  3. WrapPanel:自动折行面板,包含的元素在排满一行后,自动换行
  4. DockPanel:泊靠式面板,内部的元素可以选择泊靠方向
  5. UniformGrid:网格,UniformGrid就是Grid的简化版,每个单元格的大小相同
  6. Canvas:画布,内部元素根据像素为单位绝对坐标进行定位。
  7. Border:装饰的控件,此控件用于绘制边框及背景,在Border中只能有一个子控件

这里除了Border控件,其他控件都继承于Panel基类。

Panel基类

所有Panel元素都支持FrameworkElement定义的基本大小调整和定位属性,包括Height、Width、HorizontalAlignment、VerticalAlignment、Margin和LayoutTransform。Panel公开对了解和使用布局至关重要的其他属性。Background属性用于借助Brush填充派生面板元素的边界之间的区域。Children表示组成Panel的子元素集合。InternalChildren表示Children集合的内容以及由数据绑定生成的成员。两者均由父Panel内承载的子元素的UIElementCollection组成。

Panel提供了附加属性,ZIndex。假如一个单行单列的Grid布局控件中有两个Button,正常情况下,这两个Button都会以撑满Grid中,那么到底哪一个Button在上面,哪一个在下面。就看这两个Button的Panel.ZIndex附加属性的值,值越大的在上面,而值较小的那个Button将被上面的Button遮盖,从而在视觉上,用户只能看到一个Button。

    <Grid Background="AliceBlue" PreviewMouseUp="Grid_PreviewMouseUp"><Button Panel.ZIndex="2" Content="按钮1" Width="200"  Height="30"/><Button Panel.ZIndex="0" Content="按钮2" Width="200" Height="30"/></Grid>

Grid(网格)

Grid控件是WPF中所有布局控件中最好用的一个,因为它是自适应屏幕的宽度,最关键的一点是,它在呈现时,其ActuaWidth实际宽度和ActualHeight实际高度会有一个计算值,我们在业务开发中,有时候要根据父控件的实际宽度和高度来计算子控件的呈现位置和大小。

<Window x:Class="WpfApp1.MyGrid"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"xmlns:local="clr-namespace:WpfApp1"mc:Ignorable="d"Title="MyGrid" Height="450" Width="800"><!--展示线条--><Grid ShowGridLines="True"><!--三行--><Grid.RowDefinitions><RowDefinition Height="*" /> <!--Height="100" 固定高度--><RowDefinition Height="2*"/> <!--Height="2*" 等比例的高度--><RowDefinition Height="2*"/> <!--Height="Auto" 跟随文本的高度--></Grid.RowDefinitions><!--两列--><Grid.ColumnDefinitions><ColumnDefinition/><ColumnDefinition Width="Auto"/> <!--Width="Auto" 跟随文本的宽度--></Grid.ColumnDefinitions><!--第一行第一列--><!--Grid.RowSpan="2" 合并单元格行--><TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" Grid.RowSpan="2" Text="文本1" Grid.Row="0" Grid.Column="0" FontSize="30"/><!--第一行第二列--><TextBlock Text="文本2" Grid.Row="0" Grid.Column="1" FontSize="30"/><!--<TextBlock Text="文本3" Grid.Row="1" Grid.Column="0" FontSize="30"/>--><TextBlock Text="文本4" Grid.Row="1" Grid.Column="1" FontSize="30"/><!--Grid.ColumnSpan="2" 合并单元格列--><TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" Grid.ColumnSpan="2"Text="文本5" Grid.Row="2" Grid.Column="0" FontSize="30"/><!--<TextBlock Text="文本6" Grid.Row="2" Grid.Column="1" FontSize="30"/>
http://www.lryc.cn/news/2379097.html

相关文章:

  • 深入解析Spring Boot与Kafka集成:构建高性能消息驱动应用
  • 二十、案例特训专题3【系统设计篇】web架构设计
  • 【数据结构与算法】ArrayList 与顺序表的实现
  • 处理金融数据,特别是股票指数数据,以计算和分析RSRS(相对强度指数)
  • 【图像处理基石】OpenCV中都有哪些图像增强的工具?
  • WPS PPT设置默认文本框
  • PostGIS实现矢量数据转栅格数据【ST_AsRaster】
  • FAST-DDS源码分析PDP(一)
  • python打卡day29@浙大疏锦行
  • 【数据结构】2-3-1单链表的定义
  • 贝塞尔曲线原理
  • 3D个人简历网站 4.小岛
  • 创建型:原型模式
  • 浅谈“量子计算应用:从基础原理到行业破局”
  • Java面试攻略:从Spring Boot到微服务架构的深入探讨
  • 关于文件分片的介绍和应用
  • Tapered Off-Policy REINFORCE_ 如何为LLM实现稳定高效的策略优化?
  • 使用lvm进行磁盘分区
  • [Java实战]Spring Boot整合Elasticsearch(二十六)
  • 图像分割(1)U-net
  • 数位和:从定义到编程实现
  • 2025抓包工具Reqable手机抓包HTTPS亲测简单好用-快速跑通
  • 使用 Auto-Keras 进行自动化机器学习
  • python 自动化教程
  • 简单使用Slidev和PPTist
  • RISC-V 开发板 MUSE Pi Pro V2D图像加速器测试,踩坑介绍
  • 人工智能100问☞第26问:什么是贝叶斯网络?
  • c++多线程debug
  • 如何畅通需求收集渠道,获取用户反馈?
  • 标准库、HAl库和LL库(PC13初始化)