ControlTemplate that Respects Content : ControlTemplate « Windows Presentation Foundation « C# / CSharp Tutorial






<Window xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Title="">
        
<Grid xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
  <Grid.Resources>
    <ControlTemplate x:Key="buttonTemplate" TargetType="{x:Type Button}">
      <Grid>
        <Ellipse x:Name="outerCircle" Width="100" Height="100">
          <Ellipse.Fill>
            <LinearGradientBrush StartPoint="0,0" EndPoint="0,1">
              <GradientStop Offset="0" Color="Blue"/>
              <GradientStop Offset="1" Color="Red"/>
            </LinearGradientBrush>
          </Ellipse.Fill>
        </Ellipse>
        <Viewbox>
          <ContentControl Margin="20" Content="{TemplateBinding Content}"/>
        </Viewbox>
      </Grid>
      <ControlTemplate.Triggers>
        <Trigger Property="IsMouseOver" Value="True">
          <Setter TargetName="outerCircle" Property="Fill" Value="Orange"/>
        </Trigger>
        <Trigger Property="IsPressed" Value="True">
          <Setter Property="RenderTransform">
            <Setter.Value>
              <ScaleTransform ScaleX=".9" ScaleY=".9"/>
            </Setter.Value>
          </Setter>
          <Setter Property="RenderTransformOrigin" Value=".5,.5"/>
        </Trigger>
      </ControlTemplate.Triggers>
    </ControlTemplate>
  </Grid.Resources>
  <Button Template="{StaticResource buttonTemplate}">OK</Button>
</Grid>


</Window>
WPF Control Template That Respects Content








24.76.ControlTemplate
24.76.1.Control template: event trigger, border and textControl template: event trigger, border and text
24.76.2.Put a Control Template into a StylePut a Control Template into a Style
24.76.3.Label with ControlTemplateLabel with ControlTemplate
24.76.4.Specify Named Parts of a Control TemplateSpecify Named Parts of a Control Template
24.76.5.ProgressBar with ControlTemplateProgressBar with ControlTemplate
24.76.6.Simple ControlTemplateSimple ControlTemplate
24.76.7.ControlTemplate with TriggersControlTemplate with Triggers
24.76.8.ControlTemplate that Respects ContentControlTemplate that Respects Content
24.76.9.ControlTemplate that Respects More PropertiesControlTemplate that Respects More Properties
24.76.10.Use ControlTemplate and event handlerUse ControlTemplate and event handler
24.76.11.Finding the border that is generated by the ControlTemplate of the ButtonFinding the border that is generated by the ControlTemplate of the Button
24.76.12.Get The actual width of the border in the ControlTemplateGet The actual width of the border in the ControlTemplate
24.76.13.ControlTemplates and style xaml fileControlTemplates and style xaml file
24.76.14.Enhance the visual appearance of a ContentControl by applying a style.Enhance the visual appearance of a ContentControl by applying a style.
24.76.15.Use a ContentTemplate and determine whether the control contains content.Use a ContentTemplate and determine whether the control contains content.