在横向模式下使用纵向尺寸显示UserControl Grid得到

时间:2011-03-21 04:30:55

标签: c# wpf windows-phone-7

我有一个UserControl的XAML:

<UserControl x:Class="SW.Resources.Controls.HistoryProgressBox"
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"
mc:Ignorable="d"
FontFamily="{StaticResource PhoneFontFamilyNormal}"
FontSize="{StaticResource PhoneFontSizeNormal}"
Foreground="{StaticResource PhoneForegroundBrush}"
d:DesignHeight="480" d:DesignWidth="480">

<Grid x:Name="LayoutRoot" Style="{StaticResource AppBackgroundStyle}">
    <Grid.RowDefinitions>
        <RowDefinition Height="Auto"/>
        <RowDefinition Height="Auto"/>
        <RowDefinition Height="Auto"/>
        <RowDefinition Height="Auto"/>
    </Grid.RowDefinitions>

    <Grid.ColumnDefinitions>
        <ColumnDefinition Width="223" />
        <ColumnDefinition Width="223" />
        <ColumnDefinition Width="10" />
    </Grid.ColumnDefinitions>

    <TextBlock x:Name="TitleText" Style="{StaticResource TitleListItemStyle}" Text="41xxfd" TextWrapping="Wrap" Grid.ColumnSpan="2"/>
    <TextBlock x:Name="leftValue"  HorizontalAlignment="Right" Style="{StaticResource DetailListItemStyle}" Text="Category: " Grid.Row="1" Grid.Column="0"/>
    <TextBlock x:Name="rightValue" Style="{StaticResource DetailListItemValueStyle}" Text="tv" Grid.Row="1" Grid.Column="1" />
    <TextBlock x:Name="subLeftValue" HorizontalAlignment="Right" Style="{StaticResource DetailListItemStyle}" Text="Size: " Grid.Row="2" Grid.Column="0" />
    <TextBlock x:Name="subRightValue" Style="{StaticResource DetailListItemValueStyle}" Text="400MB" Grid.Row="2" Grid.Column="1"  />
    <Rectangle Fill="Red" x:Name="progressColor" Grid.RowSpan="4" Grid.Column="2"/>
</Grid>

它看起来像我想要的肖像。但在景观方面,控制权很早就结束了。理想情况下,我会将此控制拉伸覆盖整个屏幕。这是否可以不用任何额外的代码来处理切换到横向?

1 个答案:

答案 0 :(得分:2)

如果您将其放在页面上的另一个网格中,则应调整大小以适合页面。

您可能希望使用基于百分比的列宽,以便列也可以调整大小。

e.g。

<Grid.ColumnDefinitions>
    <ColumnDefinition Width="223*" />
    <ColumnDefinition Width="223*" />
    <ColumnDefinition Width="10*" />
</Grid.ColumnDefinitions>