WPF数据表格列忽略宽度

3
我有两个DataGrids。为了美化它们,我对它们进行了一些样式设置。我定义了CellTemplate和HeaderTemplate,并将它们应用于DataGrid的隐式样式中。我在XAML中添加列并让它们保持原样。它们也有HeaderTemplates。
编辑:我尝试了一些其他情况,所以这里有更多关于发生的事情:
DataGrid 'A'工作正常。它完全从XAML中初始化。它接受各种宽度(包括星号大小)并正确显示。它放置在具有VM的UserControl内。以下是XAML代码:
<DataGrid ItemsSource="{Binding Items}">
    <DataGrid.Columns>
        <DataGridTextColumn Binding="{Binding Name}" Header="Name" MinWidth="50" Width="250" HeaderTemplate="{StaticResource DefaultDataGridHeader}"/>
        <DataGridTextColumn Binding="{Binding StartDate}" Header="Start"  MinWidth="50" Width="150" HeaderTemplate="{StaticResource DefaultDataGridHeader}" />
        <DataGridTextColumn Binding="{Binding FinishDate}" Header="Finish"  MinWidth="50" Width="150" HeaderTemplate="{StaticResource DefaultDataGridHeader}" />
        <DataGridTextColumn Binding="{Binding Leader}" Header="Leader"  MinWidth="50" Width="*" HeaderTemplate="{StaticResource DefaultDataGridHeader}" />
    </DataGrid.Columns>
</DataGrid>

现在情况稍微复杂了一些。有一个控件用于显示DataGrid B并执行其他操作,这个控件被用在许多其他视图中,每个视图都有不同的数据。因此,对于每个数据,都存在另一个包含DataGrid列定义的视图。当数据到达主控件时,它会清除DataGrid B的列,并使用相应视图中定义的列重新填充。

下面是用户控件中的DataGrid B:

<DataGrid x:Name="datagrid" ItemsSource="{Binding Items}" IsReadOnly="True"  SelectionMode="Single" />

用户控件(UserControl)具有一个ObservableCollectionGridColumns依赖属性,其中包含实际的DataGridColumns。因此,在CollectionChanged事件中我这样做:

void GridColumnsCollectionChanged(object sender, NotifyCollectionChangedEventArgs e)
{
    datagrid.Columns.Clear();
    foreach (var gridColumn in GridColumns)
    {
        datagrid.Columns.Add(gridColumn);
    }
}

这是一个关于如何在数据特定视图中设置实际列的示例:

以下是我设置数据特定视图中实际列的示例:

<c:GenericList >
    <c:GenericList.GridColumns>
            <DataGridTextColumn Binding="{Binding Name}" Header="Name" 
            Width="300" HeaderTemplate="{StaticResource DefaultDataGridHeader}"/>
    </c:GenericList.GridColumns>
</c:GenericList>

-------- DataGrid B 的情况如下: --------

  • 如果我将 XAML 设置为这样,那么列的宽度将呈现为 300 像素。
  • 如果我将宽度更改为星号大小,或者添加任何其他星号大小的列,则它们将呈现为 20 像素的宽度(即使标题中有一些文本)。
  • 如果我设置 MinWidth,则所有星号大小的列都会呈现为 MinWidth。

  • 如果我省略整个“从另一个视图放置列”的部分,并直接向数据网格添加一些列,则像素大小的列跨越到标题文本的宽度,而星号大小的列呈现为 20px 的宽度。此外,如果我在运行应用程序时调整星号大小的列,一些宽度约束会生效,我无法再次使列变小。但在这个版本中,没有数据绑定到列。这可能引起了这种效果吗?

//编辑结束。

这些样式是使用 Blend 中的“编辑副本”功能创建的。

<Style x:Key="DefaultDataGridColumnHeaderStyle" TargetType="{x:Type DataGridColumnHeader}">
    <Setter Property="VerticalContentAlignment" Value="Center"/>
    <Setter Property="HorizontalContentAlignment" Value="Stretch"/>
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type DataGridColumnHeader}">
                <Grid >
                    <Microsoft_Windows_Themes:DataGridHeaderBorder BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" 
                                                                   IsClickable="{TemplateBinding CanUserSort}" IsPressed="{TemplateBinding IsPressed}" IsHovered="{TemplateBinding IsMouseOver}" 
                                                                   Padding="{TemplateBinding Padding}" SortDirection="{TemplateBinding SortDirection}" SeparatorBrush="{TemplateBinding SeparatorBrush}" 
                                                                   SeparatorVisibility="{TemplateBinding SeparatorVisibility}" Background="#00000000">
                        <Grid>
                            <ContentPresenter HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" 
                                              VerticalAlignment="{TemplateBinding VerticalContentAlignment}"/>
                            <Rectangle StrokeThickness="0" RadiusY="0" Opacity="0">
                                <Rectangle.Fill>
                                    <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                                        <GradientStop Color="#33000000" Offset="1"/>
                                        <GradientStop Color="#4CFFFFFF"/>
                                        <GradientStop Color="#007B7B7B" Offset="0.35"/>
                                    </LinearGradientBrush>
                                </Rectangle.Fill>
                            </Rectangle>
                        </Grid>
                    </Microsoft_Windows_Themes:DataGridHeaderBorder>
                    <Thumb x:Name="PART_LeftHeaderGripper" HorizontalAlignment="Left" Style="{StaticResource ColumnHeaderGripperStyle}" Width="8"/>
                    <Thumb x:Name="PART_RightHeaderGripper" HorizontalAlignment="Right" Style="{StaticResource ColumnHeaderGripperStyle}" Width="8"/>
                </Grid>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

<DataTemplate x:Key="DefaultDataGridHeader">
    <Border BorderBrush="{DynamicResource ShadowBrush}" Background="{x:Null}" d:DesignWidth="289" d:DesignHeight="72.28">
        <Grid>
            <Rectangle RadiusY="0" StrokeThickness="0" Fill="{DynamicResource ActionTileBrush}" />
            <Rectangle RadiusY="0" StrokeThickness="0" >
                <Rectangle.Fill>
                    <SolidColorBrush Color="#88FFFFFF" />
                </Rectangle.Fill>
            </Rectangle>
            <TextBlock Text="{Binding}" Margin="12" FontSize="16" FontWeight="Bold">
                <TextBlock.Foreground>
                    <SolidColorBrush Color="#FF11789D" />
                </TextBlock.Foreground>
            </TextBlock>
            <Rectangle RadiusY="0" StrokeThickness="1" Stroke="{DynamicResource ShadowBrush}"></Rectangle>
        </Grid>
    </Border>
</DataTemplate>


<Style x:Key="DefaultDataGridCellStyle" TargetType="{x:Type DataGridCell}">
    <Setter Property="Background" Value="Transparent"/>
    <Setter Property="BorderBrush" Value="Transparent"/>
    <Setter Property="BorderThickness" Value="1"/>
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type DataGridCell}">
                <Border BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" SnapsToDevicePixels="True" Padding="12,8">
                    <ContentPresenter SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" />
                </Border>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
    <Style.Triggers>
        <Trigger Property="IsSelected" Value="True">
            <Setter Property="Background" Value="{DynamicResource HighlightBrush}"/>
        </Trigger>
        <Trigger Property="IsKeyboardFocusWithin" Value="True">
            <Setter Property="BorderBrush" Value="{DynamicResource HighlightBrush}"/>
        </Trigger>
    </Style.Triggers>
</Style>



<Style x:Key="DefaultDataGridStyle" TargetType="{x:Type DataGrid}">
    <Setter Property="AlternatingRowBackground" Value="{x:Null}"/>
    <Setter Property="AlternationCount" Value="2"/>
    <Setter Property="AutoGenerateColumns" Value="False"/>
    <Setter Property="Background" Value="{x:Null}"/>
    <Setter Property="BorderBrush" Value="{DynamicResource ChromeBrush}"/>
    <Setter Property="BorderThickness" Value="1"/>
    <Setter Property="CellStyle" Value="{StaticResource DefaultDataGridCellStyle}"/>
    <Setter Property="ColumnHeaderStyle" Value="{StaticResource DefaultDataGridColumnHeaderStyle}"/>
    <Setter Property="Foreground" Value="{DynamicResource ForegroundBrush}"/>
    <Setter Property="HorizontalGridLinesBrush" Value="{DynamicResource ShadowBrush}"/>
    <Setter Property="RowBackground" Value="{DynamicResource BackgroundBrush}"/>
    <Setter Property="RowDetailsVisibilityMode" Value="VisibleWhenSelected"/>
    <Setter Property="ScrollViewer.CanContentScroll" Value="true"/>
    <Setter Property="ScrollViewer.PanningMode" Value="Both"/>
    <Setter Property="Stylus.IsFlicksEnabled" Value="True"/>
    <Setter Property="VerticalGridLinesBrush" Value="{DynamicResource ShadowBrush}"/>
    <Setter Property="VerticalContentAlignment" Value="Stretch"/>
    <Setter Property="HorizontalContentAlignment" Value="Stretch"/>
    <Style.Triggers>
        <Trigger Property="IsGrouping" Value="true">
            <Setter Property="ScrollViewer.CanContentScroll" Value="false"/>
        </Trigger>
    </Style.Triggers>
</Style>

显然有些地方出了问题,我应该可以将列设置为星号大小,或者如果将它们设置为像素大小,我希望它们能保持这种大小。

谢谢您的任何帮助!


我理解这是大小不正确的网格。请发布大小正确的网格的 XAML。 - paparazzo
我还没有发布另一个版本,因为它完全相同,只是使用了其他绑定。 - Tenshiko
好的,我再稍微调整了一下它们,并更新了问题,所以现在上面有更多的信息。 - Tenshiko
2个回答

0

用户控件的HorizontalAlignment属性是否设置为Stretch?我建议将用户控件的HorizontalAlignment属性设置为Stretch,也许这会限制DataGrid的大小。


0
希望在第二个DataGridTextColumn的XAML中,在Binding和Width之间有空格。

是的,那是一个复制粘贴的错误,但它们在我的代码中是分开的。 - Tenshiko

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接