[转]WinForm界面开发之布局控件"WeifenLuo.WinFormsUI.Docking"的使用

简介:

http://blog.csdn.net/ansy/archive/2010/07/06/5717241.aspx

 

本篇介绍Winform程序开发中的布局界面的设计,介绍如何在我的共享软件中使用布局控件"WeifenLuo.WinFormsUI.Docking"。

布局控件"WeifenLuo.WinFormsUI.Docking"是一个非常棒的开源控件,用过的人都深有体会,该控件之强大、美观、不亚于商业控件。而且控件使用也是比较简单的。先看看控件使用的程序界面展示效果。

配电网络可视化管理系统的界面截图:

深田之星送水管理系统网络版的界面截图:

我在几个共享软件都使用了该布局控件,我们先以“深田之星送水管理系统网络版”这款软件为例,介绍如何完成该界面的设计及显示的。

1、首先,我们添加一个主界面窗体,命名为MainForm,该窗体IsMdiContainer设置为True,也就是设置为多文档窗体格式。拖拉布局控件"WeifenLuo.WinFormsUI.Docking.DockPanel"到主窗体MainForm中,并设置下面几个属性:

Dock为Fill、DocumentStyle为DockingMdi、RightToLeftLayout为True。

这几个属性的意思应该不难,Dock就是 覆盖整个MDI窗体的区域,DocumentStyle为多文档类型、RightToLeftLayout是指新打开的窗口都停靠在右边区域。

我们看看设计界面视图如下所示。

2、主界面其实基本上就可以了,另外我们看到“送水管理系统网络版”的界面中有一个左边的工具栏,它其实也是在一个停靠的窗体中的,我们增加一个窗体用来承载相关的工具快捷键按钮展示。命名为MainToolWindow的窗体,继承自WeifenLuo.WinFormsUI.Docking.DockContent.

其中的“HideOnClose”属性很重要,该属性一般设置为True,就是指你关闭窗口时,窗体只是隐藏而不是真的关闭。

左边的窗口MainToolWindow实现停靠的代码是在MainForm的构造函数或者Load函数中加载即可。

mainToolWin.Show(this.dockPanel, DockState.DockLeft);

 3、对于工具窗口我们已经完成了,但是主业务窗口还没有做,也就是下面的部分内容。

为了方便,我们定义一个基类窗体,命名为BaseForm,继承自DockContent,如下所示

public class BaseForm : DockContent

然后每个业务窗口继承BaseForm即可。

4、剩下的内容就是如何在主窗体MainForm中展示相关的业务窗口了,展示的代码如下所示

复制代码
     public   partial   class  MainForm : Form
    {
        
#region  属性字段

         
private  MainToolWindow mainToolWin  =   new  MainToolWindow();
        
private  FrmProduct frmProduct  =   new  FrmProduct();
        
private  FrmCustomer frmCustomer  =   new  FrmCustomer();
        
private  FrmOrder frmOrder  =   new  FrmOrder();
        
private  FrmStock frmStock  =   new  FrmStock();
        
private  FrmComingCall frmComingCall  =   new  FrmComingCall();
        
private  FrmDeliving frmDeliving  =   new  FrmDeliving();
        
private  FrmTicketHistory frmHistory  =   new  FrmTicketHistory(); 

        
#endregion

        
public  MainForm()
        {
            InitializeComponent();

            SplashScreen.Splasher.Status 
=   " 正在展示相关的内容 " ;
            System.Threading.Thread.Sleep(
100 );

            mainToolWin.Show(
this .dockPanel, DockState.DockLeft);
            frmComingCall.Show(
this .dockPanel);
            frmDeliving.Show(
this .dockPanel);
            frmHistory.Show(
this .dockPanel);
            frmStock.Show(
this .dockPanel);
            frmProduct.Show(
this .dockPanel);
            frmCustomer.Show(
this .dockPanel);
            frmOrder.Show(
this .dockPanel);

            SplashScreen.Splasher.Status 
=   " 初始化完毕 " ;
            System.Threading.Thread.Sleep(
50 );

            SplashScreen.Splasher.Close();
        }

复制代码

5.下面贴出基本窗口的基本操作事件函数

复制代码
         private   void  menu_Window_CloseAll_Click( object  sender, EventArgs e)
        {
            CloseAllDocuments();
        }

        
private   void  menu_Window_CloseOther_Click( object  sender, EventArgs e)
        {
            
if  (dockPanel.DocumentStyle  ==  DocumentStyle.SystemMdi)
            {
                Form activeMdi 
=  ActiveMdiChild;
                
foreach  (Form form  in  MdiChildren)
                {
                    
if  (form  !=  activeMdi)
                    {
                        form.Close();
                    }
                }
            }
            
else
            {
                
foreach  (IDockContent document  in  dockPanel.DocumentsToArray())
                {
                    
if  ( ! document.DockHandler.IsActivated)
                    {
                        document.DockHandler.Close();
                    }
                }
            }
        }

        
private  DockContent FindDocument( string  text)
        {
            
if  (dockPanel.DocumentStyle  ==  DocumentStyle.SystemMdi)
            {
                
foreach  (Form form  in  MdiChildren)
                {
                    
if  (form.Text  ==  text)
                    {
                        
return  form  as  DockContent;
                    }
                }

                
return   null ;
            }
            
else
            {
                
foreach  (DockContent content  in  dockPanel.Documents)
                {
                    
if  (content.DockHandler.TabText  ==  text)
                    {
                        
return  content;
                    }
                }

                
return   null ;
            }
        }

        
public  DockContent ShowContent( string  caption, Type formType)
        {
            DockContent frm 
=  FindDocument(caption);
            
if  (frm  ==   null )
            {
                frm 
=  ChildWinManagement.LoadMdiForm(Portal.gc.MainDialog, formType)  as  DockContent;
            }

            frm.Show(
this .dockPanel);
            frm.BringToFront();
            
return  frm;
        }

        
public   void  CloseAllDocuments()
        {
            
if  (dockPanel.DocumentStyle  ==  DocumentStyle.SystemMdi)
            {
                
foreach  (Form form  in  MdiChildren)
                {
                    form.Close();
                }
            }
            
else
            {
                IDockContent[] documents 
=  dockPanel.DocumentsToArray();
                
foreach  (IDockContent content  in  documents)
                {
                    content.DockHandler.Close();
                }
            }
        } 
复制代码

最后呈上该控件文件,大家可以下来玩玩。

http://files.cnblogs.com/wuhuacong/WeifenLuo.WinFormsUI.Docking.rar

作者:  火地晋 
出处:  http://yelaiju.cnblogs.com 
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

在上篇文章《WinForm界面开发之布局控件"WeifenLuo.WinFormsUI.Docking"的使用》,我介绍了如何在程序界面中使用WeifenLuo.WinFormsUI.Docking这个优秀的布局控件,这款软件目前我还没有找出比他更好的免费控件了,不知WeifenLuo其人如何,不过东西确实不错,赞一个。

在使用这个控件的时候,估计大家都会碰到 这样一个问题,就是当窗口是自动隐藏的时候,好像出来的大小一般比实际的大,感觉不太美观,有没有什么方法可以控制它的呢,答案是当然有了,其实实现起来也很简单。

首先我们来看看其内部机制是如何实现的,因为该控件有一些属性,专门用来控制窗口的比例的。我们在该控件的源码上看到DocingPanel类中有这么一个属性,是用来控制自动隐藏窗口的缩放比例的。

复制代码
        [LocalizedCategory( " Category_Docking " )]
        [LocalizedDescription(
" DockContent_AutoHidePortion_Description " )]
        [DefaultValue(
0.25 )]
        
public   double  AutoHidePortion
        {
            
get     {     return  DockHandler.AutoHidePortion;    }
            
set     {    DockHandler.AutoHidePortion  =  value;    }

        } 
复制代码

 默认的大小是0.25,这个参数是可以修改的。因为控件提供了一个保存布局状态的方法,它默认是没有保存的,如果需要记住调整的窗口大小(当然这是一种最好的方法),那么只需要加上几段代码即可。

 首先我们看保存布局状态的代码。

复制代码
          private   void  MainForm_Closing( object  sender, System.ComponentModel.CancelEventArgs e)
        {
            
string  configFile  =  Path.Combine(Path.GetDirectoryName(Application.ExecutablePath),  " DockPanel.config " );
            
if  (m_bSaveLayout)
                dockPanel.SaveAsXml(configFile);
            
else   if  (File.Exists(configFile))
                File.Delete(configFile);
        }
复制代码

 这样的方法,因为是直接调用控件本身的保存,所以应该比较易懂。我们再看看程序启动的时候,加载还原原有布局信息的时候,是如何的。

复制代码
         private   void  MainForm_Load( object  sender, EventArgs e)
        {
            
// 加载布局
            m_deserializeDockContent  =   new  DeserializeDockContent(GetContentFromPersistString);
            
string  configFile  =  Path.Combine(Path.GetDirectoryName(Application.ExecutablePath),  " DockPanel.config " );
            
if  (File.Exists(configFile))
            {
                dockPanel.LoadFromXml(configFile, m_deserializeDockContent);
            }
        }
复制代码
复制代码
         private  IDockContent GetContentFromPersistString( string  persistString)
        {
            
if  (persistString  ==   typeof (MainToolWindow).ToString())
                
return  mainToolWin;
            
else   if  (persistString  ==   typeof (FrmStatus).ToString())
                
return  mainStatus;
            
else   if  (persistString  ==   typeof (FrmRoomView).ToString())
                
return  frmRoomView;
            
else
                
return   null ;
        }
复制代码

 这样,我们就可以实现布局由用户调整,而不需要怕每次都有那么一点大,不雅观了。

我们看程序的根目录下面生成了一个文件,叫做DockPanel.config, 我们看看就知道里面的布局状态参数了,其中的AutoHidePortion,我们通过自动调整界面,它也就会跟着变化的了,如下面的那个AutoHidePortion="0.179554494828958" 就是我调整后的大小。 

复制代码
  < Contents Count = " 7 " >
    
< Content ID = " 0 "  PersistString = " DockSample.DummyToolbox "  AutoHidePortion = " 0.25 "  IsHidden = " True "  IsFloat = " True "   />
    
< Content ID = " 1 "  PersistString = " DockSample.DummySolutionExplorer "  AutoHidePortion = " 0.25 "  IsHidden = " False "  IsFloat = " False "   />
    
< Content ID = " 2 "  PersistString = " DockSample.DummyPropertyWindow "  AutoHidePortion = " 0.25 "  IsHidden = " False "  IsFloat = " False "   />
    
< Content ID = " 3 "  PersistString = " DockSample.DummyOutputWindow "  AutoHidePortion = " 0.179554494828958 "  IsHidden = " False "  IsFloat = " False "   />
    
< Content ID = " 4 "  PersistString = " DockSample.DummyTaskList "  AutoHidePortion = " 0.25 "  IsHidden = " True "  IsFloat = " True "   />
    
< Content ID = " 5 "  PersistString = " DockSample.DummyDoc,,Document1 "  AutoHidePortion = " 0.25 "  IsHidden = " False "  IsFloat = " False "   />
    
< Content ID = " 6 "  PersistString = " DockSample.DummyDoc,,Document2 "  AutoHidePortion = " 0.25 "  IsHidden = " False "  IsFloat = " False "   />
  
</ Contents >
复制代码

 当然如果我们需要 完美的布局,只需要在发布前,调整好这些参数给用户就可以了,是不是很方便呢。



本文转自火地晋博客园博客,原文链接:http://www.cnblogs.com/yelaiju/archive/2010/11/05/1870318.html,如需转载请自行联系原作者

目录
相关文章
|
计算机视觉
OpenCV(二十五):边缘检测(一)
OpenCV(二十五):边缘检测(一)
845 0
|
Shell 网络安全 C#
一款 .NET 开源、功能强大的远程连接管理工具,支持 RDP、VNC、SSH 等多种主流协议!
一款 .NET 开源、功能强大的远程连接管理工具,支持 RDP、VNC、SSH 等多种主流协议!
436 4
|
9月前
|
安全 Cloud Native 容器
开发者视角:构建坚不可摧的云原生安全工具 - 安全内生于开发流
云原生时代,运维团队面临容器漏洞、微服务失陷与CI/CD污染三大威胁。通过容器基因解码、微服务免疫与管道净化构建三维防御体系,结合板栗看板、Snyk、Check Point、Aqua等工具,实现从漏洞预测到实时拦截的全链路防护。未来,安全将内生于云原生技术,构建主动免疫防线。
开发者视角:构建坚不可摧的云原生安全工具 - 安全内生于开发流
|
计算机视觉
ROS2错误排查:解决cv_bridge与opencv版本不匹配问题。
要记住,这只是一种可能的解决方式,你可能还需要针对你的特定问题进行其他操作。如果遇到任何问题,记住,遇到困难不要灰心,继续把问题当作一个冒险,勇敢地前行。
1056 92
|
人工智能 智能设计 安全
2024云栖大会《设计的未来&未来的设计》全记录
2024云栖大会《设计的未来&未来的设计》全记录
|
图形学 UED
GLTF在线编辑器
GLTF在线编辑器提供了一系列功能,支持对GLTF模型的在线查看、材质修改、模型大小修改、模型网格属性修改、重置原点、模型合批等功能
1058 0
|
开发框架 前端开发 JavaScript
在DevExpress的GridView的列中,动态创建列的时候,绑定不同的编辑处理控件
在DevExpress的GridView的列中,动态创建列的时候,绑定不同的编辑处理控件
|
存储 Oracle 关系型数据库
PACS源码,C#语言数字医学影像系统成品源码
**数字医学影像系统(RIS/PACS)**采用C#开发,基于C/S架构,配Oracle数据库,具备自主版权,适用于项目实施。系统包含分诊、超声、放射、内镜、病理等工作站,支持基本信息维护、报表查询和系统维护。功能亮点有:WorkList管理、影像采集传输、存储检索、图像处理、多序列浏览、流程控制、报告录入与审核、支持多种影像设备及高级影像处理。RIS与PACS数据库同步,并集成HIS、电子病历等系统接口。全面遵循DICOM3.0标准。
358 1
PACS源码,C#语言数字医学影像系统成品源码
|
C# 容器
WPF技术之Width和Height
WPF中的MinWidth、Width、MaxWidth、MinHeight、Height和MaxHeight属性用于定义元素的最大和最小尺寸以及默认大小。
1069 0
|
存储 Linux 编译器
打破常规,Linux内核新的数据结构上场maple tree(上)
打破常规,Linux内核新的数据结构上场maple tree