WPF Grid Layout

先来一张网格布局的图(照着BILIBILI 某个视频敲的)


image.png

Grid

网格布局,从上图我们可以看,一般可以用来划分大块的区域

行定义 Grid.RowDefinitions

    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="100"/>
            <RowDefinition />

        </Grid.RowDefinitions>
</Grid>

这是一个占位两行网格,第一格高度为 100(这里一般指的是相素PX)

Height属性

  • 默认不设值的时候,会按行数平均分
  • Auto 自动,会根据内容自动计算需要的高度
  • 0.8* 按比例分配(第一个默认的情况,其实就是都是 1*)

列定义 Grid.ColumnDefinitions

<Grid Grid.Row="1">
        <Grid.ColumnDefinitions>
              <ColumnDefinition Width="200" />
              <ColumnDefinition />
        </Grid.ColumnDefinitions>
</Grid>

两列的网格布局实现,第一列的宽度为200
Width属性同上Height

网格划分

真实的空间,不单单只划分列或者行,还可以两者组合

<Grid>

              <Grid.ColumnDefinitions>
                    <ColumnDefinition/>
                    <ColumnDefinition/>
                    <ColumnDefinition/>
                    <ColumnDefinition/>
                    <ColumnDefinition/>
                </Grid.ColumnDefinitions>

                <Grid.RowDefinitions>
                    <RowDefinition Height="0.8*"/>
                    <RowDefinition/>
                    <RowDefinition />
                </Grid.RowDefinitions>

<!-- 此外添加网格里的内容填充-->

  </Grid>
上面代码的布局

网格内容关联及合并单元格

指定关联单元格

  • 指定第几列 Grid.Column
  • 指定第几行 Grid.Row
    比如,我们如何将第一行,第二个单元格背景改为蓝色
<!-- 指定 填充的颜色为 Grid.Column="1"( 第二列),行为默认0(第1行 Grid.Row="0")-->
<Border Background="#0396FF" Margin="10" Grid.Column="1"/>

小插曲(以下内容是错误的,这里展示自己的一个思维过程 ):
一开始以为某一列的内容,直接在当前ColumnDefinition 的标签里填充,类型于HTML 元素,一层包一层

<ColumnDefinition >
    <Button>
</ColumnDefinition >

这样不就可以不用另外指定了。

BUT! Too young,too simple,sometimes naive

正常我们一般写GUI都是这样,但我们现在是网格,网格定位必须有行有列,上面的写法只能单独指定行里的内容或者列里的内容

合并单元格

  • 列合并 Grid.ColumnSpan
  • 行合并 Grid.RowSpan
<Border Background="#623AA2" Grid.Row="1" Grid.ColumnSpan="3" Margin="10"/>

综合例子

顶图的例子代码如下

<Window x:Class="WPFGridLayout.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:WPFGridLayout"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
<!-- 最外层Grid -->
    <Grid>

      <!-- 分为二行-->
        <Grid.RowDefinitions>
            <RowDefinition Height="100"/>
            <RowDefinition />
        </Grid.RowDefinitions>
      <!-- 设置第一行背景 -->
        <Border Background="#28C76F"/>

      <!--将第二行分为两列 -->
        <Grid Grid.Row="1">
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="200" />
                <ColumnDefinition />
            </Grid.ColumnDefinitions>

            <Border Background="#92FFC0" Grid.Column="0" Margin="0,10,10,10"/>

            <!--将第二列 再 用 Grid划分 -->
            <Grid Grid.Column="1">
                <!-- 分为 5 列 -->
                <Grid.ColumnDefinitions>
                    <ColumnDefinition/>
                    <ColumnDefinition/>
                    <ColumnDefinition/>
                    <ColumnDefinition/>
                    <ColumnDefinition/>
                </Grid.ColumnDefinitions>
                <!-- 分为3行 -->
                <Grid.RowDefinitions>
                    <RowDefinition Height="0.8*"/>
                    <RowDefinition/>
                    <RowDefinition />
                </Grid.RowDefinitions>

                <!-- 设置第一行5列的背景 -->
                <Border Background="#F8D800" Margin="10"/>
                <Border Background="#0396FF" Margin="10" Grid.Column="1"/>
                <Border Background="#EA5455" Margin="10" Grid.Column="2"/>
                <Border Background="#7367F0" Margin="10" Grid.Column="3"/>
                <Border Background="#32CCBC" Margin="10" Grid.Column="4"/>

                <!-- 将第二行(ROW=1),第0列开始的三列合并为一个背景 -->
                <Border Background="#623AA2" Grid.Row="1" Grid.ColumnSpan="3" Margin="10"/>
                <!-- 将第二行(ROW=1),第3列开始的两列合并为一个背景 -->
                <Border Background="#F55555" Grid.Row="1" Grid.Column="3" Grid.ColumnSpan="3" Margin="10"/>
                
                
                <Border Background="#52E5E7" Grid.Row="2" Grid.ColumnSpan="3" Margin="10"/>
                <Border Background="#79F1A4" Grid.Row="2" Grid.Column="3" Grid.ColumnSpan="3" Margin="10"/>
            </Grid>
        </Grid>
    </Grid>
</Window>

我们可以发现,我们的标签最后有 三层 </Grid>,所以Grid 是可以无限套娃(嵌套,一层套一层)。
另:
Border
貌似是个装饰产物,可以用以设置控件的背景,目前还不是很了解

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,919评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,567评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,316评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,294评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,318评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,245评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,120评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,964评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,376评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,592评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,764评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,460评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,070评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,697评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,846评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,819评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,665评论 2 354

推荐阅读更多精彩内容