I’ve been trying to create my generic ReadOnlyCheckBox style/template but I’m having a problem with the binding to the data. In the example here:
A read-only CheckBox in C# WPF
you bind directly to the data from the ControlTemplate definition, but of course this is not really what I want, as I want to be able to declare the new checkbox something like this:
<CheckBox x:Name="uiComboBox" Content="Does not set the backing property, but responds to it."
Style="{StaticResource ReadOnlyCheckBoxStyle}" IsChecked="{Binding MyBoolean}" Click="uiComboBox_Click"/>
Except of course when I do this and then set the event trigger on the bullet to be a TemplateBinding of IsChecked I have exactly what I started with! I guess I don’t understand why setting the binding directly in the bullet is different from setting IsChecked and then binding to that, isn’t the TemplateBinding just a way of referencing what is set in the properties of the control being created? How is the Click triggering the UI update even tho the data does not get updated? Is there a trigger for Click I can override to stop the update?
I got all the DictionaryResource stuff working fine so I am happy with that, cheers for the pointer.
The other thing I was curious about was if it is possible to reduce my Control/Style template by using the BasedOn parameter in the style, then I would only override the things I actually need to change rather than declaring a lot of stuff that I think is part of the standard template anyway. I might have a play with this.
Cheers
ed
The problem you’re running into is that you’re trying to use DataBinding where you shouldn’t.
I disagree with other answers you’ve been getting in the link you’ve posted. While the ControlTemplate solutions appear neat and tidy, they don’t get at the heart of your problem, which is, you’re trying to use a single control (a CheckBox) to do two different things: show state (e.g. checked/unchecked) and perform logic (remote device, etc.).
ControlTemplates are designed to change the way a control appears, but not behaves. You’re trying to change behavior, not appearance. See “What Is a ControlTemplate?” here for more details
To do that, you’re going to have to store some forego the standard binding and handle some events:
XAML:
Code-Behind:
The above code example gives you the ability to execute some code async via BackgroundWorker — I’ve put in a Thread.Sleep as a placeholder. I’m also using foo.IsEnabled as a sentinel value in foo_Checked, but you may need some extra state here to handle all of your cases (for instance, going from Checked to Unchecked).