WPF的布局--StackPanel

1. StackPanel是以堆叠的方式来显示控件(从左到右,或者从上到下)

默认是从上到下显示的,并且宽度为StackPanel的宽度,高度自动适应控件中内容的高度(未对控件进行设置时)

如图:

代码如下:

 1 <Window x:Class="ReadRemoteRegistry.MainWindow"
 2         xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
 3         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
 4         Title="MainWindow" Height="350" Width="525">
 5     <Grid>
 6         <StackPanel>
 7             <Button Content="第一个按钮" Click="Button_Click"/>
 8             <Button Content="第二个按钮" Click="Button_Click_1"/>
 9             <Button Content="第三个按钮" Click="Button_Click_2"/>
10         </StackPanel>
11             <Button Content="Button" HorizontalAlignment="Left" Margin="220,199,0,0" VerticalAlignment="Top" Width="176" Height="41" Click="Button_Click_3"/>
12
13     </Grid>
14 </Window>

2.可以通过 Orientation [or??n‘te??n] n.方向 属性来设置布局的样式(水平还是垂直,即上面说的从左到右,或从上到下)

Orientation属性的可选值有:Horizontal 水平、 Vertical 垂直(默认),如图:

代码如下:高度为StackPanel的高度,宽度自动适应控件中内容的宽度

 1 <Window x:Class="ReadRemoteRegistry.MainWindow"
 2         xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
 3         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
 4         Title="MainWindow" Height="350" Width="525">
 5     <Grid>
 6         <StackPanel Orientation="Horizontal">
 7             <Button Content="第一个按钮" Click="Button_Click"/>
 8             <Button Content="第二个按钮" Click="Button_Click_1"/>
 9             <Button Content="第三个按钮" Click="Button_Click_2"/>
10         </StackPanel>
11             <Button Content="Button" HorizontalAlignment="Left" Margin="220,199,0,0" VerticalAlignment="Top" Width="176" Height="41" Click="Button_Click_3"/>
12
13     </Grid>
14 </Window>

3.控制StackPanel内控件的属性和状态

3.1. 内部控件的 Width 和 Height

如果未对内部的控制设置这两个属性,就会出现上述的:

垂直布局时(从上到下):宽度为StackPanel的宽,高度自动适应控件中内容的高度;

水平布局时(从左到右):高度为StackPanel的高,宽度自动适应控件中内容的宽度;

3.2. Margin属性,控制内部控件的外边距

3.2.1. Margin=”10”:各边距均为10;

3.2.2.Margin=”10,20,30,40”:设定左、上、右、下各边缘分别为10、20、30、40

3.2.3.使用拆分式方式设定(使用复杂属性),如上下为10,左右为20

<Button Content="Button A">
                            <Button.Margin>
                                    <Thickness Top="10" Bottom="10" Left="20" Right="20" />
                            </Button.Margin>
                    </Button>

3.3. 设置内部控件的对齐方式

3.3.1. HorizontalAlignment、(需要在整体Orientation="Vertical"的前提下)
                            设定控件的竖直对齐方式,如,设置水平对齐为Left、Right或Center

3.3.2. VerticalAlignment属性(需要在整体Orientation="Horizontal"的前提下)

设定控件的水平对齐方式,设置水平对齐为Top、Center、Stretch或Bottom

3.4. 设置内部控件的动态值

MinWidth: 允许的最小宽度

MinHeight: 允许的最小高度

MaxWidth:随控件变化时,允许的最大宽度

MaxHeight:随控件变化时,允许的最大高度

4.使用StackPanel可以让控制随内容变化而自适应

如下图:“OK"和"Cancel“按钮的对话框,因为按钮上的文字可能因字体的改变而发生大小改变,

我们应该避免固定按钮大小的写法(即不要设置控件Width的值,而是使用MinWidth此类属性)。

StackPanel会自动根据面板的大小的自动调整内部控件的大小。

我们就不用为按钮太大或太小而烦恼了。

   <StackPanel Margin="8" Orientation="Horizontal">
       <Button MinWidth="93">OK</Button>
       <Button MinWidth="93" Margin="10,0,0,0">Cancel</Button>
   </StackPanel>

参考:http://blog.sina.com.cn/s/blog_6c81891701017a34.html

时间: 2024-10-08 04:23:08

WPF的布局--StackPanel的相关文章

WPF简单布局 浅尝辄止

WPF的窗口只能包含一个元素,为了在WPF窗口中放置多个元素并创建更实用的用户界面,需要在窗口上放置一个容器,然后在容器中放置其它元素. 注意:造成这一限制的原因是window类继承自contentcontrol类, 说道简单布局不得不说下wpf的布局原则: 理想窗口要遵循的布局原则: 1,不应显示的设定元素的尺寸. 2,不应使用屏幕坐标指定元素的位置. 3,布局容器和他们的子元素“共享”可以使用的空间. 4,可以嵌套布局容器. 布局过程包括:测量阶段和排列阶段.所有的wpf布局容器都是派生自s

WPF UI布局(Layout)

WPF是专门用户界面技术,布局是核心功能之一. 每个布局元素都有自己的特点,要灵活使用. WPF中布局元素有如下: Grid:网格 可以自行定义行和列并通过行列的数量.行高和列宽来调整布局.类似Table. Grid具有ColumnDefinitions和RowDefinitions属性,它们分别是ColumnDefinition和RowDefinition的集合, 表示Grid定义了多少行多少列. StackPanel:栈式面板 可以将包含的元素在垂直或水平方向上排成一条直线,移除前一个元素后

WPF中的StackPanel、WrapPanel、DockPanel(转)

一.StackPanel StackPanel是以堆叠的方式显示其中的控件 1.可以使用Orientation属性更改堆叠的顺序 Orientation="Vertical" 默认,由上到下显示各控件.控件在未定义的前提下,宽度为StackPanel的宽度,高度自动适应控件中内容的高度 1: <StackPanel Orientation="Vertical"> 2: <Button>Button A</Button> 3: &l

WPF UI布局之概述

在线演示:http://v.youku.com/v_show/id_XNzA5NDk2Mjcy.html 清晰版视频+代码下载:http://115.com/lb/5lbeer0m9lad 一.简单介绍 本篇对WPF的布局控件做一个初步的概览,并分别演示Grid.StackPanel.Canvas.DockPanel和WrapPanel五个布局控件.. 主要内容包含: 1.UI布局的方式和关系. 2.WPF的布局理念. 3.五种布局控件的概述和演示. 4.小结. 二.UI布局的方式和关系 1.三

二,WPF的布局

布局过程 WPF布局包含两个阶段:一个测量(measure)阶段和一个排列(arrange)阶段.在测量阶段,窗口遍历所有子元素,并询问子元素它们所期望的尺寸.在排列阶段,窗口在合适的位置放置子元素. ActualHeight属性和ActualWidth属性:在某些情况下,可能希望使用代码检查窗口中某个元素的尺寸,这时使用Height和Width是没有用的,因为这两个属性是所期望的尺寸设置,可能和实际的渲染尺寸不同,在理想情况下,应当让元素的尺寸适应它们的内容,所以不要设置Height和Widt

WPF 动态布局Grid

1 //开启线程加载 2 Action a = () => 3 { 4 var row = 7; 5 var column = 9; 6 7 var path = "../../face_img/"; 8 var files = Directory.GetFiles(path); 9 for (var i = 0; i < row; i++) 10 { 11 faceGrid.RowDefinitions.Add(new RowDefinition()); 12 } 13

Wpf之布局

上一章大家有了自己的一个Hello World的wpf程序,今天咱们就一起走进WPF,一起来看看wpF的前台xaml这门语言的魅力. 写过web 的人都知道布局这个概念,在web中布局和样式是靠div+CSS来完成的,而在wpf中布局是靠容器来完成的,大家可以把wpf中的容器和web里面的div做对比,刚入门的同学也不要着急,没学过web一点不影响大家学习容器布局的概念的概念. 大家先来看个设计图吧 因为偷懒我直接切了个百度的图来看,更贴近大家的生活,哈哈. 咱们来分析一下,这张图片由4行2列来

WPF 之 布局(一)

WPF的布局控件都在 System.Windows.Controls.Panel 这个基类下面,使用 WPF提供的各种控件在WPF应用程序中界面进行布局,同时对各种子控件(如按钮.文本框,下拉框等)进行排列组合. Pane类的公共属性太多了.就简单介绍几个常见的属性如下表. 名称 说明 Cursor 获取或设置在鼠标指针位于此元素上时显示的光标. DataContext 获取或设置元素参与数据绑定时的数据上下文. Dispatcher 获取与此 DispatcherObject 关联的 Disp

XAML 布局StackPanel

<Window x:Class="WpfApplication2.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Title="MainWindow" Height="350" Widt