微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Silverlight自适应布局

 

如果Grid是页面中的根元素,Grid不会根据子元素的尺寸来改变大小,在下面的例子里,Grid会充满整个页面
<Grid x:Name="Grid" ShowGridLines="True"  Background="Gray">
    <Grid.ColumnDeFinitions>
        <ColumnDeFinition />
        <ColumnDeFinition />
    </Grid.ColumnDeFinitions>
    <Grid.RowDeFinitions>
        <RowDeFinition />
        <RowDeFinition/>
    </Grid.RowDeFinitions>

    <Rectangle x:Name="BlueRect" Width="100" Height="100"
     Grid.Column="0" Grid.Row="0"
     Fill="Blue"/>

    <Rectangle x:Name="BlackRect" Width="100" Height="100"
     Grid.Column="0"  Grid.Row="1"
     Fill="Black"/>

    <Rectangle x:Name="GreenRect" Width="100" Height="100"
     Grid.Column="1"  Grid.Row="1"
     Fill="Green"/>
</Grid>

如果Grid包含在一个Canvas中
<Canvas x:Name="Carriar">
….上面的例子代码
</Canvas>
此时,Grid会根据子元素的尺寸改变自己的大小


如果 <Canvas> 不定义Width和Height,<Grid>的位置会不可捉摸

<Grid>中的<Border>如果不指定Width/Height或HorizontalAlignment/VerticalAlignment,<Border>会自动充满Grid,即 HorizontalAlignment/VerticalAlignment="Stretch"

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐