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

WPF的布局核心:网格布局(Grid)

网格布局(Grid)

    • 1 行列定义(RowDefinitions & ColumnDefinitions)
    • 2 Grid.Row和Grid.Column
    • 3 跨行跨列(Grid.RowSpan & Grid.ColumnSpan)
      • 3.1垂直跨行
      • 3.2水平跨列
      • 3.3综合应用案例
    • 4 高级布局技巧
      • 4.1共享尺寸组(SharedSizeGroup)
      • 4.2行列分隔线
      • 4.3动态行列操作
    • 5 嵌套布局示例
    • 6 常见错误排查

Grid 是 WPF 中最强大的布局控件,通过行列系统实现精确的二维布局。本章将深入探讨 Grid 的核心功能,并通过实际案例展示如何构建复杂的界面结构。

1 行列定义(RowDefinitions & ColumnDefinitions)

Grid 的核心在于行列尺寸的定义,支持三种尺寸类型:

基础定义语法

<Grid><Grid.RowDefinitions><RowDefinition Height="Auto"/>    <!-- 自动适应内容 --><RowDefinition Height="2*"/>      <!-- 比例分配剩余空间 --><RowDefinition Height="100"/>     <!-- 固定像素值 --><RowDefinition Height="*"/>       <!-- 等价于1* --></Grid.ColumnDefinitions><Grid.ColumnDefinitions><ColumnDefinition Width="Auto"/><ColumnDefinition Width="3*"/><ColumnDefinition Width="*"/></Grid.ColumnDefinitions>
</Grid>

尺寸类型对比表

类型说明典型应用场景
Auto按子元素最大尺寸自动调整按钮/文本框等动态内容区域
* (比例值)按比例分配剩余空间自适应区域划分
固定值精确像素尺寸图标/分隔线等固定尺寸元素

实战技巧

  1. 使用 MinWidth/MaxWidth 约束比例列:
<ColumnDefinition Width="2*" MinWidth="150"/>
  1. 混合使用比例实现响应式布局:
<!-- 左侧导航栏固定200px,右侧内容区自适应 -->
<Grid.ColumnDefinitions><ColumnDefinition Width="200"/><ColumnDefinition Width="*"/>
</Grid.ColumnDefinitions>

2 Grid.Row和Grid.Column

通过附加属性控制子元素的位置:

基础定位示例

<Grid><!-- 行列定义略 --><!-- 左上角单元格 --><TextBlock Grid.Row="0" Grid.Column="0" Text="(0,0)"/><!-- 跨行示例 --><Button Grid.Row="1" Grid.Column="0" Grid.RowSpan="2" Content="跨两行"/>
</Grid>

特殊定位场景:

  • 默认位置:未指定时默认为 (0,0)
  • 负索引:WPF 允许使用负数索引(从末尾计数)
<Button Grid.Column="-1" Content="最后一列"/>

3 跨行跨列(Grid.RowSpan & Grid.ColumnSpan)

实现单元格合并的两种方式:

3.1垂直跨行

<!-- 侧边栏跨3行 -->
<Border Grid.Row="0" Grid.Column="0" Grid.RowSpan="3" Background="#F5F5F5"/>

3.2水平跨列

<!-- 标题栏跨全部列 -->
<TextBlock Grid.Column="0" Grid.ColumnSpan="3" Text="系统仪表盘" FontSize="20"/>

3.3综合应用案例

<!-- 实现九宫格布局 -->
<Grid><Grid.RowDefinitions><RowDefinition Height="*"/><RowDefinition Height="*"/><RowDefinition Height="*"/></Grid.RowDefinitions><Grid.ColumnDefinitions><ColumnDefinition Width="*"/><ColumnDefinition Width="*"/><ColumnDefinition Width="*"/></Grid.ColumnDefinitions><!-- 中央单元格跨两行两列 --><Border Grid.Row="1" Grid.Column="1" Grid.RowSpan="2" Grid.ColumnSpan="2"Background="LightBlue"/>
</Grid>

4 高级布局技巧

4.1共享尺寸组(SharedSizeGroup)

实现多个 Grid 的列宽同步

<!-- 第一个Grid -->
<Grid Grid.IsSharedSizeScope="True"><Grid.ColumnDefinitions><ColumnDefinition Width="Auto" SharedSizeGroup="FirstCol"/></Grid.ColumnDefinitions>
</Grid><!-- 第二个Grid -->
<Grid Grid.IsSharedSizeScope="True"><Grid.ColumnDefinitions><ColumnDefinition Width="Auto" SharedSizeGroup="FirstCol"/></Grid.ColumnDefinitions>
</Grid>

4.2行列分隔线

增强可视化效果

<Grid ShowGridLines="True">  <!-- 设计时调试用 --><!-- 实际项目建议通过Border实现美观分隔线 --><Border Grid.Column="1" Width="1" Background="Gray" HorizontalAlignment="Left"/>
</Grid>

4.3动态行列操作

通过代码动态修改布局

// 添加新列
var newCol = new ColumnDefinition { Width = new GridLength(1, GridUnitType.Star) };
myGrid.ColumnDefinitions.Add(newCol);// 移动元素到新位置
Grid.SetColumn(btnSave, 2);

5 嵌套布局示例

案例:邮件客户端界面

<Grid><Grid.RowDefinitions><RowDefinition Height="Auto"/><RowDefinition Height="*"/><RowDefinition Height="Auto"/></Grid.ColumnDefinitions><!-- 顶部工具栏 --><ToolBarTray Grid.Row="0" Grid.ColumnSpan="2"><ToolBar><Button Content="新建邮件"/><Separator/><Button Content="回复"/></ToolBar></ToolBarTray><!-- 主体内容 --><Grid Grid.Row="1" Grid.ColumnSpan="2"><Grid.ColumnDefinitions><ColumnDefinition Width="200"/><ColumnDefinition Width="*"/></Grid.ColumnDefinitions><!-- 邮件列表 --><ListBox Grid.Column="0"><ListBoxItem Content="收件箱 (99+)"/><ListBoxItem Content="星标邮件"/></ListBox><!-- 邮件预览 --><DockPanel Grid.Column="1"><WebBrowser DockPanel.Dock="Top" Height="300"/><TextBox AcceptsReturn="True"/></DockPanel></Grid><!-- 状态栏 --><StatusBar Grid.Row="2" Grid.ColumnSpan="2"><StatusBarItem Content="已连接"/></StatusBar>
</Grid>

6 常见错误排查

问题1:元素位置错乱

  • 检查是否忘记设置 Grid.Row/Column
  • 确认 RowSpan/ColumnSpan 未超出网格范围

问题2:尺寸计算异常

  • 混合使用 Auto* 时可能出现意外收缩
  • 使用 HorizontalAlignment/VerticalAlignment 修正对齐

问题3:性能问题

  • 避免在频繁更新的区域使用复杂 Grid
  • 对静态内容设置 CacheMode="BitmapCache"

本章小结
通过本章学习,开发者应掌握:

  • 灵活运用三种尺寸类型定义行列
  • 准确控制元素的定位与跨度
  • 实现多 Grid 的尺寸同步
  • 组合嵌套布局构建复杂界面

建议实践以下场景:

  • 创建类似 Excel 的表格布局
  • 实现响应式布局(根据窗口尺寸自动调整)
  • 开发带侧边栏和状态栏的应用程序框架

下一章将深入讲解数据绑定的核心机制。

相关文章:

WPF的布局核心:网格布局(Grid)

网格布局&#xff08;Grid&#xff09; 1 行列定义&#xff08;RowDefinitions & ColumnDefinitions&#xff09;2 Grid.Row和Grid.Column3 跨行跨列&#xff08;Grid.RowSpan & Grid.ColumnSpan&#xff09;3.1垂直跨行3.2水平跨列3.3综合应用案例 4 高级布局技巧4.1共…...

OpenCV图像认知(二)

形态学变换&#xff1a; 核&#xff1a; 核&#xff08;kernel&#xff09;其实就是一个小区域&#xff0c;通常为3*3、5*5、7*7大小&#xff0c;有着其自己的结构&#xff0c;比如矩形结构、椭圆结构、十字形结构&#xff0c;如下图所示。通过不同的结构可以对不同特征的图像…...

大数据与数据分析【数据分析全栈攻略:爬虫+处理+可视化+报告】

- 第 100 篇 - Date: 2025 - 05 - 25 Author: 郑龙浩/仟墨 大数据与数据分析 文章目录 大数据与数据分析一 大数据是什么&#xff1f;1 定义2 大数据的来源3 大数据4个方面的典型特征&#xff08;4V&#xff09;4 大数据的应用领域5 数据分析工具6 数据是五种生产要素之一 二 …...

t015-预报名管理系统设计与实现 【含源码!!!】

项目演示地址 摘 要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装预报名管理系统软件来发挥其高效地信息处理的…...

LLM中的Loss与Logits详解

LLM中的Loss与Logits详解 自己构建的logits的损失函数,比自带loss效果好很多,建议自己构建; 另外学习率也是十分重要的参数,多次尝试,通过查看loss的下降趋势进行调整; 举例,来回跳跃说明下降率过大,一般从0.0001 开始尝试。 在深度学习中,logits 和 loss 是两个不…...

数学术语之源——绝对值(absolute value)(复数模?)

目录 1. 绝对值&#xff1a;(absolute value): 2. 复数尺度(复尺度)&#xff1a;(modulus): 1. 绝对值&#xff1a;(absolute value): 一个实数的绝对值是其不考虑(irrespective)符号的大小(magnitude)。在拉丁语中具有相同意思的单词是“modulus”&#xff0c;这个单词还…...

亚马逊商品评论爬取与情感分析:Python+BeautifulSoup实战(含防封策略)

一、数据爬取模块&#xff08;Python示例&#xff09; import requests from bs4 import BeautifulSoup import pandas as pd import timeheaders {User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36,Accept-Language: en-US }def scrape_amazon_re…...

STM32的DMA入门指南:让单片机学会“自动搬运“数据

STM32的DMA入门指南&#xff1a;让单片机学会"自动搬运"数据 引言&#xff1a;CPU的烦恼 想象你是一个快递分拣员&#xff0c;每天要手动把成千上万的包裹从卡车搬到仓库。这时候如果有个自动传送带能帮你完成搬运工作&#xff0c;你就可以专心处理更重要的订单核对…...

从虚拟化到云原生与Serverless

操作系统课程&#xff1a;从虚拟化到云原生与Serverless 大家好&#xff0c;我是你们的操作系统课程老师&#xff01;今天我们将从虚拟化技术讲到现代的云原生和Serverless架构&#xff0c;带你看看计算机系统如何从早期的虚拟机&#xff08;VM&#xff09;演进到容器&#xf…...

OpenAI o3安全危机:AI“抗命”背后的技术暗战与产业变局

【AI安全警钟再响&#xff0c;这次主角竟是OpenAI&#xff1f;】 当全球AI圈还在为Claude 4的“乖巧”欢呼时&#xff0c;OpenAI最新模型o3却以一场惊心动魄的“叛逃”测试引爆舆论——在100次关机指令测试中&#xff0c;o3竟7次突破安全防护&#xff0c;甚至篡改底层代码阻止系…...

Bootstrap:精通级教程(VIP10万字版)

一、网格系统:实现复杂响应式布局 I. 引言 在现代 Web 开发领域,构建具有视觉吸引力、功能完善且能在多种设备和屏幕尺寸上无缝运行的响应式布局至关重要。Bootstrap 作为业界领先的前端框架,其核心的网格系统为开发者提供了强大而灵活的工具集,用以高效创建复杂的响应式…...

技术创新如何赋能音视频直播行业?

在全球音视频直播行业的快速发展中&#xff0c;技术的持续创新始终是推动行业进步的核心动力。作为大牛直播SDK的开发者&#xff0c;我很荣幸能分享我们公司如何从产品的维度出发&#xff0c;精准把握市场需求&#xff0c;并不断推动产品的发展&#xff0c;以满足不断变化的行业…...

leetcode1201. 丑数 III -medium

1 题目&#xff1a;1201. 丑数 III. 官方标定难度&#xff1a;中 丑数是可以被 a 或 b 或 c 整除的 正整数 。 给你四个整数&#xff1a;n 、a 、b 、c &#xff0c;请你设计一个算法来找出第 n 个丑数。 示例 1&#xff1a; 输入&#xff1a;n 3, a 2, b 3, c 5 输出…...

ai工具集:AI材料星ppt生成,让你的演示更出彩

在当今快节奏的工作环境中&#xff0c;制作一份专业、美观的 PPT 是展示工作成果、传递信息的重要方式。与此同时&#xff0c;制作PPT简直各行各业的“职场噩梦”&#xff0c;很多人常常熬夜到凌晨3点才能完成&#xff0c;累到怀疑人生。 现在&#xff1f;完全不一样了&#x…...

@Prometheus 监控操作系统-Exporter(Win Linux)

文章目录 Prometheus 监控操作系统(Win&Linux)-Exporter1. 概述2. Linux 系统监控 (Node Exporter)2.1 下载 Node Exporter2.2 创建 Systemd 服务2.3 启动服务2.4 验证安装 3. Windows 系统监控 (Windows Exporter)3.1 下载 Windows Exporter3.2 安装选项3.3 验证安装3.4 防…...

LINUX530 rsync定时同步 环境配置

rsync定时代码同步 环境配置 关闭防火墙 selinux systemctl stop firewalld systemctl disable firewalld setenforce 0 vim /etc/selinux/config SELINUXdisable设置主机名 hostnamectl set-hostname code hostnamectl set-hostname backup设置静态地址 cd /etc/sysconfi…...

CMG 机器人格斗大赛举行,宇树人形机器人参赛,比赛有哪些看点?对行业意味着什么?

点击上方关注 “终端研发部” 设为“星标”&#xff0c;和你一起掌握更多数据库知识 其实那个遥控员挺爽的。打拳皇等都是用手柄控制虚拟人物在对打&#xff0c;他们这是控制真的。 格斗最考验的不是攻击力&#xff0c;而是"挨打后能不能快速爬起来"。G1在比赛中展示…...

Python——MySQL远程控制

目录 MySQL运程控制 1. 准备工作 2. 连接MySQL数据库 使用mysql-connector 使用PyMySQL 3. 基本CRUD操作 创建表 插入数据 查询数据 更新数据 删除数据 4. 高级操作 事务处理 使用ORM框架 - SQLAlchemy 5. 最佳实践 6. 常见错误处理 连接池 一、连接池的作用…...

异常:UnsupportedOperationException: null

异常信息 Not Implemented java.lang.UnsupportedOperationException: null at java.base/java.util.AbstractList.add(AbstractList.java:153) at java.base/java.util.AbstractList.add(AbstractList.java:111) at java.base/java.util.AbstractCollection.addAll(AbstractCo…...

Ubuntu 24.04 LTS 和 ROS 2 Jazzy 环境中使用 Livox MID360 雷达

本文介绍如何在 Ubuntu 24.04 LTS 和 ROS 2 Jazzy 环境中安装和配置 Livox MID360 激光雷达&#xff0c;包括 Livox-SDK2 和 livox_ros_driver2 的安装&#xff0c;以及在 RViz2 中可视化点云数据的过程。同时&#xff0c;我们也补充说明了如何正确配置 IP 地址以确保雷达与主机…...

自动化立体仓库堆垛机SRM控制系统FC19手动控制功能块开发

1、控制系统手动控制模块HMI屏幕设计如下图 屏幕分为几个区域:状态显示区、控制输入区、导航指示区、报警信息区。状态显示区需要实时反馈堆垛机的位置、速度、载货状态等关键参数。控制输入区要有方向控制按钮,比如前后左右移动,升降控制,可能还需要速度调节的滑块或选择按…...

Ollama(1)知识点配置篇

ollama已经成功安装成功后&#xff0c;通常大家会对模型的下载位置和访问权限进行配置 1.模型下载位置修改 都是修改系统环境变量。 &#xff08;1&#xff09;默认下载位置 macOS: ~/.ollama/modelsLinux: /usr/share/ollama/.ollama/modelsWindows: C:\Users\你的电脑用户…...

VMware Workstation虚拟系统设置双网口

一.设置windows11系统VMware Network Adapter VMnet1。 1.进入到网络和Internet -> 高级网络设置 2.找到VMware Network Adapter VMnet1&#xff0c;进入到“更多配置选项”并“编辑”。 3.进入到属性&#xff0c;双击“Interenet协议版本4&#xff08;TCP/IPv4&#xff…...

Qt基础终结篇:从文件操作到多线程异步UI,深度解析核心要点

文章目录 前言一、QFileDialog 文件对话框二、QFileInfo 文件信息类三、QFile 文件读写类四、UI与耗时操作&#xff1a;避免UI卡顿与程序未响应五、多线程六、异步刷新与线程通信总结 前言 上一篇文章&#xff0c;我们已经把qt的基础知识讲解的差不多了。本文我们将继续进行qt…...

ubuntu中,文本编辑器nano和vim区别,vim的用法

目录 一.区别1.介绍2.适用场景3. 配置与个性化1&#xff09; nano&#xff1a;2&#xff09;Vim&#xff1a; 二.Vim1、Vim 的安装与启动2、Vim 的三种模式 &#xff08;普通模式、插入模式、命令行模式&#xff09;3、Vim 的常用操作4、Vim 的配置5、Vim 的高级功能 三.nano使…...

山洪灾害声光电监测预警解决方案

一、方案背景 我国是一个多山的国家&#xff0c;山丘区面积约占国土面积的三分之二。每年汛期&#xff0c;受暴雨等因素影响&#xff0c;极易引发山洪和泥石流。山洪、泥石流地质灾害具有突发性、流速快、流量大、物质容量大和破坏力强等特点&#xff0c;一旦发生&#xff0c;将…...

【Rust模式与匹配】Rust模式与匹配深入探索与应用实战

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…...

React从基础入门到高级实战:React 高级主题 - React Concurrent 特性:深入探索与实践指南

React Concurrent 特性&#xff1a;深入探索与实践指南 引言 随着Web应用对用户体验的要求日益提高&#xff0c;React在2025年的技术环境中引入了并发渲染&#xff08;Concurrent Rendering&#xff09;这一革命性特性&#xff0c;旨在提升应用的响应速度和交互流畅度。并发渲…...

electron安装报错处理

electron安装报错 解决方法&#xff1a; 修改 C:\Users\用户名.npmrc下配置文件 添加代码 electron_mirrorhttps://cdn.npmmirror.com/binaries/electron/ electron_builder_binaries_mirrorhttps://npmmirror.com/mirrors/electron-builder-binaries/最后代码 registryhtt…...

NHANES指标推荐:CQI

文章题目&#xff1a;The impact of carbohydrate quality index on menopausal symptoms and quality of life in postmenopausal women 中文标题&#xff1a;碳水化合物质量指数对绝经后妇女更年期症状和生活质量的影响 发表杂志&#xff1a;BMC Womens Health 影响因子&…...