I've recently made an UserControl, which took quite a long time, because I had to work with custom Dependency Properties and so on...
Anyways, it was just a bunch of 3 controls: TextBox, Popup with Hierarchical Tree.
Now I realized I could probably write a ControlTemplate only. Hence what is the benefit of using UserControl?
There are three cases to consider here: UserControl, ControlTemplate, and custom Control. (I'm guessing a DataTemplate needs no explanation)
A custom Control is something you provide when you create base functionality of a new UI component. There are various pros and cons for this, but for example, if you want custom selection behaviour of an ItemsControl, you could best do it by subclassing Selector or MultiSelector (the wpftoolkit DataGrid does this). Also, if you want an object which would contain a new DependencyProperty, you will in most cases derive from Control.
The wpf principle contained here is the "lookless" control paradigm, or "be sure to expect someone templating your Control, or at least make it behave nicely in your own template scenario". Custom Controls are usually created with reusability in mind, often as parts of framework dlls.
A ControlTemplate is essentially a description of a replacement visual tree, and can be set either explicitly on FrameworkElements, or as a part of a Style. This is the option you should aim at when your goal is primarily to make an application and be done with it. You can do almost anything with a ControlTemplate visually, if you are able to get the bindings and triggers (and the possible containing Style itself) right. All this can be declared as a resource an reused, to give your application a common "theme".
A UserControl is a self-contained composite control, with parts individually editable in the designer, and is best used if you need to see your components and manage them in the designer. A ControlTemplate, on the other hand, will not expose its components for manipulation in the designer (although it will be visible). You usually create a UserControl for a Customer details page, or a Product display browser, or any case where you don't want to create a full-blown Control, but want detailed view with full designer support.
A special case here is if you use the MVVM pattern. Many great MVVM implementations use UserControls as Views, and ControlTemplates and Styles as resources used by those views. MVVM practice also minimizes the need for a custom Control, and has many other benefits.
(For more information on MVVM, among many others, Google for Josh Smith, Sacha Barber and Karl Shifflett's fantastic articles)
If you are adding your own dependency properties, then you will need your own class upon which to define them.
As you want to apply a template to the class, this custom class will have to derive from Control
(as UserControl
does).
The main benefit of writing your own Control
-derived class is that it can have its template redefined for other usage scenarios, either by you within the app, or by other users of the type.
There is very little overhead in using the UserControl
class. In fact, if you look at it in Reflector.NET, you'll see that it hardly has any code. Primarily, UserControl
just redefines the metadata on some existing dependency properties (such as making the default value of FocusableProperty
false
.)
Unless you need to redefine the template of the control immediately, you can leave it as a UserControl
for now and change it later if needed.