Partilhar via


TabControl.SelectedContentTemplate Propriedade

Definição

Obtém o DataTemplate do item atualmente selecionado.

public:
 property System::Windows::DataTemplate ^ SelectedContentTemplate { System::Windows::DataTemplate ^ get(); };
public System.Windows.DataTemplate SelectedContentTemplate { get; }
member this.SelectedContentTemplate : System.Windows.DataTemplate
Public ReadOnly Property SelectedContentTemplate As DataTemplate

Valor da propriedade

O DataTemplate do item selecionado.

Exemplos

O exemplo a seguir cria um ControlTemplate para o TabControl. Definir a ContentSource propriedade para "SelectedContent" cria aliases para as SelectedContentpropriedades , SelectedContentTemplatee SelectedContentTemplateSelector .

<Style  TargetType="{x:Type TabControl}">
  <Setter Property="OverridesDefaultStyle"
          Value="True" />
  <Setter Property="SnapsToDevicePixels"
          Value="True" />
  <Setter Property="Template">
    <Setter.Value>
      <ControlTemplate TargetType="{x:Type TabControl}">
        <Grid KeyboardNavigation.TabNavigation="Local">
          <Grid.RowDefinitions>
            <RowDefinition Height="Auto" />
            <RowDefinition Height="*" />
          </Grid.RowDefinitions>
          <VisualStateManager.VisualStateGroups>
            <VisualStateGroup x:Name="CommonStates">
              <VisualState x:Name="Disabled">
                <Storyboard>
                  <ColorAnimationUsingKeyFrames Storyboard.TargetName="Border"
                                                Storyboard.TargetProperty="(Border.BorderBrush).
                    (SolidColorBrush.Color)">
                    <EasingColorKeyFrame KeyTime="0"
                                         Value="#FFAAAAAA" />
                  </ColorAnimationUsingKeyFrames>
                </Storyboard>
              </VisualState>
            </VisualStateGroup>
          </VisualStateManager.VisualStateGroups>
          <TabPanel x:Name="HeaderPanel"
                    Grid.Row="0"
                    Panel.ZIndex="1"
                    Margin="0,0,4,-1"
                    IsItemsHost="True"
                    KeyboardNavigation.TabIndex="1"
                    Background="Transparent" />
          <Border x:Name="Border"
                  Grid.Row="1"
                  BorderThickness="1"
                  CornerRadius="2"
                  KeyboardNavigation.TabNavigation="Local"
                  KeyboardNavigation.DirectionalNavigation="Contained"
                  KeyboardNavigation.TabIndex="2">
            <Border.Background>
              <LinearGradientBrush EndPoint="0.5,1"
                                   StartPoint="0.5,0">
                <GradientStop Color="{DynamicResource ContentAreaColorLight}"
                              Offset="0" />
                <GradientStop Color="{DynamicResource ContentAreaColorDark}"
                              Offset="1" />
              </LinearGradientBrush>
            </Border.Background>
            <Border.BorderBrush>
              <SolidColorBrush Color="{DynamicResource BorderMediumColor}"/>
            </Border.BorderBrush>
            <ContentPresenter x:Name="PART_SelectedContentHost"
                              Margin="4"
                              ContentSource="SelectedContent" />
          </Border>
        </Grid>
      </ControlTemplate>
    </Setter.Value>
  </Setter>
</Style>

O exemplo a seguir associa a SelectedContentTemplate propriedade à ContentPresenter.ContentTemplate propriedade usando a Extensão de Marcação TemplateBinding.

<ContentPresenter Content="{TemplateBinding SelectedContent}" 
     ContentTemplate="{TemplateBinding SelectedContentTemplate}" 
     ContentTemplateSelector="{TemplateBinding SelectedContentTemplateSelector}" />

Comentários

O TabControl atualiza essa propriedade para fazer referência ao DataTemplate para o ativo TabItem quando a seleção de guia é alterada. Defina ou a ContentTemplate propriedade em um TabItem para especificar o DataTemplate para um TabItem.TabControl.ContentTemplate

O ControlTemplate do TabControl usa a ContentPresenter.ContentSource propriedade para associar a ContentPresenter.ContentTemplate propriedade a essa propriedade. Se você criar um novo ControlTemplate para o TabControl, certifique-se de associar a ContentPresenter.Content propriedade a essa propriedade definindo a ContentPresenter.ContentSource propriedade como "SelectedContent" ou usando TemplateBinding Markup Extension.

Uso do Atributo XAML

<object property="{TemplateBinding SelectedContentTemplate}"/>  

Informações da propriedade de dependência

Campo Identificador SelectedContentTemplateProperty
Propriedades de metadados definidas como true Nenhum

Aplica-se a