c语言按不同条件查询,使用C语言实现的查询条件界面展开/收起方案

这篇博客介绍了如何在C#客户端应用中实现查询界面的展开/收起功能。作者首先展示了原始的实现方式,通过LinkLabel控制Panel高度变化。然后为了提高代码复用性和简化页面逻辑,作者创建了一个自定义控件HeightController,该控件能够自动调整其父容器的高度并显示相应的提示文字。自定义控件包含了收起和展开的高度、文字等属性,使得在不同页面间可以方便地进行复用。
摘要由CSDN通过智能技术生成

先简单说一下应用场景,现有一个C#客户端的查询界面,上方放置查询条件,下方放置查询结果。因为实际情况中查询条件可能占了好几行的位置,所以希望在界面上默认只保留一行最主要的查询条件,并在右侧有一个“展开/收起”功能。

收起时界面:

85060048_1

展开时界面:

85060048_2

最开始我的实现方式是这样的,在界面上放置一个LinkLabel,设置此LinkLabel的鼠标单击事件,调整查询条件所在Panel的Height属性。

85060048_3

C#代码如下:

using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;namespace SatyrAndNymph{ public partial class FormMethod1 : Form { //收起状态时Panel高度 private const int HeightWhenFold = 50; //收起状态时LinkLabel显示文字 private const string DescriptionWhenFold = '展开'; //展开状态时Panel高度 private const int HeightWhenExpand = 85; //展开状态时LinkLabel显示文字 private const string DescriptionWhenExpand = '收起'; /// /// 窗体构造函数 /// public FormMethod1 { InitializeComponent; //构造函数后将Panel调整为收起状态 lnkControlHeight.Text = DescriptionWhenFold; pnlQueryConds.Height = HeightWhenFold; } /// /// LinkLabel单击事件 /// /// /// private void lnkControlHeight_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e) { //根据显示文字为展开/收起,调整Panel的高度及LinkLabel展示文字 if (lnkControlHeight.Text == DescriptionWhenFold) { lnkControlHeight.Text = DescriptionWhenExpand; pnlQueryConds.Height = HeightWhenExpand; } else if (lnkControlHeight.Text == DescriptionWhenExpand) { lnkControlHeight.Text = DescriptionWhenFold; pnlQueryConds.Height = HeightWhenFold; } } }}

不过我认为这样处理还是不够完美:每次使用都需要专门创建一个LinkLabel,并且每个页面的代码都不一样,因为父容器的标识符是不一样的。

为了解决这两个问题,我设计了一个自定义控件以方便后续的开发工作。

控件名为HeightController,界面如下:

自定义控件中只包含一个LinkLabel,AutoSize属性被设置为False,Dock属性被设置为Full,TextAlign属性被设置为MiddleLeft。

C#代码如下:

using System;using System.Collections.Generic;using System.ComponentModel;using System.Drawing;using System.Data;using System.Linq;using System.Text;using System.Windows.Forms;namespace SatyrAndNymph{ /// /// 展开/收起控制器 /// public partial class HeightController : UserControl { /// /// 展开/收起控制器 /// public HeightController { InitializeComponent; } /// /// 控制器状态 /// private ControllerStatusEnum _controllerStatus = ControllerStatusEnum.FOLD; // 控制器状态 /// [System.ComponentModel.Description('控制器状态')] public ControllerStatusEnum ControllerStatus { get { return _controllerStatus; } set { _controllerStatus = value; //调整展开/收起情况 if (value == ControllerStatusEnum.FOLD) { Fold; } else if (value == ControllerStatusEnum.EXPAND) { Expand; } } } /// /// 父容器展开 /// public void Expand { if (this.Parent != null) { this.Parent.Height = HeightWhenExpand; } this.lnkHeightController.Text = DescriptionWhenExpand; } /// /// 父容器收起 /// public void Fold { if (this.Parent != null) { this.Parent.Height = HeightWhenFold; } this.lnkHeightController.Text = DescriptionWhenFold; } /// /// 收起时高度 /// private int _heightWhenFold = 50; // 收起时高度 /// [DefaultValue(50)] [System.ComponentModel.Description('收起时高度')] public int HeightWhenFold { get { return _heightWhenFold; } set { _heightWhenFold = value; } } /// /// 收起时显示文字 /// private string _descriptionWhenFold = '展开'; // 收起时显示文字 /// [System.ComponentModel.Description('收起时显示文字')] public string DescriptionWhenFold { get { return _descriptionWhenFold; } set { _descriptionWhenFold = value; } } /// /// 展开时高度 /// private int _heightWhenExpand = 85; // 展开时高度 /// [DefaultValue(85)] [System.ComponentModel.Description('展开时高度')] public int HeightWhenExpand { get { return _heightWhenExpand; } set { _heightWhenExpand = value; } } /// /// 展开时显示文字 /// private string _descriptionWhenExpand = '收起'; // 展开时显示文字 /// [System.ComponentModel.Description('展开时显示文字')] public string DescriptionWhenExpand { get { return _descriptionWhenExpand; } set { _descriptionWhenExpand = value; } } /// /// 点击LinkLabel文字 /// /// /// private void lnkHeightController_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e) { if (this.Parent != null) { int height = this.Parent.Height; //根据父容器高度判断父容器应是收起还是展开 if (height < heightwhenexpand)="" {="" controllerstatus="ControllerStatusEnum.EXPAND;" }="" else="" {="" controllerstatus="ControllerStatusEnum.FOLD;" }="" }="" }="">

使用此控件时,直接将此控件拖入要改变高度的Panel或其他容器即可。

85060048_4

使用前需要先在控件属性中设置好如下5项内容:

85060048_5

各属性说明如下:

1、ControllerStatus,是一个枚举,包含EXPAND和FOLD两种选择,决定窗体打开时查询条件是展开或是收起的。

2、DescriptionWhenExpand,当查询条件区域处于展开状态时,控制器展示的文字

3、DescriptionWhenFold,当查询条件区域处于收起状态时,控制器展示的文字

4、HeightWhenExpand,查询条件区域处于展开状态时高度

5、HeightWhenFold,查询条件区域处于收起状态时高度

HeightController控件使用效果如下:

收起时界面:

85060048_6

展开时界面:

85060048_7

END

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值