我正在使用wpf工具包datagrid并且有一个用切换按钮填充的列。使用以下样式,如果选择了切换按钮,也会在鼠标悬停时更改背景颜色。不幸的是,如果我启用虚拟化,当我在单元格中选择一个切换按钮并在网格中向下滚动时,我会发现其他单元格的背景也已更改。我认为这是我滚动时虚拟化如何重用单元格的一个错误。有什么建议可以解决这个问题并仍然使用虚拟化吗?
<Style TargetType="{x:Type ToggleButton}">
<Setter Property="Control.Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ToggleButton}">
<TextBlock x:Name="Tb" Tag="{TemplateBinding Property=Tag}" Padding="{TemplateBinding Property=Padding}" Text="{TemplateBinding Property=Content}" >
</TextBlock>
<ControlTemplate.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter TargetName="Tb" Property="Background" Value="{StaticResource HoverRed}" />
</Trigger>
<Trigger Property="IsChecked" Value="True">
<Setter TargetName="Tb" Property="Background" Value="{StaticResource SelectYellow}" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
答案 0 :(得分:0)
通过绑定样式所针对的togglebutton的IsChecked属性,我已经能够解决这个问题。这使我可以打开虚拟化,并使每个单元格中模板化切换按钮的背景颜色与应该保持同步。
<ToggleButton Tag="button" IsChecked="{Binding Path=Selected,Mode=TwoWay}" FocusVisualStyle="{x:Null}" Content="{Binding Path=MarkerName,Mode=OneWay}">
</ToggleButton>