好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

使用C#语言实现的查询条件界面展开和收起功能

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

收起时界面:

展开时界面:

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

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 = "收起" ;

/// <summary>

/// 窗体构造函数

/// </summary>

public formmethod1()

{

initializecomponent();

//构造函数后将panel调整为收起状态

lnkcontrolheight.text = descriptionwhenfold;

pnlqueryconds.height = heightwhenfold;

}

/// <summary>

/// linklabel单击事件

/// </summary>

/// <param name="sender"></param>

/// <param name="e"></param>

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

{

/// <summary>

/// 展开/收起控制器

/// </summary>

public partial class heightcontroller : usercontrol

{

/// <summary>

/// 展开/收起控制器

/// </summary>

public heightcontroller()

{

initializecomponent();

}

private void heightcontroller_load( object sender, eventargs e)

{

//设计器模式时,不触发展开/收起,否则会对设计工作造成干扰

if (! this .designmode)

{

//调整展开/收起情况

if (controllerstatus == controllerstatusenum.fold)

{

fold();

}

else if (controllerstatus == controllerstatusenum.expand)

{

expand();

}

}

}

/// <summary>

/// 控制器状态

/// </summary>

private controllerstatusenum _controllerstatus = controllerstatusenum.fold;

///<summary>

/// 控制器状态

///</summary>

[system.componentmodel.description( "控制器状态" )]

public controllerstatusenum controllerstatus

{

get

{

return _controllerstatus;

}

set

{

_controllerstatus = value;

}

}

/// <summary>

/// 父容器展开

/// </summary>

public void expand()

{

controllerstatus = controllerstatusenum.expand;

if ( this .parent != null )

{

this .parent.height = heightwhenexpand;

}

this .lnkheightcontroller.text = descriptionwhenexpand;

}

/// <summary>

/// 父容器收起

/// </summary>

public void fold()

{

controllerstatus = controllerstatusenum.fold;

if ( this .parent != null )

{

this .parent.height = heightwhenfold;

}

this .lnkheightcontroller.text = descriptionwhenfold;

}

/// <summary>

/// 收起时高度

/// </summary>

private int _heightwhenfold = 50;

///<summary>

/// 收起时高度

///</summary>

[defaultvalue(50)]

[system.componentmodel.description( "收起时高度" )]

public int heightwhenfold

{

get

{

return _heightwhenfold;

}

set

{

_heightwhenfold = value;

}

}

/// <summary>

/// 收起时显示文字

/// </summary>

private string _descriptionwhenfold = "展开" ;

///<summary>

/// 收起时显示文字

///</summary>

[system.componentmodel.description( "收起时显示文字" )]

public string descriptionwhenfold

{

get

{

return _descriptionwhenfold;

}

set

{

_descriptionwhenfold = value;

}

}

/// <summary>

/// 展开时高度

/// </summary>

private int _heightwhenexpand = 85;

///<summary>

/// 展开时高度

///</summary>

[defaultvalue(85)]

[system.componentmodel.description( "展开时高度" )]

public int heightwhenexpand

{

get

{

return _heightwhenexpand;

}

set

{

_heightwhenexpand = value;

}

}

/// <summary>

/// 展开时显示文字

/// </summary>

private string _descriptionwhenexpand = "收起" ;

///<summary>

/// 展开时显示文字

///</summary>

[system.componentmodel.description( "展开时显示文字" )]

public string descriptionwhenexpand

{

get

{

return _descriptionwhenexpand;

}

set

{

_descriptionwhenexpand = value;

}

}

/// <summary>

/// 点击linklabel文字

/// </summary>

/// <param name="sender"></param>

/// <param name="e"></param>

private void lnkheightcontroller_linkclicked( object sender, linklabellinkclickedeventargs e)

{

if ( this .parent != null )

{

int height = this .parent.height;

//根据父容器高度判断父容器应是收起还是展开

if (controllerstatus == controllerstatusenum.fold)

{

expand();

}

else

{

fold();

}

}

}

}

}

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

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

各属性说明如下:

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

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

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

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

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

heightcontroller控件使用效果如下:

收起时界面:

展开时界面:

demo程序下载地址:

链接: http://pan.baidu.com/s/1jhsvvee  密码: qfp7

以上所述是小编给大家介绍的使用c#语言实现的查询条件界面展开和收起功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!

原文链接:https://my.oschina.net/Tsybius2014/blog/791349?utm_source=tuicool&utm_medium=referral

dy("nrwz");

查看更多关于使用C#语言实现的查询条件界面展开和收起功能的详细内容...

  阅读:51次