GridSplitter 的 ResizeBehavior 属性介绍

来源:互联网 发布:电话会议用什么软件 编辑:程序博客网 时间:2024/05/18 02:43

我们先来看一个我们在使用 GridSplitter 时,经常可能会碰到的问题:

把一个窗体分成2部分,这两部分中间是一个GridSplitter来支持这左右两部分的宽度变动。类似下面的效果图:

GridSplitter 的 ResizeBehavior 属性介绍01

中间红色就是分割线,这个分割线支持左右两部分的宽度变更,一般我们会把这个需求写成类似下面XAML文件的方式:

    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    x:Class="WpfApplication_GridSplitter.Window1"
    Title="Window1" Height="100" Width="300">
   
       
           
           
           
       

       
       
       
       
   

但是仅仅上面的代码,我们在拖动分割线的时候,会发现,分割线右边的尺寸发生变化了,而左边的尺寸没有发生变化,类似下面效果图:

GridSplitter 的 ResizeBehavior 属性介绍02

中间出现了一个空白区域。

这是为何呢??

原因很简单, GridSplitter 默认的 ResizeBehavior 属性为:BasedOnAlignment

ResizeBehavior 属性是一个枚举类型:GridResizeBehavior ,这个枚举类型包含以下枚举项:

BasedOnAlignment    根据VerticalAlignment 和 HorizontalAlignment 属性来确定分割线移动后,有哪些项被移动
CurrentAndNext        Grid 当前所在的区域以及下一个区域被影响
PreviousAndCurrent  前一个和当前区域被影响
PreviousAndNext      前一个和后一个区域被影响

我们把这个XAML文件改成下面方式就可以左右联动了。注意,只改动了加粗,加红的这一个属性。

    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    x:Class="WpfApplication_GridSplitter.Window1"
    Title="Window1" Height="100" Width="300">
   
       
           
           
           
       

       
       
       

ResizeBehavior="PreviousAndNext" />
       
   

改动后的效果图:

GridSplitter 的 ResizeBehavior 属性介绍03

总结:

GridSplitter 的默认 ResizeBehavior 属性导致我们无法实现左右联动,我们只需要简单的修改这个属性就实现左右联动。

这个问题,由于是第一次接触WPF,让我花了好几个星期,才发现是这里简单的问题所导致的。所以特写此篇博客,希望对碰到这个问题人有所帮助。

参考资料:

MSDN GridResizeBehavior Enumeration 


原创粉丝点击