WPF实现动态四宫格布局

devtools/2025/1/20 23:21:22/

需求描述

我们要设计一个界面,用户可以通过 CheckBox 控制哪些图表显示。图表的数量是动态的,最多可以选择显示四个图表。如果显示一个图表,它会占满整个区域;如果显示两个图表,它们会水平排列;显示三个图表时,上面两个水平排列,下面一个铺满宽度;如果显示四个图表,它们会均匀分布在四个格子中。

XAML 代码

首先,我们需要一个 Grid 布局,它将包含最多四个图表的占位区域。我们还需要一些 CheckBox 控制每个图表的显示。以下是 XAML 代码

<Window x:Class="DynamicGridLayout.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"Title="动态四宫格布局" Height="450" Width="800"><Grid><!-- 控制图表显示的 CheckBox --><StackPanel Margin="10" HorizontalAlignment="Left" Orientation="Horizontal"><TextBlock Text="显示图表:" /><CheckBox x:Name="chbChart1" Margin="10,0,0,0" Checked="ChartShow_OnChecked" Unchecked="ChartShow_OnChecked" Content="图表 1" IsChecked="True"/><CheckBox x:Name="chbChart2" Margin="10,0,0,0" Checked="ChartShow_OnChecked" Unchecked="ChartShow_OnChecked" Content="图表 2" IsChecked="True"/><CheckBox x:Name="chbChart3" Margin="10,0,0,0" Checked="ChartShow_OnChecked" Unchecked="ChartShow_OnChecked" Content="图表 3" IsChecked="True"/><CheckBox x:Name="chbChart4" Margin="10,0,0,0" Checked="ChartShow_OnChecked" Unchecked="ChartShow_OnChecked" Content="图表 4" IsChecked="True"/></StackPanel><!-- 动态布局的 Grid --><Grid x:Name="MainGrid" Margin="10,60,10,10"><Border x:Name="chart1" Background="LightBlue" Visibility="Visible" BorderBrush="Black" BorderThickness="1" /><Border x:Name="chart2" Background="LightCoral" Visibility="Visible" BorderBrush="Black" BorderThickness="1" /><Border x:Name="chart3" Background="LightGreen" Visibility="Visible" BorderBrush="Black" BorderThickness="1" /><Border x:Name="chart4" Background="LightGoldenrodYellow" Visibility="Visible" BorderBrush="Black" BorderThickness="1" /></Grid></Grid>
</Window>
C# 代码

接下来,我们在 C# 代码中根据用户的选择动态更新布局。关键是 ChartShow_OnChecked 方法,它根据当前选中的 CheckBox 控制图表的可见性,并动态调整 Grid 的行列定义。

public partial class MainWindow : Window
{public MainWindow(){InitializeComponent();UpdateChartLayout();}// 控制图表显示的事件private void ChartShow_OnChecked(object sender, RoutedEventArgs e){// 确保至少有一个图表被选中bool isAnyChecked = chbChart1.IsChecked == true ||chbChart2.IsChecked == true ||chbChart3.IsChecked == true ||chbChart4.IsChecked == true;// 如果没有任何图表选中,恢复当前选中的图表if (!isAnyChecked && sender is CheckBox currentCheckBox){currentCheckBox.IsChecked = true;MessageBox.Show("至少需要选中一个图表!", "提示", MessageBoxButton.OK, MessageBoxImage.Warning);return;}// 控制对应图表的显示和隐藏chart1.Visibility = chbChart1.IsChecked == true ? Visibility.Visible : Visibility.Collapsed;chart2.Visibility = chbChart2.IsChecked == true ? Visibility.Visible : Visibility.Collapsed;chart3.Visibility = chbChart3.IsChecked == true ? Visibility.Visible : Visibility.Collapsed;chart4.Visibility = chbChart4.IsChecked == true ? Visibility.Visible : Visibility.Collapsed;// 更新布局UpdateChartLayout();}// 更新图表的布局private void UpdateChartLayout(){// 获取当前显示的图表var visibleCharts = new[] { chart1, chart2, chart3, chart4 }.Where(chart => chart.Visibility == Visibility.Visible).ToList();// 清空现有的布局MainGrid.RowDefinitions.Clear();MainGrid.ColumnDefinitions.Clear();// 设置默认的布局foreach (var chart in visibleCharts){Grid.SetRow(chart, 0);Grid.SetColumn(chart, 0);Grid.SetColumnSpan(chart, 1);}// 根据图表数量进行不同布局switch (visibleCharts.Count){case 1:// 单个图表,铺满整个区域MainGrid.RowDefinitions.Add(new RowDefinition());MainGrid.ColumnDefinitions.Add(new ColumnDefinition());Grid.SetRow(visibleCharts[0], 0);Grid.SetColumn(visibleCharts[0], 0);break;case 2:// 两个图表,水平排列MainGrid.RowDefinitions.Add(new RowDefinition());MainGrid.ColumnDefinitions.Add(new ColumnDefinition());MainGrid.ColumnDefinitions.Add(new ColumnDefinition());Grid.SetRow(visibleCharts[0], 0);Grid.SetColumn(visibleCharts[0], 0);Grid.SetRow(visibleCharts[1], 0);Grid.SetColumn(visibleCharts[1], 1);break;case 3:// 三个图表,上方两个,下面一个铺满MainGrid.RowDefinitions.Add(new RowDefinition());MainGrid.RowDefinitions.Add(new RowDefinition());MainGrid.ColumnDefinitions.Add(new ColumnDefinition());MainGrid.ColumnDefinitions.Add(new ColumnDefinition());Grid.SetRow(visibleCharts[0], 0);Grid.SetColumn(visibleCharts[0], 0);Grid.SetRow(visibleCharts[1], 0);Grid.SetColumn(visibleCharts[1], 1);Grid.SetRow(visibleCharts[2], 1);Grid.SetColumn(visibleCharts[2], 0);Grid.SetColumnSpan(visibleCharts[2], 2); // 跨两列break;case 4:// 四个图表,标准两行两列MainGrid.RowDefinitions.Add(new RowDefinition());MainGrid.RowDefinitions.Add(new RowDefinition());MainGrid.ColumnDefinitions.Add(new ColumnDefinition());MainGrid.ColumnDefinitions.Add(new ColumnDefinition());for (int i = 0; i < visibleCharts.Count; i++){Grid.SetRow(visibleCharts[i], i / 2);Grid.SetColumn(visibleCharts[i], i % 2);}break;}}
}

http://www.ppmy.cn/devtools/152215.html

相关文章

【前端】CSS学习笔记(1)

目录 CSS的简介CSS的概念语法 CSS的引入方式内联样式&#xff08;行内样式&#xff09;内部样式外部样式&#xff08;推荐&#xff09; 选择器全局选择器元素选择器类选择器ID选择器合并选择器后代选择器子选择器相邻兄弟选择器通用兄弟选择器伪类选择器:link:visited:hover:ac…

【客观对比】激光雷达 vs 纯视觉方案:汽车自动驾驶的两种路径

激光雷达 vs 纯视觉方案&#xff1a;汽车自动驾驶的两种路径 导语 汽车自动驾驶技术正以惊人的速度发展&#xff0c;未来无疑会彻底改变我们的出行方式。在这场技术竞争中&#xff0c;激光雷达&#xff08;LiDAR&#xff09;和纯视觉&#xff08;Camera-based&#xff09;方案…

青少年编程与数学 02-007 PostgreSQL数据库应用 09课题、规则、约束和默认值

青少年编程与数学 02-007 PostgreSQL数据库应用 09课题、规则、约束和默认值 一、规则二、规则应用示例示例1&#xff1a;使用规则实现视图示例2&#xff1a;使用规则自动填充数据示例3&#xff1a;使用规则实现数据的合并插入 三、约束四、约束应用示例示例1&#xff1a;主键约…

EAMM: 通过基于音频的情感感知运动模型实现的一次性情感对话人脸合成

EAMM: 通过基于音频的情感感知运动模型实现的一次性情感对话人脸合成 1所有的材料都可以在EAMM: One-Shot Emotional Talking Face via Audio-Based Emotion-Aware Motion Model网站上找到。 摘要 尽管音频驱动的对话人脸生成技术已取得显著进展&#xff0c;但现有方法要么忽…

C# 委托和事件(Lambda表达式)

回调(callback&#xff09;函数是Windows编程的一个重要部分。C或C编程背景&#xff0c;在许多Windows API中使用过回调。VB添加AddressOf关键字后&#xff0c;开发人员就可以利用以前一度受到限制的API。回调函数实际上是方法调用的指针也称为函数指针。.NET以委托的形式实现函…

AI 时代的 Prompt 工程入门

引言 网络有句话流行的话—— “未来&#xff0c;淘汰你的不是AI&#xff0c;而是掌握了AI的人”。那我们应该怎么掌握AI&#xff1f;我自己的理解是学会面向AI提问&#xff0c;利用好AI工具为我们的工作提效和赋能。毕竟我们普通人不太可能直接去开发大模型&#xff0c;我们更…

主从复制

简述mysql 主从复制原理及其工作过程&#xff0c;配置一主两从并验证。 主从原理&#xff1a;MySQL 主从同步是一种数据库复制技术&#xff0c;它通过将主服务器上的数据更改复制到一个或多个从服务器&#xff0c;实现数据的自动同步。 主从同步的核心原理是将主服务器上的二…

ComfyUI 矩阵测试指南:用三种方法,速优项目效果

在ComfyUI中&#xff0c;矩阵测试也叫xyz图表测试&#xff0c;作用是通过控制变量的方式来对Lora模型以及各种参数开展测试&#xff0c;并进行有效区分。其中测试方法有很多种&#xff0c;可以通过借助插件也可以自行搭建工作流实现&#xff0c;下面介绍3种方式&#xff1a; 1…