WPF Step By Step 完整布局介绍

回顾

        上一篇,我们介绍了基本控件及控件的重要属性和用法,我们本篇详细介绍WPF中的几种布局容器及每种布局容器的使用场景,当

然这些都是本人在实际项目中的使用经验,可能还存在错误之处,还请大家指出。

本文大纲

1、Grid

2、StackPanel

3、DockPanel

4、WrapPanel

Grid

1、Row和Column

我们下面来介绍Grid的行的用法,及我们在UI设计过程中需要注意的细节。

由于前面我们在第一章中已经介绍了基本的关于Grid的表格行和列的定义及相关属性,为了防止大家遗忘,我们这里再次介绍下:

WPF Step By Step 完整布局介绍_第1张图片

为了加深大家对Grid布局的印象,我们这里加入控件来展示效果。

下面在每个单元格都加入子控件

WPF Step By Step 完整布局介绍_第2张图片

上面指定了控件在Grid表格中的哪一行那一列,如果我们的某个控件跨行或者跨列如何做呢?

WPF Step By Step 完整布局介绍_第3张图片

关于跨行和跨列一样,只不过将Grid.ColumnSpan换成Grid.RowSpan。

下面介绍,在Grid如何将控件设置为自适应宽度和高度,或者是固定宽度或固定高度时,应该注意的细节。

WPF Step By Step 完整布局介绍_第4张图片

1、自适应区域:

WPF Step By Step 完整布局介绍_第5张图片

2、顶部对齐或底部对齐

WPF Step By Step 完整布局介绍_第6张图片

对于顶部对齐和底部对齐,相对来说都一样。

3、左右对齐时:

WPF Step By Step 完整布局介绍_第7张图片

4、下面来举个例子,我们来如何分析,根据原型来使用Grid布局来达到要求和目标:

例如下图:

WPF Step By Step 完整布局介绍_第8张图片

我们以博客园为例,可能例子不太合适,但是如果我们想做一个博客园的桌面版,保持风格一致的情况下,如果我们使用Grid布局如何来布局呢?

A、有Logo图片,上面还有设置等菜单,所以,我们可以吧这块设置为二行,这样比较容易区分页面的布局和设置

B、下面有几个二级菜单,新闻、博问等 一行

C、左侧有网站分类。必须1列

D、右侧有内容区。上面有区分首页、精华、候选、新闻、关注等、1列

E、右侧有找找看、还有最新新闻等 1列。

F、最下面,肯定还有状态栏,如果我们开发桌面系统。1行

 

根据上面的分析,我们的Grid表格至少5行、3列

关于其他的设计,我们通过Grid表格的组合来进行控制。

下面我们就来实现下:

先设置大体布局如下:

WPF Step By Step 完整布局介绍_第9张图片

关于上述布局的具体实现如下:

        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindow" Height="600" Width="800">
   
       
           
           
           
           
           
       

       
           
           
           
       

       
           
               
               
               
               
               
               
               
               
           

       

       
           
       

       
           
               
               
               
               
               
           

       

   

 

从上面的代码可以看出来,非常的简单,Grid特别适合软件系统的整体布局,在实际的项目中通过Grid与其他的布局控件相结合一起完成页面的整体布局。

StackPanel

StackPanel 适合水平或者垂直方向的布局,在上面的例子中我们大量的使用该种布局方式。适合局部区域的布局。比如博客园中的如下区域就可以采用StackPanel进行布局。

WPF Step By Step 完整布局介绍_第10张图片

WPF Step By Step 完整布局介绍_第11张图片

WPF Step By Step 完整布局介绍_第12张图片

对于这类的固定的区域,我们可以不适用Grid来进行布局,使用StackPanel也可以达到目标。

我们来使用StackPanel来进行布局


               
                   
                       

DockPanel

DockPanel停靠容器,专门负责自适应窗口的布局,之前我们介绍了DockPanel的布局设置,这里再回顾下:


               
               

               
               

               
               

               
                   
                       
                           
                         
                         
                         
                         
                         
                         
                         
                     

                 
             
         

         
             
             
             
             
             
         

         
             
                 
                     
                         

 

 

 

WrapPanel

WrapPanel容器我们也介绍过,该容器可以看做自动换行功能的StackPanel容器。下面我们就来分析下该容器的一般应用场景。

WPF Step By Step 完整布局介绍_第16张图片 我们看到了windows8中的如下页面,如果我们仿制该页面的时候,其实我们可以采用wrappanel来实现自动的换行,下面我们来试试吧

最终代码如下:

        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="Window8Window" Height="600" Width="800">
   
       
           
           
       

       
           

       
           
               
               
               
               
               
               
               
               
               
               
               
               
               
               
               
               
           

       

   

 

运行后,效果如下:

WPF Step By Step 完整布局介绍_第17张图片

当然,我们的界面效果,还打不到美感,但是的确是自动换行。我们将水平方向,修改为垂直方向后,运行:

WPF Step By Step 完整布局介绍_第18张图片

运行查看效果。

WPF Step By Step 完整布局介绍_第19张图片

通过上面的简单案例,我们基本上知道了wrapPanel的用法。

 

总结

通过上面的介绍和demo的演示,我们知道了如何在项目中什么情况下,使用什么样的布局容器,通过实际的案例,我们更容易理解和掌握布局的模式。错误之处,还请大家反馈,我及时改正,谢谢!

你可能感兴趣的:(WPF Step By Step 完整布局介绍)