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.