ItemsPanelTemplate Classe
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Spécifie le panneau créé par l'ItemsPresenter pour la disposition des éléments d’un ItemsControl.
public ref class ItemsPanelTemplate : System::Windows::FrameworkTemplate
public class ItemsPanelTemplate : System.Windows.FrameworkTemplate
type ItemsPanelTemplate = class
inherit FrameworkTemplate
Public Class ItemsPanelTemplate
Inherits FrameworkTemplate
- Héritage
Pour créer un ListBoxhorizontal, vous pouvez créer un modèle qui spécifie un StackPanel horizontal et le définir comme propriété ItemsPanel. L’exemple suivant montre un ListBoxStyle qui crée une ListBoxhorizontale.
<Style TargetType="ListBox">
<Setter Property="ItemsPanel">
<Setter.Value>
<ItemsPanelTemplate>
<StackPanel Orientation="Horizontal"
VerticalAlignment="Center"
HorizontalAlignment="Center"/>
</ItemsPanelTemplate>
</Setter.Value>
</Setter>
</Style>
L’exemple suivant utilise un ControlTemplate pour créer un ListBox horizontal qui a des angles arrondis. Notez que dans cet exemple, au lieu de définir la propriété ItemsPanel comme dans l’exemple précédent, la StackPanel horizontale est spécifiée dans le ControlTemplate. Notez que la propriété IsItemsHost est définie sur true
sur le StackPanel, indiquant que les éléments générés doivent se trouver dans le panneau. Lorsque vous le spécifiez de cette façon, la ItemsPanel ne peut pas être remplacée par l’utilisateur du contrôle sans utiliser de ControlTemplate. Par conséquent, effectuez cette opération uniquement si vous savez que vous ne souhaitez pas que le panneau soit remplacé sans l’utilisation d’un modèle.
<Style TargetType="ListBox">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="ListBox">
<Border CornerRadius="5" Background="{TemplateBinding ListBox.Background}">
<ScrollViewer HorizontalScrollBarVisibility="Auto">
<StackPanel Orientation="Horizontal"
VerticalAlignment="Center"
HorizontalAlignment="Center"
IsItemsHost="True"/>
</ScrollViewer>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
Vous pouvez également effectuer les opérations suivantes pour obtenir les mêmes résultats. Dans ce cas, le ItemsPresenter crée le panneau pour la disposition des éléments en fonction de ce qui est spécifié par le ItemsPanelTemplate.
<Style TargetType="{x:Type ListBox}">
<Setter Property="ItemsPanel">
<Setter.Value>
<ItemsPanelTemplate>
<StackPanel Orientation="Horizontal"
VerticalAlignment="Center"
HorizontalAlignment="Center"/>
</ItemsPanelTemplate>
</Setter.Value>
</Setter>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ListBox}">
<Border CornerRadius="5"
Background="{TemplateBinding ListBox.Background}">
<ScrollViewer HorizontalScrollBarVisibility="Auto">
<ItemsPresenter/>
</ScrollViewer>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
Pour obtenir un exemple d’utilisation des différentes propriétés de style et de création de modèles sur le ItemsControl, consultez Vue d’ensemble de la création de modèles de données.
Le ItemsPanelTemplate spécifie le panneau utilisé pour la disposition des éléments. GroupStyle a une propriété Panel de type ItemsPanelTemplate. ItemsControl types ont une propriété ItemsPanel de type ItemsPanelTemplate.
Chaque type ItemsControl a une ItemsPanelTemplatepar défaut. Pour la classe ItemsControl, la valeur ItemsPanel par défaut est une ItemsPanelTemplate qui spécifie un StackPanel. Pour l'ListBox, la valeur par défaut utilise la VirtualizingStackPanel. Pour MenuItem, la valeur par défaut utilise WrapPanel. Pour StatusBar, la valeur par défaut utilise DockPanel.
Items |
Initialise une instance de la classe ItemsPanelTemplate. |
Items |
Initialise une instance de la classe ItemsPanelTemplate avec le modèle spécifié. |
Dispatcher |
Obtient la Dispatcher cette DispatcherObject est associée. (Hérité de DispatcherObject) |
Has |
Obtient une valeur qui indique si ce modèle a optimisé le contenu. (Hérité de FrameworkTemplate) |
Is |
Obtient une valeur qui indique si cet objet est dans un état immuable afin qu’il ne puisse pas être modifié. (Hérité de FrameworkTemplate) |
Resources |
Obtient ou définit la collection de ressources qui peuvent être utilisées dans l’étendue de ce modèle. (Hérité de FrameworkTemplate) |
Template |
Obtient ou définit une référence à l’objet qui enregistre ou lit les nœuds XAML du modèle lorsque le modèle est défini ou appliqué par un enregistreur. (Hérité de FrameworkTemplate) |
Visual |
Obtient ou définit le nœud racine du modèle. (Hérité de FrameworkTemplate) |
Check |
Détermine si le thread appelant a accès à ce DispatcherObject. (Hérité de DispatcherObject) |
Equals(Object) |
Détermine si l’objet spécifié est égal à l’objet actuel. (Hérité de Object) |
Find |
Recherche l’élément associé au nom spécifié défini dans ce modèle. (Hérité de FrameworkTemplate) |
Get |
Sert de fonction de hachage par défaut. (Hérité de Object) |
Get |
Obtient la Type de l’instance actuelle. (Hérité de Object) |
Load |
Charge le contenu du modèle en tant qu’instance d’un objet et retourne l’élément racine du contenu. (Hérité de FrameworkTemplate) |
Memberwise |
Crée une copie superficielle du Objectactuel. (Hérité de Object) |
Register |
Inscrit une nouvelle paire nom/objet dans l’étendue actuelle du nom. (Hérité de FrameworkTemplate) |
Seal() |
Verrouille le modèle afin qu’il ne puisse pas être modifié. (Hérité de FrameworkTemplate) |
Should |
Retourne une valeur qui indique si les processus de sérialisation doivent sérialiser la valeur de la propriété Resources sur les instances de cette classe. (Hérité de FrameworkTemplate) |
Should |
Retourne une valeur qui indique si les processus de sérialisation doivent sérialiser la valeur de la propriété VisualTree sur les instances de cette classe. (Hérité de FrameworkTemplate) |
To |
Retourne une chaîne qui représente l’objet actuel. (Hérité de Object) |
Unregister |
Supprime un mappage nom/objet de l’étendue de noms XAML. (Hérité de FrameworkTemplate) |
Validate |
Vérifie que le parent modèle est un objet ItemsPresenter non null. |
Verify |
Applique que le thread appelant a accès à ce DispatcherObject. (Hérité de DispatcherObject) |
IName |
Retourne un objet qui a le nom d’identification fourni. (Hérité de FrameworkTemplate) |
IQuery |
Interroge si une propriété ambiante spécifiée est disponible dans l’étendue actuelle. (Hérité de FrameworkTemplate) |
Produit | Versions |
---|---|
.NET Framework | 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
Windows Desktop | 3.0, 3.1, 5, 6, 7, 8, 9 |
Commentaires sur .NET
.NET est un projet open source. Sélectionnez un lien pour fournir des commentaires :