我正在尝试使用包含文本块和按钮的自定义标头创建数据网格。文本块和按钮由我创建的UserControl
表示:
<UserControl x:Class="SilverlightWorkshop.Controls.CollapsibleDataGridHeader"
...
/>
<StackPanel Orientation="Horizontal">
<TextBlock Text="{Binding HeaderText, Mode=TwoWay}" />
<Button Content="←" Click="ArrowButtonClick"/>
</StackPanel>
</UserControl>
这个想法是,当用户点击按钮时,列宽会折叠到一个小的尺寸。但是,我无法找到使用此控件作为列标题模板的优雅解决方案。
这有效:
<sdk:DataGrid>
<sdk:DataGrid.Columns>
<sdk:DataGridTextColumn>
<sdk:DataGridTextColumn.Header>
foo
</sdk:DataGridTextColumn.Header>
</sdk:DataGridTextColumn>
</sdk:DataGrid.Columns>
</sdk:DataGrid>
但我不能控制住。这不起作用:
<sdk:DataGrid>
<sdk:DataGrid.Columns>
<sdk:DataGridTextColumn>
<sdk:DataGridTextColumn.Header>
<Button/>
</sdk:DataGridTextColumn.Header>
</sdk:DataGridTextColumn>
</sdk:DataGrid.Columns>
</sdk:DataGrid>
但是,http://msdn.microsoft.com/en-us/library/system.windows.controls.primitives.datagridcolumnheader(v=vs.95).aspx意味着我可以添加一个对象作为标题的子项。
我最接近的是将标题设置为样式:
<navigation:Page xmlns:my="clr-namespace:SilverlightWorkshop.Controls" xmlns:sdk="http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk" x:Class="SilverlightWorkshop.Views.CollapsibleColumns"
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"
xmlns:navigation="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
d:DesignWidth="640" d:DesignHeight="480"
Title="CollapsibleColumns Page">
<navigation:Page.Resources>
<Style x:Key="CollapsibleHeaderStyle" TargetType="sdk:DataGridColumnHeader">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="sdk:DataGridColumnHeader">
<my:CollapsibleDataGridHeader HeaderText="Cheese" ArrowButtonClicked="ArrowButtonClick"/>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</navigation:Page.Resources>
<sdk:DataGrid ItemsSource="{Binding Data, Mode=TwoWay}" AutoGenerateColumns="False">
<sdk:DataGrid.Columns>
<sdk:DataGridTextColumn Binding="{Binding String2, Mode=TwoWay}" HeaderStyle="{StaticResource CollapsibleHeaderStyle}"/>
<sdk:DataGridTextColumn Binding="{Binding String1, Mode=TwoWay}"/>
</sdk:DataGrid.Columns>
</sdk:DataGrid>
</navigation:Page>
然而,有一些我不喜欢的事情。设置列标题的模板属性会清除一些默认外观,例如标题的背景颜色和排序图标。看起来我完全取代了整个事情。
另外,我不确定如何找到单击哪个列标题,这样我就可以更改相应列的宽度,也不会将每列的不同标题名称绑定到HeaderText
我的CollapsibleDataGridHeader
控件中的属性。
是否可以避免使用样式,而是将我的控件分配给列标题?如果没有,我将如何使用上面的样式设置解决方案进行绑定并检索单击哪个列?
答案 0 :(得分:0)
Manas Patnaik的这篇文章似乎有答案:
有XAML显示如何设置标题模板以保留默认样式,还有如何通过代码隐藏从DataGrid标题访问控件的说明。
这个答案解释了如何绑定到Style中设置的控件:
Dynamically setting the Header text of a Silverlight DataGrid Column