WPF 页面布局 DockPanel Grid StackPanel UniformGrid WrapPanel WPF布局入门 WPF布局资料

news2025/1/18 10:43:09

在布局常用的布局属性

HorizontalAlignment: 用于设置元素的水平位置VerticalAlignment: 用于设置元素的垂直位置
Margin: 指定元素与容器的边距
Height: 指定元素的高度
Width: 指定素的宽度
WinHeight/WinWidth: 指定元素的最小高度和宽度MaxHeight/MaxWidth: 指定元素的最大高度和宽度
Padding: 指定元素内部边距

通常使用元素 

DockPanel

包含在DockPanel中的元素,具备DockPanel.Dock的4个枚举值 (Top/Left/Right/Botom) 用于设置元素的错定位置LastChildFill:容器中的最后一个元素时,默认该元素填充DockPanel所有空间,默认值为TrueDockPanel中的元素未显示添加DockPanel.Dock属性时,系统则会默认为DockPanel.Dock=“Left"

<DockPane1>
<Button DockPanel.Dock="Top" Width="40" Height="40" Background="Red"/>
<Button DockPanel.Dock="Left" Width="40" Height="40" Background="Yellow"/>
<Button DockPanel.Dock="Right" Width="40" Height="40" Background="Blue"/>
<Button DockPanel.Dock="Bottom" Width="40" Height="40" Background="Green"/>
</DockPanel>

Grid

Grid为最常用的布局容器,作为View中的主要组成部分,负责框架中整体的页面布局。
ShowGridLines: 可以设置行业的边距线的显示。

Grid.RowDefinitions:可以创建任意行,进行固定高度与百分比或自适应高度设置Grid.ColumnDefinitions: 可以创建任意列,进行固定宽度与百分或自适应宽度设置

<Grid ShowGridLines="True">
    <Grid.RowDefinitions>
        <RowDefinition/><RowDefinition/>
    </Grid.RowDefinitions>
    <Grid.ColumnDefinitions>
        <ColumnDefinition/>
        <ColumnDefinition/>
    </Grid.ColumnDefinitions>
</Grid>
<Grid showGridlines="True">
    <Grid.RowDefinitions>
        <RowDefinition/>
        <RowDefinition/>
    </Grid.RowDefinitions>
    <Grid.ColumnDefinitions>
        <ColumnDefinition/>
        <ColumnDefinition/>
    <Grid.ColumnDefinitions>
    <Border Background="#F26321" Margin="5"/>
    <Border Background="#8CC43D" Grid.Column="1" Margin="5"/>
    <Border Background="#0OABED" Grid.Row="1" Grid.Column="0" Margin="5"/>
    <Border Background="#EFB70B" Grid.Row="1" Grid.Column="0" Margin="5"/>
</Grid>

StackPanel

StackPanel 是一个垂直或水平排列控件的控件。使用 Orientation 属性来指定是垂直对齐还是水平对齐。

  • Horizontal:水平方向。
  • Vertical :垂直方向。

<StackPanel Orientation="Horizontal">
    <Button Width="100" Height="40" Background="Red"/>
    <Button Width="100" Height="40" Background="Yellow"/>
    <Button Width="100" Height="40" Background="Blue"/>
    <Button Width="100" Height="40" Background="Green"/>
</StackPane1>

UniformGrid

与Grid不同的是,该容器具备Columns/Rows 属性 通过设置该属性UniformGrid则具备相应的行与列,但是设置的Columns/Rows不允许单独的进行容器的大小设置。位于UniformGrid中的子元素,按输入顺序排列至容器中直至填充容器的所有空间。未显示指定Columns/RowsUniformGrid则为子元素动态分配Columns/Rows,换行与换列的基准主要基于UniformGrid的容器大小(宽度与高度)。

<UniformGrid>
    <Button Width="40" Height="40" Background="Red"/>
    <Button Width="40" Height="40" Background="Yellow"/>
    <Button Width="40" Height="40" Background="Blue"/>
    <Button Width="40" Height="40" Background="Green"/>
</UniformGrid>

<UniformGrid Columns="2" Rows="3">
    <Button width="100" Height="40"/>
    <Button width="100" Height="40"/>
    <Button width="100" Height="40"/>
    <Button width="100" Height="40"/>
</UniformGrid>

WrapPanel

WrapPanel与StackPanel类似的功能,相对于WrapPanel,具有在有限的容器范围内,可以自动换行,或者换列处理。具体则取决于WrapPanel的排列方式(Qrientation)。默认水平布局方向(Horizontal)

<WrapPanel>
    <Button Width="100" Height="40" Background="Red"/>
    <Button Width="100" Height="40" Background="Yellow"/>
    <Button Width="100" Height="40" Background="Blue"/>
    <Button Width="100" Height="40" Background="Green"/>
    <Button Width="100" Height="40" Background="#54FF9F"/>
    <Button Width="100" Height="40" Background="#6A5ACD"/>
</WrapPanel>

Canvas  

精准定位  一个类似坐标系的面板,通过left,right,right,bottom 四个字段来设置控件的摆放位置 

<Canvas>
        <Button Content="Test1" Canvas.Left="0" Canvas.Top="20"  Width="60"/>
        <Button Content="Test2" Canvas.Right="0" Canvas.Bottom="60" Width="60"/>
        <Button Content="Test3" Canvas.Left="150" Canvas.Top="50" Width="60"/>
        <Button Content="Test4" Canvas.Right="150" Canvas.Bottom="50"  Width="60"/>
    </Canvas>

<Canvas>
        <Button Content="Test1" Canvas.Left="150" Canvas.Top="60"  Width="90" Height="50" Background="Yellow" Foreground="Gray"/>
        <Button Content="Test2" Canvas.Left="150" Canvas.Top="80" Width="90"  Height="50" Background="Red" Foreground="White"/>
        <Button Content="Test3" Canvas.Left="150" Canvas.Top="100" Width="90"  Height="50" Background="green" Foreground="White"/>
        <Button Content="Test4" Canvas.Left="150" Canvas.Top="120"  Width="90"  Height="50" />
    </Canvas>

<Canvas>
        <Button Content="Test1" Panel.ZIndex="3"  Canvas.Left="150" Canvas.Top="60"  Width="90" Height="50" Background="Yellow" Foreground="Gray"/>
        <Button Content="Test2" Panel.ZIndex="2" Canvas.Left="150" Canvas.Top="80" Width="90"  Height="50" Background="Red" Foreground="White"/>
        <Button Content="Test3" Panel.ZIndex="1" Canvas.Left="150" Canvas.Top="100" Width="90"  Height="50" Background="green" Foreground="White"/>
        <Button Content="Test4" Panel.ZIndex="0" Canvas.Left="150" Canvas.Top="120"  Width="90"  Height="50" />
    </Canvas>

canvas还有一个z_index属性来设置控件的折叠顺序,如果不设置z_index,系统是按照控件定义的先后顺序来排序,定义了z_index属性,可调整控件的重叠顺序

例:不加z_index时

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

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

相关文章

Selenium自动化测试(基于Java)

目录 一. 了解Selenium ✅1.1 概念 ✅1.2 作用 ✅1.3 特点 ✅ 工作原理 二. Selenium Java 环境搭建 ✅2.1 下载 Chrome 浏览器 ✅2.2 查看浏览器的版本 ✅2.3 下载浏览器驱动 ✅2.4 验证环境是否搭建成功 三. Selenium 常用 API ✅3.1 定位元素 ✅3.2 操作对象 ✅…

给你的终端(windows 11的命令行 增加一个好看的背景)

1.win R 键入cmd 加回车 2.点击这个符号 进入设置 3. 找到命令提示符 4.往下滚动你的小鼠标 5.看见其他设置 点击外观 6.继续滚动小鼠标 找到背景图像 路径 最后选择 自己的喜欢图片的存放路径就可以啦 啦啦啦

宠物医院小程序开发需具备哪些功能?

想要开发一款专业好用的宠物医院小程序系统&#xff0c;需要具备哪些基本功能呢&#xff1f; 1、在线预约。用户可以在线上预约宠物医院的服务&#xff0c;包括医生、服务的具体内容、预约的时间、具体的宠物医院地址等&#xff0c;不仅可以帮助用户合理安排好时间还能让…

consul命令总结

1. consul members -http-addrxxxxx 查看指定地址consul集群的所有节点 举例&#xff1a;查看地址192.168.5.47上consul集群的所有consul节点 如下图&#xff0c;该集群一共有三个节点 2. consul info -http-addrxxxxx 查看指定地址consul集群的详细信息 举例&#xff1a;查看…

python:根据红光波段和近红外波段的遥感图像计算NDVI

作者:CSDN @ _养乐多_ 本文将介绍使用python中的GDAL库,以及红光波段和近红外波段两个单波段影像计算NDVI影像的方法和代码。并使用matplotlib库将NDVI绘制成图片。 结果如下图所示, 文章目录 一、代码1,主函数2,执行函数二、使用matpoltlib绘图一、代码 1,主函数 im…

自然科学领域期刊分区——什么是核心期刊(核心A、B、C)

目录 前言 1、什么是核心期刊 2、期刊来源数据库的大致排名 3、什么是顶刊、权威期刊、核心A、核心B、核心C 4、JCR分区与中科院分区 5、中科院2023年预警国际期刊 前言 本文只做一个简单的科普&#xff0c;当然每所院校或者科研单位对期刊分区或者认定有一套自己的认定…

搭建stm32电机控制代码框架(一)——Stm32CubeMx入门

也是挑战一下自己吧&#xff0c;看看多久能够把自己的代码框架搭建起来&#xff0c;今天是5月23日&#xff0c;看看最终搭建成功的时候是什么时候&#xff0c;目标其实这个阶段很简单&#xff0c;电机转一个双闭环FOC就行。 这次的任务是基于stm32f405芯片进行展开&#xff0c…

如何看待现在的网络安全行业?

前言 网络安全是一个需要具备专业技术和能力的综合性行业&#xff0c;从业者需要具备扎实的技术功底和批判性思维&#xff0c;不断学习和更新知识&#xff0c;以保证随时能够应对威胁和攻击。 在现在的网络安全行业&#xff0c;从业者面临的挑战较多&#xff0c;如恶意代码、…

K8s环境部署Triton实现云端模型推理

前置条件&#xff1a;K8集群、helm 1、以模型名作为目录名&#xff0c;创建目录 mkdir resnet50_pytorch 2、将模型文件、配置文件&#xff08;输入、输出等&#xff09;存到刚创建的目录下&#xff0c;resnet50_pytorch目录下文件层级结构如下 model-respository/ └── …

攫取 RGB图像 和 PCM音频 数据

一、获取源码 1. 下载地址 Github: https://github.com/Gaaagaa/MediaGrabber 2. 编译提醒 这个测试程序&#xff0c;是使用 QtCreator 写的 Qt 界面程序&#xff0c;调用我封装好的 vlc_mgrabber_t 类实现了一个简单的播放器。MFC的我也写过相应的测试程序&#xff0c;这里…

Web安全:Redis 未授权访问漏洞 测试.

Web安全&#xff1a;Redis 未授权访问漏洞 测试. Redis 默认情况下绑定在 6379 端口&#xff0c;然后如果没有进行添加防火墙规则避免其他非信任来源 IP 访问等相关安全策略&#xff0c;直接暴露在公网上。然后再没有设置密码或者设置了弱密码&#xff0c;因此导致此漏洞的产生…

第12届蓝桥杯Scratch省赛真题集锦

编程题 第 1 题 问答题 下雨 题目说明 编程实现: 下雨。 具体要求: 1).点击绿旗&#xff0c;角色与背景如下图所示呈现在对应位置; 2).小猫说:“快下雨了&#xff0c;赶快回家”&#xff0c;小狗说:“我再玩一会”; 3).开始下雨&#xff0c;雨滴持续下落&#xff0c; 4).小猫…

【WinForm】继承窗体

1、VS创建2个界面&#xff0c;分别为Form1、Form2 2、重新生成后&#xff0c;将Form的父类改为Form1 3、观察设计界面&#xff0c;Form2继承了Form1窗体的控件&#xff0c;且处于锁定状态 4、在Form1中创建点击事件&#xff0c;改写标签信息&#xff0c;验证此时的类对象 …

Qt文件系统源码分析—第六篇QSaveFile

深度 本文主要分析Windows平台&#xff0c;Mac、Linux暂不涉及 本文只分析到Win32 API/Windows Com组件/STL库函数层次&#xff0c;再下层代码不做探究 本文QT版本5.15.2 类关系图 QTemporaryFile继承QFile QFile、QSaveFile继承QFileDevice QFileDevice继承QIODevice Q…

Linux:软件管理器yum编辑器vim

软件管理器yum&&编辑器vim &#x1f506;软件管理器yum软件包是什么rzsz网络通畅性验证查看软件包怎么安装软件安装yum扩展源怎么卸载软件 &#x1f506;编辑器vim基本概念基本操作正常模式指令集末行模式指令集简单配置vim配置文件的位置常用配置选项使用插件参考资料…

初阶数据结构(6)(队列的概念、常用的队列方法、队列模拟实现【用双向链表实现、用数组实现】、双端队列 (Deque)、OJ练习【用队列实现栈、用栈实现队列】)

接上次博客&#xff1a;初阶数据结构&#xff08;5&#xff09;&#xff08;栈的概念、栈的模拟实现、栈的应用及练习【改变元素的序列 、 将递归转化为循环、括号匹配、逆波兰表达式求值、出栈入栈次序匹配、最小栈】、链栈和顺序栈栈、虚拟机栈、栈帧的区别&#xff09;_di-D…

2023年天猫618活动iPhone苹果手机800元优惠券怎么领取?2023天猫618红包预售满减活动时间是从几号什么时候开始?

2023年淘宝天猫618活动期间Apple iPhone 14 Pro Max无疑是一款令人期待的顶级智能手机。从其出色的设计、强大的性能到出色的摄像功能和整合的生态系统&#xff0c;它将成为我们追求科技潮流和卓越体验的理想选择。如果你也想拥有一部顶级的智能手机&#xff0c;不妨关注iPhone…

从月薪8k到月薪30k,自动化测试究竟该怎样学...

绝大多数测试工程师都是从功能测试做起的&#xff0c;工作忙忙碌碌&#xff0c;每天在各种业务需求学习和点点中度过&#xff0c;过了好多年发现自己还只是一个功能测试工程师。 随着移动互联网的发展&#xff0c;从业人员能力的整体进步&#xff0c;软件测试需要具备的能力要…

大学生数学建模题论文

大学生数学建模题论文篇1 浅论高中数学建模与教学设想 论文关键词&#xff1a;数学建模 数学 应用意识 数学建模教学 论文摘要&#xff1a;为增强学生应用数学的意识&#xff0c;切实培养学生解决实际问题的能力&#xff0c;分析了高中数学建模的必要性&#xff0c;并通过对高中…

【Linux】1、systemd 超详细介绍

文章目录 一、背景二、系统管理2.1 systemctl2.1.1 State: degraded2.2 systemd-analyze2.3 hostnamectl2.4 localectl2.5 timedatectl2.6 loginctl 三、Unit3.1 含义3.2 展示3.3 状态3.4 管理3.5 依赖关系 四、Unit 的配置文件4.1 配置文件层级4.2 配置文件的状态4.3 配置文件…