有些控制不伸展

时间:2014-12-03 18:43:02

标签: c# .net wpf xaml

在这个窗口中,我有许多不同的控件,我想伸展可能的 但是'stackGroup','listBox1','listBox2'有一些控件没有拉伸..为什么? 这种方式也是我这样做的方式

<Window x:Class="TwoColumnGridSample.Window1"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Loaded="Window_Loaded"
        Title="Window1" Height="759" Width="800">
    <Grid Margin="0,0,0,95">
        <Grid.RowDefinitions>
            <RowDefinition Height="509"></RowDefinition>
            <RowDefinition Height="111"></RowDefinition>
        </Grid.RowDefinitions>
        <Grid Grid.Row="0" Height="472" VerticalAlignment="Top">
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="165" />
                <ColumnDefinition Width="*" />
            </Grid.ColumnDefinitions>
            <StackPanel Grid.Column="0" VerticalAlignment="Stretch" Margin="0,0,0,163">
                <ListBox Name="listBox1" SelectedItem="{Binding SelectedItem}" Width="165" ItemsSource="{Binding Buttons}" SelectionChanged="ListBox_SelectionChanged" HorizontalContentAlignment="Left" VerticalAlignment="Stretch"  >
                    <ListBox.ItemTemplate>
                        <DataTemplate>
                            <Button Content="{Binding .}" Click="Button_Click"  Style="{StaticResource  listboxbuttons}"></Button>
                        </DataTemplate>
                    </ListBox.ItemTemplate>
                </ListBox>
            </StackPanel>
            <StackPanel Name="stackGroup" HorizontalAlignment="Stretch" Grid.Column="1" Height="457" VerticalAlignment="Top" >
                <Grid HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Height="460" Margin="0,0,10,0" >
                    <Grid.RowDefinitions>
                        <RowDefinition Height="100" />
                        <RowDefinition Height="24" />
                        <RowDefinition Height="316"/>
                        <RowDefinition Height="60" />
                    </Grid.RowDefinitions>
                    <Image x:Name="imageMap" Source="Resources/images.jpg" HorizontalAlignment="Stretch" Grid.Row="0" Stretch="Fill" Margin="2,0,0,0" />
                    <Border  BorderBrush="Green" BorderThickness="3" CornerRadius="1,1,1,1" Margin="2,4,0,17" Grid.Row="1" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Grid.RowSpan="2">
                        <Grid Grid.Row="1" Margin="3,3,3,3">
                            <GroupBox Header="Club Badge" HorizontalAlignment="Left" VerticalAlignment="Top" Height="123" Width="134"/>
                            <GroupBox Header="Goalie" HorizontalAlignment="Left" VerticalAlignment="Top" Height="179" Width="134" Margin="0,128,0,0"/>
                            <GroupBox Header="Defender" HorizontalAlignment="Left" Margin="139,0,0,0" VerticalAlignment="Top" Height="307" Width="134"/>
                            <GroupBox Header="MidFielder" HorizontalAlignment="Left" Margin="278,0,0,0" VerticalAlignment="Top" Height="307" Width="134"/>
                            <GroupBox Header="GroupBox" HorizontalAlignment="Left" Margin="417,0,0,0" VerticalAlignment="Top" Height="307" Width="155"/>
                        </Grid>
                    </Border>
                    <ProgressBar BorderBrush="#FF6081B0" HorizontalAlignment="Stretch" Margin="2,303,0,43" Value="45" Grid.Row="2" Foreground="#FF6081B0" Grid.RowSpan="2"  />
                </Grid>
            </StackPanel>
        </Grid>
        <ListBox Height="96" HorizontalAlignment="Stretch" Margin="0,0,0,0" VerticalAlignment="Bottom" Name="listBox2" Width="782" Grid.RowSpan="2">
            <ListBox.ItemsPanel>
                <ItemsPanelTemplate>
                    <StackPanel Orientation="Horizontal" />
                </ItemsPanelTemplate>
            </ListBox.ItemsPanel>
            <ListBox.ItemContainerStyle>
                <Style TargetType="ListBoxItem">
                    <Setter Property="Padding" Value="30 0 30 0" />
                </Style>
            </ListBox.ItemContainerStyle>
            <ListBoxItem Content="Vertical Item 1" />
            <ListBoxItem Content="Vertical Item 2" />
            <ListBoxItem Content="Vertical Item 3" />
            <ListBoxItem Content="Vertical Item 4" />
            <ListBoxItem Content="Vertical Item 5" />
        </ListBox>
    </Grid>
</Window>

1 个答案:

答案 0 :(得分:1)

this question中的答案相同。 StackPanel不会将拉伸对齐方向与方向相同。因此,方向为垂直的StackPanel不会影响子项的VerticalAlignment。

listBox1没有拉伸,因为它的VerticalAlignment是拉伸的,它的容器StackPanel的方向是Vertical(这是它的默认值)。您可以将StackPanel更改为水平,将其替换为另一个容器(例如DockPanel),或者将其全部删除,因为它只包含一个元素。

类似的推理可以适用于您的其他问题