一、Canvas(不太常用)
是最基本的布局面板,仅仅支持显示坐标定位(是与设备无关的像素)元素。
他是通过设置到面板的上下左右的像素来控制在panel中元素的位置。
如控制一个button的位置:我们可以设置附加属性:Canvas.Top="" Canvas.Left="".....从而来定位元素,
但是值得注意的是如果我们同时设置两个相对的属性如Canvas.Left="" Canvas.Right="" 这样的话Canvas.Right就会被忽略,如果不这样的话又怎么显示呢
这个容器能够对元素做准确的定位,但同时也是其创建的页面不够灵活。
二、StackPanel
最大的优点是:他会顺序的对他的子元素进行排列显示。(没有任何附加属性)
要注意的是:他有两个属性:Orientation和FlowDirection从而可以设置子元素的排列显示形式
Orientation的值设为Horizontal则为水平排列,设为Vertical则垂直排列。
FlowDirection的值设为RightToLeft,则从右向左排列。设为LeftToRight,则从左向右排列。
三、WrapPanel
类似于StackPanel,具有StackPanel的属性和功能(也具有FlowDirection属性的设置)。
同时,它还具有向我们通常用的windows资源管理器一样,会随着窗口的大小,从而将子元素进行合理的分行显示,而不会出现因为窗口变小从而是一些子元素无法显示。
四、DockPanel
与Cavas相似的是,他也是从容器的边缘来定位子元素的位置。不同的是,它只能让子元素简简单单的停靠在容器边缘,然后拉伸来填充整个panel,
他会根据子元素出现的先后顺序来填充他所能填充的空间。通过设置子元素的附加属性:DockPanel.Dock 的值:Top,Left,Right,Buttom,从而实现控制子元素显示的结果。
这个控件常用于布局windows和page,如包括菜单,状态栏,隐藏的面板等布局,(Visual studio 集成开发工具)
五、Grid(最常用)
类似于HTML中的Table
1、通过
类似于以上的语法来为Grid添加行和列。
2、每个单元格可以设置为空,也可以放多个元素。
3、RowSpan和ColumnSpan来设置单元格的跨行跨列属性。
4、行和列的高度和宽度的设置:auto:自动尺寸监控
(像素):绝对尺寸
(带“*”的数字)比例尺寸
5、GridSplitter
将GridSplitter放到一个一个单元格中可以通过鼠标改变该单元格的大小:
它的两个属性:设置为VerticalAlignment="Bottom" HorizontalAlignment="Stretch"时,就会在单元格的下方显示可以改变单元格的高度。
VerticalAlignment="Stretch" HorizontalAlignment="Right" 就会改变单元格的宽度。
值得注意的是:水平方向和垂直方向有一个的值必须设为Stretch,否则的话是一个小点,就无法实现其功能。
GridSplitter必须有一个显示的Width和Height这样才能看到,并且启到作用。
6、共享行和列的尺寸。
ColumnDefinition 和RowDefinition都有一个共同的属性:SharedSizeGroup 它的值是一个自定义的值,这样被标记的具有同样值的行和列就会一直有相同的呈现形式,其中的一个改变,另一个也会改变。
但值得注意的是在使用这个属性的时候,要将grid的共享开启: ....
六、处理内容溢出
1、剪切(clipping)
大部分面板都有一个Boolean的属性ClipToBounds并且它们的值都设为true,所以只要是溢出面板的都会被剪切掉
只有 Canvas面板的这个属性可以设置,并且ClipToBounds的值默认是false。
2、滚屏(scrolling)
只需将所有的元素(或面板)放入到一个.....内即可。他有属性:VerticalScrollBarVisibility(默认值Visible)和HorizontalScrollBarVisibility(默认值Auto)可以设置他们的值:Visible,Hidden,Auto,Disabled
3、缩放(scaling)
将内容放置到...之内即可实现缩放。
属性Stretch:值
Uniform(默认):显示整个元素到窗体的空间上,会随着窗体的大小而自动缩放,(但是某个方向上可能因为比例不合适而无法填充剩余空间)
UniformToFill:在保存外观比例同时缩放子元素来完全填充viewbox内的空间(但是某个方向上可能因为比例不合适而要截断部分显示)
None:不进行缩放,与不用viewbox没什么区别。
Fill:显示子元素到viewbox中,各个方向都要拉伸以填充所有空间。
属性StretchDirection值
Both(默认)扩大或缩小内容。DownOnly:如果合适缩小内容。如果内容足够小,viewbox保持当前内容大小不变。UpOnly:如果合适扩大内容,如果内容足够大,Viewbox保持当前内容大小不变。