WPF实现动态四宫格布局

embedded/2025/1/21 4:05:45/

需求描述

我们要设计一个界面,用户可以通过 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/embedded/155668.html

相关文章

【C++】面试题整理(未完待续)

【C】面试题整理 文章目录 一、概述二、C基础2.1 - 指针在 32 位和 64 位系统中的长度2.2 - 数组和指针2.3 - 结构体对齐补齐2.4 - 头文件包含2.5 - 堆和栈的区别2.6 - 宏函数比较两个数值的大小2.7 - 冒泡排序2.8 - 菱形继承的内存布局2.9 - 继承重写2.10 - 如何禁止类在栈上分…

Redis 中 TTL 的基本知识与禁用缓存键的实现策略(Java)

目录 前言1. 基本知识2. Java代码 前言 &#x1f91f; 找工作&#xff0c;来万码优才&#xff1a;&#x1f449; #小程序://万码优才/r6rqmzDaXpYkJZF 单纯学习Redis可以看我前言的Java基本知识路线&#xff01;&#xff01; 对于Java的基本知识推荐阅读&#xff1a; java框架…

PiliPalaX ( 第三方安卓哔哩哔哩)

PiliPalaX 是一款哔哩哔哩第三方客户端。使用 Flutter 开发&#xff0c;基于PiliPala原版基础上创作出来的X升级版&#xff0c;目前支持Android、IOS客户端。 应用特色 目前着重移动端(Android、iOS)和Pad端&#xff0c;暂时没有适配桌面端、手表端等 https://pan.quark.cn/s/…

第九章:演示文稿软件PPT

文章目录&#xff1a; 一&#xff1a;界面 1.介绍 2.选项卡 2.1 开始 2.2 插入 2.3 设计 2.4 切换 2.5 动画 2.6 放映 2.7 审阅 2.8 视图 2.9 音频工具 2.10 视频工具 二&#xff1a;基础 三&#xff1a;设计 1.静态 2.动态 四&#xff1a;放映 一&#xff1…

软考信安22~网站安全需求分析与安全保护工程

1、网站安全威胁与需求分析 1.1、网站安全概念 网站安全主要是有关网站的机密性、完整性、可用性及可控性。 网站的机密性是指网站信息及相关数据不被授权查看或泄露。 网站的完整性是指网站的信息及数据不能非授权修改,网站服务不被劫持。 网站的可用性是指网站可以待续…

基于 Spring Boot、Vue 实现的调问开源问卷系统

是一款简单、高效、成熟、稳定、专业的开源问卷系统&#xff0c;自2012年启动至今经过9年的积累&#xff0c;已经形成一套完善的基于 JAVA WEB 的开源问卷表单解决方案。 &#x1f389;&#x1f389;&#x1f389; 企业版 全新的 企业版 已经发布&#xff0c;前后端分别采用 …

PyTorch 神经协同过滤 (NCF) 推荐系统教程

目录 教程概述1. 神经协同过滤模型概述NCF 模型的主要组成部分&#xff1a; 2. 数据加载与预处理3. 定义神经协同过滤模型4. 训练模型5. 模型评估6. 推荐物品7. 完整示例8. 总结 在本教程中&#xff0c;我们将使用 PyTorch 实现一个神经协同过滤&#xff08;Neural Collaborat…

NavVis手持激光扫描帮助舍弗勒快速打造“数字孪生”工厂-沪敖3D

在全球拥有近100家工厂的舍弗勒&#xff0c;从2016年开启数字化运营进程&#xff0c;而当前制造、库存、劳动力和物流的数字化&#xff0c;已无法支持其进一步简化工作流程&#xff0c;亟需数字化物理制造环境&#xff0c;打造“数字孪生”工厂。 NavVis为其提供NavVis VLX 3…