想象一下,我有一个名为“MyCheckBoxStyle”的CheckBox自定义样式。
如何根据MyCheckBoxStyle制作嵌入自定义DataGridCheckBoxColumn样式的Datagrid样式?
答案 0 :(得分:12)
您只需使用 ElementStyle 属性定义的样式。
资源中定义的样式:
<Style x:Key="MyCheckBoxStyle" TargetType="{x:Type CheckBox}"> ... </Style>
我的datagrid复选框列:
<DataGridCheckBoxColumn ElementStyle="{StaticResource MyCheckBoxStyle}" Binding="{Binding someValue}" />
答案 1 :(得分:3)
试试这个
<DataGridCheckBoxColumn MinWidth="100"
Binding="{Binding Path=BoolValue}"
Header="Bool Column"
IsThreeState="True">
<DataGridCheckBoxColumn.ElementStyle>
<Style TargetType="CheckBox">
<Setter Property="Background" Value="{Binding BoolValueColour, Converter={StaticResource MyConverter}}" />
</Style>
</DataGridCheckBoxColumn.ElementStyle>
</DataGridCheckBoxColumn>
答案 2 :(得分:2)
您可以使用DataGridTemplateColumn创建自定义checkboxcolumn
<Custom:DataGridTemplateColumn x:Name="gdchk" Header="Test" MaxWidth="50">
<Custom:DataGridTemplateColumn.CellTemplate >
<DataTemplate>
<CheckBox IsChecked="{Binding Path = classname}" HorizontalAlignment="Center" Style="{DynamicResource myCheckBoxStyle}"/>
</DataTemplate>
</Custom:DataGridTemplateColumn.CellTemplate>
</Custom:DataGridTemplateColumn>
希望这有帮助。
答案 3 :(得分:0)
在我找到以下解决方法后,对我来说没有工作:
<DataGridTemplateColumn
Header="Skip" Width="18"
IsReadOnly="False" CanUserResize="False">
<DataGridTemplateColumn.CellTemplate >
<DataTemplate DataType="gfxModule:BatchPairItemModel">
<CheckBox
Tag="{Binding}"
IsChecked="{Binding Tag.Skip, Mode=TwoWay,
RelativeSource={RelativeSource Self}}"
Template="{DynamicResource CheckBoxCircleXTemplate}"
ToolTip="Skip"
/>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>