再谈布局控件"WeifenLuo.WinFormsUI.Docking"的使用--如何控制自动停靠窗口的大小

简介:

在上篇文章《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 >

 本文转自博客园伍华聪的博客,原文链接:再谈布局控件"WeifenLuo.WinFormsUI.Docking"的使用--如何控制自动停靠窗口的大小,如需转载请自行联系原博主。



目录
相关文章
|
敏捷开发 前端开发 开发者
【RaETable】🚀🚀🚀告别Form,RaETable表格列宽度支持拖动调整了,附带原理说明
【RaETable】🚀🚀🚀告别Form,RaETable表格列宽度支持拖动调整了,附带原理说明
|
JavaScript 前端开发
jquery 展开收缩改变状态 保姆式教学代码,默认第二项展开
jquery 展开收缩改变状态 保姆式教学代码,默认第二项展开
|
编解码 前端开发 UED
每日一学—设置页面文字大小随屏幕大小变化而变化(rem布局)
每日学一点加强技术水平,夯实基础。 阅读这篇文章,一起学习rem布局吧。
420 0
每日一学—设置页面文字大小随屏幕大小变化而变化(rem布局)
SwiftUI—预览视图在正常模式和黑暗模式下的效果
SwiftUI—预览视图在正常模式和黑暗模式下的效果
152 0
SwiftUI—预览视图在正常模式和黑暗模式下的效果
|
vr&ar 图形学
【Unity3D 灵巧小知识点】 ☀️ | 层级面板中的 ‘小手指‘ 作用: 在Scen中将该物体设置为不可选中状态
Unity 小科普 老规矩,先介绍一下 Unity 的科普小知识: Unity是 实时3D互动内容创作和运营平台 。 包括游戏开发、美术、建筑、汽车设计、影视在内的所有创作者,借助 Unity 将创意变成现实。 Unity 平台提供一整套完善的软件解决方案,可用于创作、运营和变现任何实时互动的2D和3D内容,支持平台包括手机、平板电脑、PC、游戏主机、增强现实和虚拟现实设备。
【Unity3D 灵巧小知识点】 ☀️ | 层级面板中的 ‘小手指‘ 作用: 在Scen中将该物体设置为不可选中状态
巧用生活号icon菜单和功能扩展区,更快传达你的服务!
01 你用icon菜单了吗?   还在使用单一的文字菜单? 想要表达内容太多,只能深深藏进二级菜单? 那么,建议你试试icon菜单。 简单直白,你所能提供的服务 一.目.了.然 | 杭州市民卡,利用icon菜单,所有服务一目了然,菜单点击数据直线上升;  02 功能扩展区启用了吗?   用图文推送来宣传活动?吸引点击? 可是,图文很快就会被覆盖。
486 12
|
Web App开发 SQL JavaScript
【自然框架】分享 n级联动下拉列表框
  特点:1、 使用js方法,把需要的数据一次性写入到页面里,然后用js来实现联动的效果。2、 支持n级。3、 封装成了服务器控件,所以使用非常简单。4、 支持在回发的时候保持状态。5、 支持修改记录的时候设置默认选项。
1264 0
|
SQL JavaScript 前端开发
【自然框架】之鼠标点功能现(二):表单控件的“应用”—— 代码?只写需要的!
  【自然框架】之鼠标点功能现(一):单表的增删改查(即上次5月23日活动的一个主题)【Demo、源码下载】           看了大家的回复,好像不少人误会了,我为了突出“鼠标点,功能现”,所以没有说代码,没有贴代码,这就让一些人认为我想要完全抛弃VS,自己写一个“平台”来代替,不好意思,您高估我了,我可达不到。
869 0
|
Android开发 Java 数据格式
界面无小事(七):使用代码动态增删布局
界面无小事(一):RecyclerView+CardView了解一下界面无小事(二):让RecyclerView展示更多不同视图界面无小事(三):用RecyclerView + Toolbar做个文件选择器界面无小事(四):来写个滚动选择器吧!界面无小...
1341 0
|
前端开发 容器
用MVVM模式开发中遇到的零散问题总结(5)——将动态加载的可视元素保存为图片的控件,Binding刷新的时机
原文:用MVVM模式开发中遇到的零散问题总结(5)——将动态加载的可视元素保存为图片的控件,Binding刷新的时机       在项目开发中经常会遇到这样一种情况,就是需要将用户填写的信息排版到一张表单中,供打印或存档。
832 0