Windows Phone 7 使用Canvas Grid StackPanel进行布局管理

简介:

一、布局原理

  首先,所有元素的最顶层必须是一个容器(通常如Grid,Canvas,StackPanel等),然后在容器中摆放元素,容器中也可能包含容器。这里 的容器就像行政长官一样,他们负责分配元素的空间。同样,首先顶层的容器一个一个的问自己的子元素:你想要多大的空间?如果子元素也是容器,它又继续向下 递归,最后又顶层开始向上汇报。这就是所谓的测量。

  测量完之后就是排列,这个时候每个容器知道自己每个子元素想要的空间大小,就按自己的实际情况进行分配。一致递归到最底层。

  这里的容器也一样,容器拥有完全的分配权,不过这里容器不仅仅是分配空间,还决定元素的位置,因为空间总是跟位置相关的。也就是说,容器说想给你多大空间你就只有有那么大的空间可使用,容器想让你摆在什么位置,你就得乖乖呆着什么位置。

二、继承层次结构

System.Object 
System.Windows.DependencyObject
System.Windows.UIElement
System.Windows.FrameworkElement
System.Windows.Controls.Panel
System.Windows.Controls.Canvas
System.Windows.Controls.Grid
System.Windows.Controls.StackPanel
System.Windows.Controls.VirtualizingPanel
 

 

三、Canvas Grid StackPanel 介绍

Canvas-画布 定义一个区域,在此区域内,您可以使用相对于 Canvas 区域的坐标显式定位子元素。
Canvas的规则是:我读取附加属性Canvas.Left,Canvas.Right,Canvas.Top,Canvas.Bottom,并以此来决定元素的位置。

可以嵌套 Canvas 对象。嵌套对象时,每个对象使用的坐标都是相对于直接包含它们的 Canvas 而言的。

每个子对象都必须是 UIElement。在 XAML 中,将子对象声明为对象元素,这些元素是 Canvas 对象元素的内部 XML。在代码中,可以通过获取由 Children 属性访问的集合来操作 Canvas 子对象的集合。

由于 Canvas 为 UIElement 类型,因此可以嵌套 Canvas 对象。

很多情况下,Canvas 仅仅用作其他对象的容器,而没有任何可见属性。如果满足以下任一条件,Canvas 即不可见:

Height 属性等于 0。

Width 属性等于 0。

Background 属性等于 nullNothingnullptrunitnull 引用(在 Visual Basic 中为 Nothing)。

Opacity 属性等于 0。

Visibility 属性等于 Visibility..::..Collapsed。

Canvas 的某个上级对象不可见。

Grid-表格 定义由行和列组成的灵活网格区域。
Grid的规则是:我把我这个空间分成一格一格的格子,看起来有些像Table,在我里面的元素我完全按照附加属性Grid.Row,Grid.Column,Grid.RowSpan,Grid.ColumnSpan来决定其大小和位置。

可以通过使用 Grid.Column 和 Grid.Row 附加属性,在 Grid 的特定单元格中定位对象。

列和行可以利用 Star 缩放来按比例分配剩余空间。当选择 Star 作为行或列的高度或宽度时,该行或列将得到一个剩余可用空间的加权比例分配。Star 大小调整是默认行为。

StackPanel-堆放容器 将子元素排列成一行(可沿水平或垂直方向)。
StackPanel的规则是:根据附加属性,我要么让元素横着排列,要么竖着排列。

StackPanel 为启用布局的 Panel 元素之一。在特定情形下,例如,要将一组对象排列在竖直或水平列表(例如,项的水平或竖直菜单)中,StackPanel 很有用。设置 Orientation 属性可确定列表的方向。Orientation 属性的默认值为 Vertical。

StackPanel 中内容的 HorizontalAlignment 和 VerticalAlignment 默认值均为 Stretch。

三、实例

Canvas

 

 

 


 
 
  1. <!--LayoutRoot contains the root grid where all other page content is placed--> 
  2.     <Grid x:Name="LayoutRoot" Background="Transparent"> 
  3.         <Grid.RowDefinitions> 
  4.             <RowDefinition Height="Auto"/> 
  5.             <RowDefinition Height="*"/> 
  6.         </Grid.RowDefinitions> 
  7.  
  8.         <!--TitlePanel contains the name of the application and page title--> 
  9.         <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28"> 
  10.             <TextBlock x:Name="ApplicationTitle" Text="ELLIPSE CHAIN" Style="{StaticResource PhoneTextNormalStyle}"/> 
  11.             <TextBlock x:Name="PageTitle" Text="main page" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/> 
  12.         </StackPanel> 
  13.  
  14.         <!--ContentPanel - place additional content here--> 
  15.         <Grid x:Name="ContentPanel" Grid.Row="1" Margin="1 0 0 0"> 
  16.             <Canvas> 
  17.                 <Canvas.Resources> 
  18.                     <Style x:Key="ellipseStyle"   
  19.                            TargetType="Ellipse"> 
  20.                         <Setter Property="Width" Value="100" /> 
  21.                         <Setter Property="Height" Value="100" /> 
  22.                         <Setter Property="Stroke" Value="{StaticResource PhoneAccentBrush}" /> 
  23.                         <Setter Property="StrokeThickness" Value="10" /> 
  24.                     </Style> 
  25.                 </Canvas.Resources> 
  26.                   
  27.                 <Ellipse Style="{StaticResource ellipseStyle}" 
  28.                          Canvas.Left="0" Canvas.Top="0" /> 
  29.  
  30.                 <Ellipse Style="{StaticResource ellipseStyle}" 
  31.                          Canvas.Left="52" Canvas.Top="53" /> 
  32.                   
  33.                 <Ellipse Style="{StaticResource ellipseStyle}" 
  34.                          Canvas.Left="116" Canvas.Top="92" /> 
  35.  
  36.                 <Ellipse Style="{StaticResource ellipseStyle}" 
  37.                          Canvas.Left="190" Canvas.Top="107" /> 
  38.  
  39.                 <Ellipse Style="{StaticResource ellipseStyle}" 
  40.                          Canvas.Left="263" Canvas.Top="92" /> 
  41.  
  42.                 <Ellipse Style="{StaticResource ellipseStyle}" 
  43.                          Canvas.Left="326" Canvas.Top="53" /> 
  44.  
  45.                 <Ellipse Style="{StaticResource ellipseStyle}" 
  46.                          Canvas.Left="380" Canvas.Top="0" /> 
  47.             </Canvas> 
  48.         </Grid> 
  49.     </Grid> 

Windows Phone 7 使用Canvas Grid StackPanel进行布局管理

一、布局原理

  首先,所有元素的最顶层必须是一个容器(通常如Grid,Canvas,StackPanel等),然后在容器中摆放元素,容器中也可能包含容器。这里 的容器就像行政长官一样,他们负责分配元素的空间。同样,首先顶层的容器一个一个的问自己的子元素:你想要多大的空间?如果子元素也是容器,它又继续向下 递归,最后又顶层开始向上汇报。这就是所谓的测量。

  测量完之后就是排列,这个时候每个容器知道自己每个子元素想要的空间大小,就按自己的实际情况进行分配。一致递归到最底层。

  这里的容器也一样,容器拥有完全的分配权,不过这里容器不仅仅是分配空间,还决定元素的位置,因为空间总是跟位置相关的。也就是说,容器说想给你多大空间你就只有有那么大的空间可使用,容器想让你摆在什么位置,你就得乖乖呆着什么位置。

二、继承层次结构

System.Object 
System.Windows.DependencyObject
System.Windows.UIElement
System.Windows.FrameworkElement
System.Windows.Controls.Panel
System.Windows.Controls.Canvas
System.Windows.Controls.Grid
System.Windows.Controls.StackPanel
System.Windows.Controls.VirtualizingPanel
 

 

三、Canvas Grid StackPanel 介绍

Canvas-画布 定义一个区域,在此区域内,您可以使用相对于 Canvas 区域的坐标显式定位子元素。
Canvas的规则是:我读取附加属性Canvas.Left,Canvas.Right,Canvas.Top,Canvas.Bottom,并以此来决定元素的位置。

可以嵌套 Canvas 对象。嵌套对象时,每个对象使用的坐标都是相对于直接包含它们的 Canvas 而言的。

每个子对象都必须是 UIElement。在 XAML 中,将子对象声明为对象元素,这些元素是 Canvas 对象元素的内部 XML。在代码中,可以通过获取由 Children 属性访问的集合来操作 Canvas 子对象的集合。

由于 Canvas 为 UIElement 类型,因此可以嵌套 Canvas 对象。

很多情况下,Canvas 仅仅用作其他对象的容器,而没有任何可见属性。如果满足以下任一条件,Canvas 即不可见:

Height 属性等于 0。

Width 属性等于 0。

Background 属性等于 nullNothingnullptrunitnull 引用(在 Visual Basic 中为 Nothing)。

Opacity 属性等于 0。

Visibility 属性等于 Visibility..::..Collapsed。

Canvas 的某个上级对象不可见。

Grid-表格 定义由行和列组成的灵活网格区域。
Grid的规则是:我把我这个空间分成一格一格的格子,看起来有些像Table,在我里面的元素我完全按照附加属性Grid.Row,Grid.Column,Grid.RowSpan,Grid.ColumnSpan来决定其大小和位置。

可以通过使用 Grid.Column 和 Grid.Row 附加属性,在 Grid 的特定单元格中定位对象。

列和行可以利用 Star 缩放来按比例分配剩余空间。当选择 Star 作为行或列的高度或宽度时,该行或列将得到一个剩余可用空间的加权比例分配。Star 大小调整是默认行为。

StackPanel-堆放容器 将子元素排列成一行(可沿水平或垂直方向)。
StackPanel的规则是:根据附加属性,我要么让元素横着排列,要么竖着排列。

StackPanel 为启用布局的 Panel 元素之一。在特定情形下,例如,要将一组对象排列在竖直或水平列表(例如,项的水平或竖直菜单)中,StackPanel 很有用。设置 Orientation 属性可确定列表的方向。Orientation 属性的默认值为 Vertical。

StackPanel 中内容的 HorizontalAlignment 和 VerticalAlignment 默认值均为 Stretch。

三、实例

Canvas

按 Ctrl+C 复制代码
 

 

Grid

 


      
      
  1. <!--LayoutRoot contains the root grid where all other page content is placed--> 
  2.     <Grid x:Name="LayoutRoot" Background="Transparent"> 
  3.         <Grid.RowDefinitions> 
  4.             <RowDefinition Height="Auto"/> 
  5.             <RowDefinition Height="*"/> 
  6.         </Grid.RowDefinitions> 
  7.  
  8.         <!--TitlePanel contains the name of the application and page title--> 
  9.         <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28"> 
  10.             <TextBlock x:Name="ApplicationTitle" Text="SIMPLE GRID" Style="{StaticResource PhoneTextNormalStyle}"/> 
  11.             <TextBlock x:Name="PageTitle" Text="main page" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/> 
  12.         </StackPanel> 
  13.  
  14.         <!--ContentPanel - place additional content here--> 
  15.         <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0"> 
  16.             <Grid.RowDefinitions> 
  17.                 <RowDefinition Height="Auto" /> 
  18.                 <RowDefinition Height="*" /> 
  19.                 <RowDefinition Height="Auto" /> 
  20.             </Grid.RowDefinitions> 
  21.               
  22.             <Grid.ColumnDefinitions> 
  23.                 <ColumnDefinition Width="2*" /> 
  24.                 <ColumnDefinition Width="*" /> 
  25.             </Grid.ColumnDefinitions> 
  26.               
  27.             <TextBlock Grid.Row="0" 
  28.                        Grid.Column="0" 
  29.                        Grid.ColumnSpan="2" 
  30.                        Text="Heading at top of Grid" 
  31.                        HorizontalAlignment="Center" /> 
  32.               
  33.             <Image Grid.Row="1" 
  34.                    Grid.Column="0" 
  35.                    Source="Images/BuzzAldrinOnTheMoon.png" /> 
  36.               
  37.             <Ellipse Grid.Row="1" 
  38.                      Grid.Column="1" 
  39.                      Stroke="{StaticResource PhoneAccentBrush}" 
  40.                      StrokeThickness="6" /> 
  41.               
  42.             <TextBlock Grid.Row="2" 
  43.                        Grid.Column="0" 
  44.                        Grid.ColumnSpan="2" 
  45.                        Text="Footer at bottom of Grid" 
  46.                        HorizontalAlignment="Center" /> 
  47.               
  48.         </Grid> 
  49.     </Grid> 

 StackPanel

 

 

 


 
 
  1. <!--LayoutRoot contains the root grid where all other page content is placed--> 
  2.     <Grid x:Name="LayoutRoot" Background="Transparent"> 
  3.         <Grid.RowDefinitions> 
  4.             <RowDefinition Height="Auto"/> 
  5.             <RowDefinition Height="*"/> 
  6.         </Grid.RowDefinitions> 
  7.  
  8.         <!--TitlePanel contains the name of the application and page title--> 
  9.         <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28"> 
  10.             <TextBlock x:Name="ApplicationTitle" Text="STACKPANEL WITH FOUR ELEMENTS" Style="{StaticResource PhoneTextNormalStyle}"/> 
  11.         </StackPanel> 
  12.  
  13.         <!--ContentPanel - place additional content here--> 
  14.         <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0"> 
  15.             <StackPanel Name="stackPanel" 
  16.                         Orientation="Vertical"> 
  17.                 <TextBlock Text="TextBlock aligned at right bottom" 
  18.                            HorizontalAlignment="Right" 
  19.                            VerticalAlignment="Bottom" /> 
  20.  
  21.                 <Image Source="Images/BuzzAldrinOnTheMoon.png" /> 
  22.  
  23.                 <Ellipse Stroke="{StaticResource PhoneAccentBrush}" 
  24.                          StrokeThickness="12" /> 
  25.  
  26.                 <TextBlock Text="TextBlock aligned at left top" 
  27.                            HorizontalAlignment="Left" 
  28.                            VerticalAlignment="Top" /> 
  29.             </StackPanel> 
  30.         </Grid> 
  31.     </Grid> 

 


本文转自linzheng 51CTO博客,原文链接:http://blog.51cto.com/linzheng/1079159


相关文章
|
6月前
|
Windows
构建布局良好的Windows程序
构建布局良好的Windows程序
|
Android开发 iOS开发 Windows
Windows Phone 寿终正寝了,这些经典机型你还记得吗?
不久前,随着最后一家WP手机厂商惠普宣布取消今后Windows Phone的研发计划,以及微软官方声明对WP8.1系统今后所有升级维护的终止,WP手机,作为曾经和安卓手机、苹果手机并驾齐驱的三大智能手机之一,正式寿终正寝。
1473 0
Windows Phone 寿终正寝了,这些经典机型你还记得吗?
|
XML 开发框架 前端开发
Windows Phone快速入门需掌握哪些能力
在此之前,先普及下Windows Phone的概念和开发工具的介绍。 Windows Phone是微软公司开发的手机操作系统,它将微软旗下的Xbox Live游戏、Xbox Music音乐与独特的视频体验集成至手机中。2012年6月21日,微软正式发布Windows Phone 8,采用和Windows 8相同的Windows NT内核,同时也针对市场的Windows Phone 7.5发布Windows Phone 7.8。
172 0
Windows Phone快速入门需掌握哪些能力
|
移动开发 Android开发 开发者
Windows Phone 8.1 新功能汇总 开发者预览版开放下载
在Build 2014大会上,微软正式发布了传闻已久的Windows Phone 8.1系统,所有的Windows Phone 8手机都可以升级,微软这次可谓是十分厚道。虽然并非迭代升级,但WP 8.1还是拥有很多重大更新,对于微软进一步完善移动平台拥有积极的意义。下面,就一起来了解一下WP 8.1的主要新特性。
265 0
Windows Phone 8.1 新功能汇总 开发者预览版开放下载
|
编解码 前端开发 JavaScript
Windows Phone 下开发 LBS 应用
基于位置的服务(Location Based Service,LBS),它是通过电信移动运营商的无线电通讯网络(如GSM网、CDMA网)或外部定位方式(如GPS)获取移动终端用户的位置信息(地理坐标,或大地坐标),在GIS(Geographic Information System,地理信息系统)平台的支持下,为用户提供相应服务的一种增值业务。
202 0
|
Windows 缓存 异构计算
背水一战 Windows 10 (72) - 控件(控件基类): UIElement - UIElement 的位置, UIElement 的布局, UIElement 的其他特性
原文:背水一战 Windows 10 (72) - 控件(控件基类): UIElement - UIElement 的位置, UIElement 的布局, UIElement 的其他特性 [源码下载] 背水一战 Windows 10 (72) - 控件(控件基类): UIElement - UIE...
1050 0
|
物联网 开发工具 Windows
【WinHec启示录】透过Windows 10技术布局,谈微软王者归来
每个时代都有王者,王者的成功,往往是因为恰逢其时地发布了一个成功的产品(具有里程碑意义,划时代的产品)。
694 0
|
22天前
|
边缘计算 安全 网络安全
|
15天前
|
数据安全/隐私保护 Windows
安装 Windows Server 2019
安装 Windows Server 2019