Поделиться через


Пример использования шаблона ControlTemplate для элемента управления ListBoxItem

Обновлен: Ноябрь 2007

Элементы управления в Windows Presentation Foundation (WPF) имеют шаблон ControlTemplate, содержащий визуальное дерево этого элемента управления. Разработчик может изменить структуру и внешний вид элемента управления, изменяя шаблон ControlTemplate соответствующего элемента управления. Не существует способа для замены только части визуального дерева элемента управления; чтобы изменить визуальное дерево элемента управления, следует установить свойство Template элемента управления для его нового и завершенного объекта ControlTemplate.

В данном разделе демонстрируется шаблон ControlTemplate элемента управления WPF ListBoxItem.

В этом разделе содержатся следующие подразделы.

  • Необходимые компоненты
  • Пример шаблона ControlTemplate для элемента управления ListBoxItem
  • Связанные разделы

Необходимые компоненты

Для выполнения примеров из данного раздела необходимо понимание технологии написания приложений WPF. Дополнительные сведения см. в разделе Введение в Windows Presentation Foundation. Следует также знать, как стили используются в WPF. Дополнительные сведения см. в разделе Стилизация и использование шаблонов.

Пример шаблона ControlTemplate для элемента управления ListBoxItem

Хотя в данном примере содержатся все элементы, которые определены по умолчанию в шаблоне ControlTemplate элемента управления ListBoxItem, указанные значения следует рассматривать как примеры.

<Style x:Key="{x:Type ListBoxItem}" TargetType="ListBoxItem">
  <Setter Property="SnapsToDevicePixels" Value="true"/>
  <Setter Property="OverridesDefaultStyle" Value="true"/>
  <Setter Property="Template">
    <Setter.Value>
      <ControlTemplate TargetType="ListBoxItem">
        <Border 
          Name="Border"
          Padding="2"
          SnapsToDevicePixels="true">
          <ContentPresenter />
        </Border>
        <ControlTemplate.Triggers>
          <Trigger Property="IsSelected" Value="true">
            <Setter TargetName="Border" Property="Background"
                    Value="{StaticResource SelectedBackgroundBrush}"/>
          </Trigger>
          <Trigger Property="IsEnabled" Value="false">
            <Setter Property="Foreground"
                    Value="{StaticResource DisabledForegroundBrush}"/>
          </Trigger>
        </ControlTemplate.Triggers>
      </ControlTemplate>
    </Setter.Value>
  </Setter>
</Style>

В предыдущем примере использовались следующие ресурсы.

<SolidColorBrush x:Key="SelectedBackgroundBrush" Color="#DDD" />


...


<SolidColorBrush x:Key="DisabledForegroundBrush" Color="#888" />

Полный пример см. в разделе Пример стилизации с использованием ControlTemplates.

См. также

Основные понятия

Рекомендации по разработке элементов управления с возможностью использования стилей

Пример шаблона элемента управления ListBox

Другие ресурсы

Примеры ControlTemplate