ContentControl extends Control and has three main properties (of which 'Template' property is inherited from the parent Control class):
// Summary: // Gets or sets the value of the System.Windows.Controls.ContentControl dependency // property. // // Returns: // An object that contains the control's content. The default is null. public object Content { get; set; } // // Summary: // Gets or sets the data template that is used to display the content of the // System.Windows.Controls.ContentControl. // // Returns: // The data template that is used to display the content of the System.Windows.Controls.ContentControl. public DataTemplate ContentTemplate { get; set; }
//(Note: Inherited from parent 'Control' class // Summary: // Gets or sets a control template. // // Returns: // The template that defines the appearance of the System.Windows.Controls.Control. public ControlTemplate Template { get; set; }ControlTemplate is used for display of the control. All ContentControl objects come with default values for their ControlTemplate property.The control author can define the default ControlTemplate and the application author can override the ControlTemplate to reconstruct the visual structure of the control.The default ControlTemplate contains a ContentPresenter that is defined by the control author. If the application author chooses to redefine the Template property, he HAS to include the ContentPresenter in the ControlTemplate otherwise, the ContentControl will not display.The DataTemplate is used to display the data contained in the control.This should be defined in XAML only and cannot be done in code.The XAML usage that defines the content for creating a data template is not exposed as a settable property. It is special behavior built into the XAML processing of a DataTemplate object element.Here is how they all work together (click here for more details):
You typically use the ContentPresenter in the ControlTemplate of a ContentControl to specify where the content is to be added. Every ContentControl type has a ContentPresenter in its default ControlTemplate.When a ContentPresenter object is in a ControlTemplate of a ContentControl, the Content, ContentTemplate, and ContentTemplateSelector properties get their values from the properties of the same names of theContentControl. You can have the ContentPresenter property get the values of these properties from other properties of the templated parent by setting the ContentSource property or binding to them.The ContentPresenter uses the following logic to display the Content:Similarly, The ItemsControl is used for collections. The equivalent of ContentTemplate here is ItemTemplate (hence the type is the same: DataTemplate). In an items control, when bound to a collection, each element of the collection is displayed using the ItemTemplate.
- If the ContentTemplate property on the ContentPresenter is set, the ContentPresenter applies that DataTemplate to the Content property and the resulting UIElement and its child elements, if any, are displayed. For more information about DataTemplate objects, see Data Templating Overview.
- If the ContentTemplateSelector property on the ContentPresenter is set, the ContentPresenter applies the appropriate DataTemplate to the Content property and the resulting UIElement and its child elements, if any, are displayed.
- If there is a DataTemplate associated with the type of Content, the ContentPresenter applies that DataTemplate to the Content property and the resulting UIElement and its child elements, if any, are displayed.
- If Content is a UIElement object, the UIElement is displayed. If the UIElement already has a parent, an exception occurs.
- If there is a TypeConverter that converts the type of Content to a UIElement, the ContentPresenter uses that TypeConverter and the resulting UIElement is displayed.
- If there is a TypeConverter that converts the type of Content to a string, the ContentPresenter uses that TypeConverter and creates a TextBlock to contain that string. The TextBlock is displayed.
- If the content is an XmlElement, the value of the InnerText property is displayed in a TextBlock.
- The ContentPresenter calls the ToString method on the Content and creates a TextBlock to contain the string returned by ToString. The TextBlock is displayed.
// // Summary: // Gets or sets the System.Windows.DataTemplate used to display each item. // // Returns: // The template that specifies the visualization of the data objects. The default // is null. public DataTemplate ItemTemplate { get; set; }