Silverlight - Dispositions fixes
La disposition des commandes est très importante et critique pour la convivialité de l'application. Il est utilisé pour organiser un groupe d'éléments GUI dans votre application. Il y a certaines choses importantes à considérer lors de la sélection des panneaux de disposition. Ils sont -
- Positions des éléments enfants.
- Tailles des éléments enfants.
- Superposition d'éléments enfants qui se chevauchent les uns sur les autres.
Une disposition de pixels fixe des commandes ne fonctionne pas si l'application a été utilisée sur différentes résolutions d'écran. XAML fournit un ensemble complet de panneaux de disposition intégrés pour organiser les éléments de l'interface graphique de manière appropriée.
Nous allons commencer par regarder simple fixedmises en page. Ensuite, nous examinerons leDynamicscénarios de mise en page, que Silverlight a conçu pour prendre en charge. Nous verrons les propriétés et les concepts liés à la mise en page qui imprègnent tous les éléments de l'interface utilisateur.
Disposition fixe
Le type de mise en page le plus simple est offert par le Canvasélément. leCanvas panel est le panneau de mise en page de base dans lequel les éléments enfants peuvent être positionnés explicitement en utilisant les coordonnées relatives à n'importe quel côté du canevas tel que gauche, droite, haut et bas.
En règle générale, le Canvasest utilisé pour les éléments graphiques 2D (tels que Ellipse, Rectangle, etc.). Il n'est pas utilisé pour les éléments d'interface utilisateur car la spécification de coordonnées absolues pose des problèmes lorsque vous redimensionnez, localisez ou mettez à l'échelle votre application XAML.
Ci-dessous sont les properties de Canvas 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 | 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 | LeftProperty Identifie la propriété jointe Canvas.Left XAML. |
9 | Margin Obtient ou définit la marge extérieure d'un élément. (Hérité de FrameworkElement.) |
dix | 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.) |
11 | Orientation Obtient ou définit une valeur qui spécifie la dimension dans laquelle le contenu enfant est organisé. |
12 | Parent Obtient l'élément parent logique de cet élément. (Hérité de FrameworkElement.) |
13 | Resources Obtient ou définit le dictionnaire de ressources défini localement. (Hérité de FrameworkElement.) |
14 | Style Obtient ou définit le style utilisé par cet élément lors de son rendu. (Hérité de FrameworkElement.) |
15 | TopProperty Identifie la propriété jointe Canvas.Top XAML. |
16 | Width Obtient ou définit la largeur de l'élément. (Hérité de FrameworkElement.) |
17 | ZIndexProperty Identifie la propriété jointe Canvas.ZIndex XAML. |
Ci-dessous sont les methods de Canvas.
Sr. No. | Méthode et description |
---|---|
1 | GetLeft Obtient la valeur de la propriété jointe Canvas.Left XAML pour l'élément cible. |
2 | GetTop Obtient la valeur de la propriété jointe Canvas.Top XAML pour l'élément cible. |
3 | GetZIndex Obtient la valeur de la propriété jointe XAML Canvas.ZIndex pour l'élément cible. |
4 | SetLeft Définit la valeur de la propriété jointe Canvas.Left XAML pour un élément cible. |
5 | SetTop Définit la valeur de la propriété jointe Canvas.Top XAML pour un élément cible. |
6 | SetZIndex Définit la valeur de la propriété jointe Canvas.ZIndex XAML pour un élément cible. |
L'exemple suivant montre comment ajouter des éléments enfants dans un Canvas. Vous trouverez ci-dessous l'implémentation XAML dans laquelle une Ellipse est créée à l'intérieur d'un Canvas avec différentes propriétés de décalage.
<UserControl x:Class = "FirstExample.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">
<Canvas Width = "380" Height = "280" >
<Ellipse Canvas.Left = "30" Canvas.Top = "30"
Fill = "Gray" Width = "200" Height = "120" />
</Canvas>
</Grid>
</UserControl>
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.