zoukankan      html  css  js  c++  java
  • C#使用splitContainer控件制作收缩展开面板

    C#使用splitContainer控件制作收缩展开面板

    原创 2011年07月19日 17:18:02
            最近对Squid Ink公司的一款PC端软件系统上的一个收缩伸展面板很感兴趣,加上自己做的喷码机数据管理系统的界面非常单调,想在现在界面的基础上将这个功能加上去。我个人只是写c#的一个菜鸟,在网上查了C#的很多控件,很多人都是用GroupBox和SplitContainer实现的,于是就对这两个控件进行了测试。
    附Squid Ink公司软件的界面效果:

            先说GroupBox这个控件,这个基本上能实现面板伸缩和扩展的功能,但是个人感觉GroupBox其本身那个框让人感觉不是很爽,再加上我想在点击处加上伸缩和展开的图标,并且鼠标放在点击处会变成手型(GroupBox的话鼠标放在整个控件都会变成手型,不只是标题处),于是就没深究这个框到底能不能去掉。

            再去网上搜了一下SplitContainer这个控件的用法,这个控件总共有两个面板,网上很多人用这个控件都是采用点击第一个面板,隐藏第二个面板的方法:

    [csharp] view plain copy
     
    1. private void SplitContainer_Panel1_MouseClick(object sender, MouseEventArgs e)  
    2. {  
    3.             int i;  
    4.               
    5.             SplitterPanel splitPanel = (SplitterPanel)sender;  
    6.   
    7.             for (i = 0; i < 10; i++)  
    8.                 if (splitContainers[i].Panel1 == splitPanel)  
    9.                     break;  
    10.               
    11.             splitContainers[i].Panel2Collapsed = !splitContainers[i].Panel2Collapsed;  
    12. }  

            首先在第一个面板上面添加鼠标点击事件,用点击的方法将第二个面板伸缩和展开,由于监听的是第一个面板,而第二个面板隐藏需要SplitContainer需要整个控件的变量,所以我把所有Form里面的SplitContainer都添加到splitContainers这个数组里面。如果只有一个SplitContainer控件需要隐藏的话,那么这个功能基本上就能实现了,但是如果有多个面板需要隐藏的话,这个方法的排版会很麻烦,因为第二个面板只是隐藏,不是消失,第二个面板位置跟上去的话会出现控件的覆盖问题。如果有朋友解决了这个问题的话,可以指点我一下。

           本来是山穷水尽了,一个意外的想法突然出现在脑海中。其实我一直是抓着SplitContainer这个控件的面板隐藏功能不放,换一种思路,我们可以像GroupBox一样,直接设置SplitContainer控件的大小:

    [csharp] view plain copy
     
    1. private void SplitContainer_Panel1_MouseClick(object sender, MouseEventArgs e)  
    2. {  
    3.     int i;  
    4.       
    5.     SplitterPanel splitPanel = (SplitterPanel)sender;  
    6.   
    7.     for (i = 0; i < 10; i++)  
    8.         if (splitContainers[i].Panel1 == splitPanel)  
    9.             break;  
    10.       
    11.     //splitContainers[i].Panel2Collapsed = !splitContainers[i].Panel2Collapsed;  
    12.     if (splitContainers[i].Size.Height <= 50)  
    13.     {  
    14.         splitContainers[i].Size = containerSizes[i];  
    15.         splitContainers[i].Panel1.BackgroundImage = global::inkjet.Properties.Resources.展开;  
    16.     }  
    17.     else  
    18.     {  
    19.         splitContainers[i].Size = new Size(splitContainers[i].Size.Width, 20);  
    20.         splitContainers[i].Panel1.BackgroundImage = global::inkjet.Properties.Resources.收缩;  
    21.     }  
    22. }  

            事实证明,重新设置SplitContainer的大小之后,再修改下面的SplitContainer控件的位置能很好地满足我的需求。后来我发现,将所有的SplitContainer控件放到FlowLayoutPanel里面,在修改SplitContainer控件大小之后,无需修改位置就能解决这个问题。

    附 效果图:

            当然界面的颜色还需完善,展开和收缩的图标是从Squid Ink公司的软件截图而来。但是已经能满足这款软件的需求,如果路过的朋友有更好的方法的话,欢迎指点。

  • 相关阅读:
    黑名单项目
    MVC
    《Spring敲门砖之基础教程第一季》 第一章 概要介绍
    【推荐】Java工程师如何从普通成为大神值得一读
    Spring框架知识总结-注入Bean的各类异常
    循序渐进Socket网络编程(多客户端、信息共享、文件传输)
    Struts2:ValueStack
    Struts2 的国际化实现
    一位10年程序员生涯的骨灰给小弟弟小妹妹们的一些总结性忠告
    集合类接口和类层次关系图
  • 原文地址:https://www.cnblogs.com/woxihuadabai/p/8037001.html
Copyright © 2011-2022 走看看