Silverlight - Disposition dynamique
le Canvasest le moins intéressant de tous les panneaux de mise en page de Silverlight. Les autres panneaux permettentDynamic Layouts, ce qui signifie que les mises en page peuvent s'adapter à mesure que le nombre d'éléments affichés change, ou que la taille des informations affichées varie, ou si la quantité d'espace disponible pour l'application change parce que l'utilisateur a redimensionné le navigateur.
Silverlight propose deux panneaux avec des stratégies de mise en page dynamique.
StackPanel - qui dispose les éléments dans une pile verticale ou horizontale.
Grid - qui fournit un système de disposition flexible en forme de grille ou de tableau.
Panneau de pile
Le panneau Stack est un panneau de disposition simple et utile en XAML. DansStack Panel, les éléments enfants peuvent être disposés sur une seule ligne horizontalement ou verticalement en fonction de leur propriété d'orientation. Il est souvent utilisé chaque fois qu'un type de liste doit être créé. ItemsControls utilise des panneaux de pile.Menu, ListBox et ComboBox sont leur panneau de disposition interne par défaut.
Ci-dessous sont les properties de StackPanel.
Sr. No. | Propriété et description |
---|---|
1 | Background Obtient ou définit un Brush qui remplit la zone de contenu du panneau. (Hérité de Panel) |
2 | Children Obtient un UIElementCollection d'éléments enfants de ce Panel. (Hérité de Panel.) |
3 | Height Obtient ou définit la hauteur proposée de l'élément. (Hérité de FrameworkElement.) |
4 | ItemHeight Obtient ou définit une valeur qui spécifie la hauteur de tous les éléments contenus dans un WrapPanel. |
5 | ItemWidth Obtient ou définit une valeur qui spécifie la largeur de tous les éléments contenus dans un WrapPanel. |
6 | LogicalChildren Obtient un énumérateur qui peut itérer les éléments enfants logiques de cet élément Panel. (Hérité de Panel.) |
sept | LogicalOrientation Orientation du panneau, si le panneau prend en charge la mise en page dans une seule dimension. (Hérité de Panel.) |
8 | Margin Obtient ou définit la marge extérieure d'un élément. (Hérité de FrameworkElement.) |
9 | Name Obtient ou définit le nom d'identification de l'élément. Le nom fournit une référence afin que le code-behind, tel que le code du gestionnaire d'événements, puisse faire référence à un élément de balisage après sa construction pendant le traitement par un processeur XAML. (Hérité de FrameworkElement.) |
dix | Orientation Obtient ou définit une valeur qui spécifie la dimension dans laquelle le contenu enfant est organisé. |
11 | Parent Obtient l'élément parent logique de cet élément. (Hérité de FrameworkElement.) |
12 | Resources Obtient ou définit le dictionnaire de ressources défini localement. (Hérité de FrameworkElement.) |
13 | Style Obtient ou définit le style utilisé par cet élément lors de son rendu. (Hérité de FrameworkElement.) |
14 | Width Obtient ou définit la largeur de l'élément. (Hérité de FrameworkElement.) |
L'exemple suivant montre comment ajouter des éléments enfants dans un StackPanel. Ci-dessous se trouve l'implémentation XAML dans laquelleButtons sont créés dans un StackPanel avec certaines propriétés.
<UserControl x:Class = "DynamicLayout.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d"
d:DesignHeight = "300" d:DesignWidth = "400">
<Grid x:Name = "LayoutRoot" Background = "White">
<StackPanel>
<Button x:Name = "button" Content = "Button" Margin = "10" />
<Button x:Name = "button1" Content = "Button" Margin = "10"/>
<Button x:Name = "button2" Content = "Button" Margin = "10"/>
<Button x:Name = "button3" Content = "Button" Margin = "10"/>
</StackPanel>
</Grid>
</UserControl>
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Le StackPanel essaie de faire en sorte que chaque élément ait autant d'espace qu'il en a besoin dans le sens de l'empilement.
Maintenant, si vous redimensionnez le navigateur, vous verrez que la largeur des boutons a également changé.
la grille
Le panneau Grille fournit une zone flexible, composée de lignes et de colonnes. DansGrid, les éléments enfants peuvent être disposés sous forme de tableau. Un élément peut être ajouté à n'importe quelle ligne et colonne spécifiques en utilisantGrid.Row et Grid.ColumnPropriétés. Par défaut, leGridLe panneau est créé avec une ligne et une colonne. Plusieurs lignes et colonnes sont créées parRowDefinitions et ColumnDefinitionsPropriétés. La hauteur des lignes et la largeur des colonnes peuvent être définies des trois manières suivantes -
Fixed value - Pour attribuer une taille fixe d'unités logiques (1/96 pouce).
Auto - Cela prendra l'espace nécessaire pour les contrôles de cette ligne / colonne spécifique.
Star (*) - Cela prendra l'espace restant lorsque Auto et fixed sized sont remplis.
Ci-dessous sont les properties de Grid classe.
Sr. No. | Propriété et description |
---|---|
1 | Background Obtient ou définit un Brush qui remplit la zone de contenu du panneau. (Hérité de Panel) |
2 | Children Obtient un UIElementCollection d'éléments enfants de ce Panel. (Hérité de Panel.) |
3 | ColumnDefinitions Obtient une liste d'objets ColumnDefinition définis sur cette instance de Grid. |
4 | Height Obtient ou définit la hauteur proposée de l'élément. (Hérité de FrameworkElement.) |
5 | ItemHeight Obtient ou définit une valeur qui spécifie la hauteur de tous les éléments contenus dans un WrapPanel. |
6 | ItemWidth Obtient ou définit une valeur qui spécifie la largeur de tous les éléments contenus dans un WrapPanel. |
sept | Margin Obtient ou définit la marge extérieure d'un élément. (Hérité de FrameworkElement.) |
8 | Name Obtient ou définit le nom d'identification de l'élément. Le nom fournit une référence afin que le code-behind, tel que le code du gestionnaire d'événements, puisse faire référence à un élément de balisage après sa construction pendant le traitement par un processeur XAML. (Hérité de FrameworkElement.) |
9 | Orientation Obtient ou définit une valeur qui spécifie la dimension dans laquelle le contenu enfant est organisé. |
dix | Parent Obtient l'élément parent logique de cet élément. (Hérité de FrameworkElement.) |
11 | Resources Obtient ou définit le dictionnaire de ressources défini localement. (Hérité de FrameworkElement.) |
12 | RowDefinitions Obtient une liste d'objets RowDefinition définis sur cette instance de Grid. |
13 | Style Obtient ou définit le style utilisé par cet élément lors de son rendu. (Hérité de FrameworkElement.) |
14 | Width Obtient ou définit la largeur de l'élément. (Hérité de FrameworkElement.) |
Ci-dessous sont les methods de Grid classe.
Sr. No. | Méthode et description |
---|---|
1 | GetColumn Obtient la valeur de la propriété jointe XAML Grid.Column à partir du FrameworkElement spécifié. |
2 | GetColumnSpan Obtient la valeur de la propriété jointe Grid.ColumnSpan XAML à partir du FrameworkElement spécifié. |
3 | GetRow Obtient la valeur de la propriété jointe Grid.Row XAML à partir du FrameworkElement spécifié. |
4 | SetColumn Définit la valeur de la propriété jointe XAML Grid.Column sur le FrameworkElement spécifié. |
5 | SetRow Définit la valeur de la propriété jointe Grid.Row XAML sur le FrameworkElement spécifié. |
6 | SetRowSpan Définit la valeur de la propriété jointe Grid.RowSpan XAML sur le FrameworkElement spécifié. |
L'exemple suivant montre comment ajouter les éléments enfants dans une grille pour le spécifier sous forme de tableau. Vous trouverez ci-dessous l'implémentation XAML dans laquelle certains éléments d'interface utilisateur sont ajoutés.
<UserControl x:Class = "DynamicLayout.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d"
d:DesignHeight = "300" d:DesignWidth = "400">
<Grid x:Name = "LayoutRoot" Background = "White">
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "130" />
<ColumnDefinition Width = "1*" />
<ColumnDefinition Width = "2*" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "50" />
</Grid.RowDefinitions>
<TextBlock Grid.Column = "0" Grid.Row = "0"
Text = "Content that no longer fits, not even close here"
TextWrapping = "Wrap" />
<Button Grid.Column = "1" Grid.Row = "0" Content = "OK" />
<Ellipse Grid.Column = "1" Grid.Row = "1" Fill = "Aqua" />
<Rectangle Grid.Column = "2" Grid.Row = "1" Fill = "Orchid" RadiusX = "20" RadiusY = "20" />
</Grid>
</UserControl>
La première colonne est définie sur une taille fixe. Tout élément de cette colonne aura cette largeur.Grid.Column et Grid.Row properties spécifient dans quelle ligne et colonne ces éléments se trouvent, et ce sont des propriétés basées sur 0.
Les deuxième ou troisième colonnes ont une largeur de 1* et 2*. Cela signifie qu'ils partagent l'espace restant après que les colonnes de largeur fixe et automatique ont pris leur espace. L'importance de la1 et 2 voici que le 2* la colonne reçoit deux fois plus d'espace que la 1* colonne.
Lorsque le code ci-dessus est exécuté, vous verrez la sortie suivante.
Lorsque vous redimensionnez l'application, le contenu de ces deux colonnes est redimensionné pour correspondre. À propos, la valeur absolue d'une ligne ou d'une colonne de taille étoile n'a pas d'importance; ce ne sont que les ratios qui sont importants.