1

我有一种情况,我需要在两个组框中的网格之间共享列的宽度,XAML 看起来像这样:

<GroupBox Header="Box A">
        <StackPanel Orientation="Horizontal">
            <!-- Labels -->
            <Grid>
                <Grid.ColumnDefinitions>
                    <ColumnDefinition SharedSizeGroup="Labels"></ColumnDefinition>
                </Grid.ColumnDefinitions>
                <Grid.RowDefinitions>
                    <RowDefinition SharedSizeGroup="Rows"></RowDefinition>
                </Grid.RowDefinitions>

                <Label Grid.Column="0" Grid.Row="0">Label A</Label>
            </Grid>

            <!-- Fields -->
            <ItemsControl Grid.IsSharedSizeScope="True" ItemsSource="{Binding Items}">
                <ItemsControl.ItemsPanel>
                    <ItemsPanelTemplate>
                        <StackPanel Orientation="Horizontal"></StackPanel>
                    </ItemsPanelTemplate>
                </ItemsControl.ItemsPanel>
                <ItemsControl.ItemTemplate>
                    <DataTemplate>
                        <Grid>
                            <Grid.RowDefinitions>
                                <RowDefinition SharedSizeGroup="Rows"></RowDefinition>
                            </Grid.RowDefinitions>

                            <TextBox Text="{Binding PropertyA}"></TextBox>
                        </Grid>
                    </DataTemplate>
                </ItemsControl.ItemTemplate>
            </ItemsControl>
        </StackPanel>
    </GroupBox>

    <GroupBox Header="Box B">
        <StackPanel Orientation="Horizontal">
            <!-- Labels -->
            <Grid>
                <Grid.ColumnDefinitions>
                    <ColumnDefinition SharedSizeGroup="Labels"></ColumnDefinition>
                </Grid.ColumnDefinitions>
                <Grid.RowDefinitions>
                    <RowDefinition SharedSizeGroup="Rows"></RowDefinition>
                </Grid.RowDefinitions>

                <Label Grid.Column="0" Grid.Row="0">Label B</Label>
            </Grid>

            <!-- Fields -->
            <ItemsControl Grid.IsSharedSizeScope="True" ItemsSource="{Binding Items}">
                <ItemsControl.ItemsPanel>
                    <ItemsPanelTemplate>
                        <StackPanel Orientation="Horizontal"></StackPanel>
                    </ItemsPanelTemplate>
                </ItemsControl.ItemsPanel>
                <ItemsControl.ItemTemplate>
                    <DataTemplate>
                        <Grid>
                            <Grid.RowDefinitions>
                                <RowDefinition SharedSizeGroup="Rows"></RowDefinition>
                            </Grid.RowDefinitions>

                            <TextBox Text="{Binding PropertyB}"></TextBox>
                        </Grid>
                    </DataTemplate>
                </ItemsControl.ItemTemplate>
            </ItemsControl>
        </StackPanel>
    </GroupBox>

我尝试在包含子网格的 StackPanel 和 GroupBox 上将 Grid.IsSharedSizeScope 设置为 true,但这不起作用。我想知道在这种情况下我应该采取什么方法来共享网格列定义与“标签”的 SharedSizeGroup 之间的大小?

谢谢,

亚历克斯。

4

1 回答 1

3

用 a包围你的两个GroupBoxesGrid并设置Grid.IsSharedSizeScope.

<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">
  <Grid Grid.IsSharedSizeScope="True">
    <Grid.Resources>
      <x:Array x:Key="xItems" Type="sys:String">
        <sys:String>Hello</sys:String>
        <sys:String>World ddd</sys:String>
      </x:Array>
      <x:Array x:Key="xItems2" Type="sys:String">
        <sys:String>Hello long fsdfhuzweb kbhui</sys:String>
        <sys:String>World</sys:String>
      </x:Array>
    </Grid.Resources>

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

    <GroupBox Grid.Column="0" Header="Box A">
      <StackPanel Orientation="Horizontal">
        <!-- Labels -->
        <Grid>
          <Grid.ColumnDefinitions>
            <ColumnDefinition SharedSizeGroup="Labels" />
          </Grid.ColumnDefinitions>
          <Label Grid.Column="0" Grid.Row="0">Label A</Label>
        </Grid>
        <!-- Fields -->
        <ItemsControl ItemsSource="{Binding Source={StaticResource xItems}}">
          <ItemsControl.ItemsPanel>
            <ItemsPanelTemplate>
              <StackPanel Orientation="Horizontal" />
            </ItemsPanelTemplate>
          </ItemsControl.ItemsPanel>
          <ItemsControl.ItemTemplate>
            <DataTemplate>
              <Grid>
                <Grid.ColumnDefinitions>
                  <ColumnDefinition SharedSizeGroup="Fields" />
                </Grid.ColumnDefinitions>
                <Grid.RowDefinitions>
                  <RowDefinition SharedSizeGroup="Rows" />
                </Grid.RowDefinitions>
                <TextBox Text="{Binding Mode=OneWay}" />
              </Grid>
            </DataTemplate>
          </ItemsControl.ItemTemplate>
        </ItemsControl>
      </StackPanel>
    </GroupBox>

    <GroupBox Grid.Column="1" Header="Box B">
      <StackPanel Orientation="Horizontal">
        <!-- Labels -->
        <Grid>
          <Grid.ColumnDefinitions>
            <ColumnDefinition SharedSizeGroup="Labels" />
          </Grid.ColumnDefinitions>
          <Grid.RowDefinitions>
            <RowDefinition SharedSizeGroup="Rows" />
          </Grid.RowDefinitions>
          <Label Grid.Column="0" Grid.Row="0">Label B long</Label>
        </Grid>
        <!-- Fields -->
        <ItemsControl ItemsSource="{Binding Source={StaticResource xItems2}}">
          <ItemsControl.ItemsPanel>
            <ItemsPanelTemplate>
              <StackPanel Orientation="Horizontal" />
            </ItemsPanelTemplate>
          </ItemsControl.ItemsPanel>
          <ItemsControl.ItemTemplate>
            <DataTemplate>
              <Grid>
                <Grid.ColumnDefinitions>
                  <ColumnDefinition SharedSizeGroup="Fields" />
                </Grid.ColumnDefinitions>
                <Grid.RowDefinitions>
                  <RowDefinition SharedSizeGroup="Rows" />
                </Grid.RowDefinitions>
                <TextBox Text="{Binding Mode=OneWay}" />
              </Grid>
            </DataTemplate>
          </ItemsControl.ItemTemplate>
        </ItemsControl>
      </StackPanel>
    </GroupBox>
  </Grid>
</Page>

在此处输入图像描述

希望这可以帮助。

于 2014-12-13T16:52:25.073 回答