GridSplitter无法调整内容大小的问题

时间:2010-06-30 10:19:29

标签: silverlight xaml silverlight-4.0 gridsplitter

首先,我是XAML的新手,请原谅我,如果我做了一些愚蠢的事情。

我已将我的页面拆分为以下示例XAML(可在XamlPad中查看):

<Page xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
xmlns:sys="clr-namespace:System;assembly=mscorlib" 
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" 
mc:Ignorable="d" d:DesignWidth="640" d:DesignHeight="480">
    <Grid ShowGridLines="True">
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="200" MinWidth="150"  />
            <ColumnDefinition />
        </Grid.ColumnDefinitions>
        <Grid.RowDefinitions>
            <RowDefinition Height="3*" />
            <!--<RowDefinition Height="Auto" />-->
            <RowDefinition MaxHeight="25" Height="25" MinHeight="25" />
            <RowDefinition Height="1*"/>
        </Grid.RowDefinitions>
        <Grid Grid.RowSpan="4" Grid.Row="0" Grid.Column="0" VerticalAlignment="Stretch" HorizontalAlignment="Stretch" />
        <GridSplitter Grid.Row="0" Grid.RowSpan="4" Width="4" />
        <Frame >
        </Frame>
        <GridSplitter Grid.Row="0" Height="4" Grid.Column="1" HorizontalAlignment="Stretch" VerticalAlignment="Bottom" />
        <Grid Grid.Column="2" Grid.Row="2" VerticalAlignment="Stretch" HorizontalAlignment="Stretch"/>
        <ScrollViewer VerticalScrollBarVisibility="Auto" HorizontalScrollBarVisibility="Auto" Grid.Column="2" Grid.Row="3">
            <Grid VerticalAlignment="Stretch" HorizontalAlignment="Stretch" />
        </ScrollViewer>
    </Grid>
</Page>

我想要发生的是水平网格分割器调整顶部面板的大小,移动底部网格(我希望保持在25高度)和Scrollviewer控制下来。

我已经尝试将水平网格分割器放入它自己的Row中,这会将内容向下移动,但会缩小顶部网格的内容,这不是我正在寻找的内容。

有任何关于我做错的建议吗?是否与比例高度有关?

2 个答案:

答案 0 :(得分:1)

首先,您已将分割器定义为应用于多个行和列,但实际上它们必须具有自己的行或列,并且它们适用于相邻的行/列,因此您之前处于正确的轨道上

问题比例(星)行。对于分离器工作,至少有一个相邻的行/列必须固定(像素)大小,或者不用鼠标调整,而是用一些奇怪的比例运动调整。

我不明白你的“但它缩小了顶部网格的内容,这不是我正在寻找的”评论,所以它可能需要更多的解释,我已经做了一些猜测,但下面显示的XAML文件的分割器表现为:

 <Grid ShowGridLines="True">
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="191.5"  />
            <ColumnDefinition Width="8.5"/>
            <ColumnDefinition />
        </Grid.ColumnDefinitions>
        <Grid.RowDefinitions>
            <RowDefinition Height="194" />
            <RowDefinition Height="0.148*"/>
            <RowDefinition MaxHeight="25" Height="25" MinHeight="25" />
            <RowDefinition Height="0.852*"/>
        </Grid.RowDefinitions>
        <Grid Grid.RowSpan="4" Grid.Row="0" Grid.Column="0" VerticalAlignment="Stretch" HorizontalAlignment="Stretch" Grid.ColumnSpan="2" Margin="0,0,-0.5,0" />
        <sdk:GridSplitter Grid.Row="0" Grid.RowSpan="4" Grid.Column="1" HorizontalAlignment="Stretch" Margin="0.5,0,-0.5,0" />
        <Frame >
        </Frame>
        <sdk:GridSplitter Grid.Row="1" HorizontalAlignment="Stretch" Grid.ColumnSpan="3" />
        <Grid Grid.Column="2" Grid.Row="3" VerticalAlignment="Stretch" HorizontalAlignment="Stretch" Margin="0.5,0,-1,0"/>
        <ScrollViewer VerticalScrollBarVisibility="Auto" HorizontalScrollBarVisibility="Auto" Grid.Column="2" Grid.Row="3" Margin="0.5,0,-1,0">
            <Grid VerticalAlignment="Stretch" HorizontalAlignment="Stretch" />
        </ScrollViewer>
    </Grid>

答案 1 :(得分:1)

如果我正确理解你的问题。 您应该可以从内部网格中取出VerticalAlignment =“Stretch”和Horizo​​ntalAlignment =“Stretch”并获得所需内容。

gridsplitter不喜欢将Allignments设置为拉伸的不同行(或col)中的其他内容。