Silverlight - Guide rapide
Bienvenue dans les didacticiels Silverlight. Silverlight est une plate-forme pour créer des applications Internet riches. Ce didacticiel expliquera les concepts de Silverlight et vous montrera comment l'intégrer dans vos applications Web. Une fois terminé, vous aurez une meilleure compréhension des applications Silverlight utilisant XAML et C #.
Qu'est-ce que Silverlight
Silverlight est un plug-in de navigateur, conçu pour créer des applications Internet riches; les applications qui s'exécutent dans le navigateur comme des applications Web normales, mais qui tentent de faire progresser l'interface utilisateur au-delà de ce que HTML peut aller. Par exemple,
Silverlight est un framework permettant de créer des applications riches, hébergées par un navigateur qui s'exécutent sur une variété de systèmes d'exploitation.
Il peut également coexister avec HTML. Par conséquent, Silverlight peut améliorer une application Web existante.
Silverlight opère sa magie grâce à un plug-in de navigateur. Lorsque vous naviguez sur une page Web contenant du contenu Silverlight, ce plug-in de navigateur s'exécute, exécute le code et rend ce contenu dans une région spécifiquement désignée de la page.
La partie importante est que le plug-in Silverlight fournit un environnement plus riche que le mélange traditionnel de HTML et de JavaScript qui alimente les pages Web ordinaires.
Vous pouvez créer des pages Silverlight qui lisent des vidéos, présentent des graphiques 3D accélérés par le matériel et utilisent des animations vectorielles.
Du point de vue du développeur, la caractéristique la plus intéressante de Silverlight est qu'elle apporte le modèle de programmation .NET Framework du côté client de vos applications Web.
Silverlight est conçu pour fonctionner à l'intérieur des pages Web, de sorte qu'il peut fonctionner comme un plugin de navigateur. Il fournit des services graphiques pour le rendu des bitmaps, des graphiques vectoriels, des vidéos haute définition et des animations.
Vous pouvez écrire en C # ou Visual Basic .NET et utiliser les fonctionnalités de la bibliothèque de classes .NET Framework sur le code qui s'exécute dans le navigateur Web.
Les interfaces utilisateur Silverlight utilisent elles-mêmes un modèle très similaire à Windows Presentation Foundation (WPF), qui est le framework d'interface utilisateur dans le .NET Framework de bureau complet.
Si vous connaissez WPF, Silverlight est facile à apprendre. Silverlight est un téléchargement beaucoup plus petit que .NET. C'est à peu près un dixième de la taille, donc seul un sous-ensemble de la bibliothèque de classes est présent, et diverses implications ont été apportées au modèle de WPF.
Malgré l'échelle réduite, les développeurs .NET expérimentés se sentiront instantanément chez eux dans Silverlight.
Plateformes et navigateurs
Les plates-formes et navigateurs pris en charge par Silverlight sont -
les fenêtres
Silverlight prend en charge Windows, comme vous pouvez vous y attendre d'un produit Microsoft. Il nécessite au moins Windows XP Service Pack 2 ou des versions récentes de Windows.
Les anciennes versions ne sont pas entièrement prises en charge. Par exemple, Silverlight ne fonctionnera pas du tout sur Windows ME et Windows 2000 a une prise en charge limitée.
En ce qui concerne les navigateurs, Silverlight prend bien sûr en charge Internet Explorer de Microsoft et prend en charge Firefox et Google Chrome version 4.
Globalement, Silverlight prend en charge l'API de plug-in de navigateur Web commune. Il fonctionne dans une gamme de navigateurs plus large que la liste officiellement prise en charge.
Mac
Silverlight prend en charge Mac OS10, bien que Silverlight version 2 ou ultérieure ne fonctionne que sur les Mac Intel.
Sur les Mac modernes, Firefox et Safari sont pris en charge.
Linux
Le plug-in Silverlight de Microsoft ne fonctionne pas sous Linux, mais le projet open source Mono a une ramification appelée Moonlight, qui est un plug-in compatible Silverlight qui fonctionne sous Linux.
Moonlight fonctionne dans Firefox et, fait intéressant, a toujours été capable de fonctionner en mode autonome.
L'une des raisons pour lesquelles le projet Mono a décidé de créer Moonlight en premier lieu est qu'il pensait que Silverlight serait une technologie utile pour créer des widgets d'interface utilisateur fonctionnant sur le bureau.
Microsoft fournit deux outils importants pour le développement d'applications Silverlight. Ils sont -
- Visual Studio
- Mélange d'expression
Actuellement, les deux outils peuvent créer des projets Silverlight, mais le fait est que Visual Studio est davantage utilisé par les développeurs tandis que Blend est toujours utilisé plus souvent par les concepteurs. Microsoft fournit une version gratuite de Visual Studio, qui peut être téléchargée à partir dehttps://www.visualstudio.com. Pour ce didacticiel, nous utiliserons principalement Visual Studio.
Installation
Step 1- Une fois Silverlight téléchargé, exécutez le programme d'installation. La boîte de dialogue suivante s'affiche.
Step 2 - Cliquez sur le Install bouton et il lancera le processus d'installation.
Step 3 - Une fois que Sivelight est installé avec succès, vous verrez la boîte de dialogue suivante.
Step 4 - Fermez cette boîte de dialogue et redémarrez votre ordinateur si nécessaire.
Step 5 - Maintenant ouvert Visual studio du Startmenu, qui ouvrira la boîte de dialogue ci-dessous. Il faudra un certain temps pour la préparation, tout en regardant pour la première fois.
Step 6 - Ensuite, vous verrez la fenêtre principale de Visual Studio.
Step 7- Maintenant, pour commencer avec l'application Silverlight, vous devez également installer l'outil Silverlight Developer sur votre machine. Téléchargez et installez le dernier outil de développement Silverlight à partir dehttp://silverlight.dlservice.microsoft.com/download/8/E/7/8E7D9B4B-2088-4AED8356-20E65BE3EC91/40728.00/Silverlight_Developer_x64.exe
Step 8 - Cliquez Install. Cela prendra un certain temps pour l'installation.
Step 9 - Une fois l'installation terminée, vous verrez le message suivant.
Step 10- Vous êtes maintenant prêt à créer votre première application Silverlight. Cliquez surClose.
Dans ce chapitre, nous examinerons un exemple fonctionnel de Silverlight. Nous avons besoin de deux choses -
Tout d'abord, nous avons besoin d'une page Web. Silverlight est destiné aux applications Internet riches.Il est conçu pour fonctionner à l'intérieur d'un navigateur Web dans le cadre d'une page Web. La page doit intégrer une balise appropriée pour charger le plug-in Silverlight. Il peut également inclure la logique permettant de détecter si Silverlight est installé et peut fournir une interface utilisateur de secours, lorsqu'il est absent.
La deuxième chose dont nous avons besoin est le contenu Silverlight lui-même. Ce didacticiel se concentrera sur le modèle de programmation .NET pour Silverlight. Nous allons créer une application Silverlight compilée contenant un mélange de XAML, le langage de maquette que nous utilisons pour définir les interfaces utilisateur Silverlight et du code .NET écrit en C #.
Créer une page Web
Le moyen le plus simple de commencer à utiliser Silverlight est de créer un site Web ordinaire avec des pages HTML et sans code côté serveur. Prenons un exemple très simple.
Step 1 - Ouvert Visual Studio. Clique leFile menu, pointez sur New puis cliquez sur Project.
Step 2 - Un New Projectla boîte de dialogue s'ouvre. En dessous deTemplates, sélectionnez Visual C# et alors click Silverlight. Dans le volet droit, choisissez Application Silverlight.
Entrez un nom de projet et un emplacement sur votre disque dur pour enregistrer votre projet, puis cliquez sur OK pour créer le projet.
Le projet Silverlight lui-même ne fera que créer le contenu Silverlight, et ce contenu n'est qu'un atout parmi d'autres qui constitueront l'ensemble de l'application Web.
Cliquez sur OK.
Step 3 - Vérifiez le Host the Silverlight application checkbox. La valeur par défaut est un projet d'application Web ASP.NET.
Step 4- MS-Visual Studio a créé deux projets, le projet Silverlight et une application Web ASP.NET. Maintenant, nous avons besoin d'une application Web ASP.NET. Vous pouvez le voir dans leSolution Explorer comme indiqué ci-dessous.
Tout ce qui peut servir le contenu via HTTP fera l'affaire, mais c'est Visual Studio, et il comprend la technologie Web ASP.NET, c'est donc ce qu'il nous donne.
Pour démontrer que Silverlight ne dépend d'aucune technologie particulière côté serveur, supprimons ceci .aspx fichier, ne laissant que le fichier HTML statique.
Step 5- Cliquez avec le bouton droit sur FirstExampleTestpage.aspx. Dans la liste des options, cliquez surDelete.
Step 6 - Ensemble FirstExampleTestPage.html comme le Start page.
le MainPage.xamlfile définit l'interface utilisateur pour le contenu Silverlight. Soit vous pouvez écrire directement du code XAML, soit vous pouvez également utiliserToolbox pour faire glisser et déposer différents éléments de l'interface utilisateur.
Step 7 - Ci-dessous est un code simple en MainPage.xaml dans lequel un Button et un TextBlock sont définis à l'intérieur du StackPanel.
<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">
<StackPanel>
<TextBlock x:Name = "TextMessage"
Text = "Hello World!"
Margin = "5">
</TextBlock>
<Button x:Name = "ClickMe"
Click = "ClickMe_Click"
Content = "Click Me!"
Margin = "5">
</Button>
</StackPanel>
</Grid>
</UserControl>
Step 8 - Cet exemple suppose que vous avez créé une méthode de gestion des événements nommée ClickMe_Click. Voici à quoi cela ressemble dans leMainPage.xaml.cs fichier.
using System.Windows;
using System.Windows.Controls;
namespace FirstExample {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void ClickMe_Click(object sender, RoutedEventArgs e) {
TextMessage.Text = "Congratulations! you have created your first Silverlight Applicatoin";
}
}
}
Step 9 - Une application Silverlight peut être exécutée sur tous les navigateurs installés.
Step 10 - Lorsque le code ci-dessus est compilé et exécuté, vous verrez la page Web suivante.
Step 11 - Maintenant, lorsque vous cliquez sur le Click Me bouton, il mettra à jour le texte dans le TextBlock comme indiqué ci-dessous.
Nous vous recommandons d'exécuter l'exemple ci-dessus en ajoutant d'autres éléments d'interface utilisateur.
L'une des premières choses que vous rencontrerez lors de l'utilisation de Silverlight est XAML. XAML est synonyme de langage de balisage d'application extensible. C'est un langage simple et déclaratif basé sur XML.
En XAML, il est très facile de créer, d'initialiser et de définir les propriétés d'un objet avec des relations hiérarchiques.
Il est principalement utilisé pour la conception de l'interface graphique.
Il peut également être utilisé à d'autres fins, par exemple pour déclarer un flux de travail dans une fondation de flux de travail.
Syntaxe de base
Lorsque vous créez un nouveau projet Silverlight, vous verrez une partie du code XAML par défaut dans MainPage.xaml comme indiqué ci-dessous.
<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">
</Grid>
</UserControl>
Vous pouvez voir que le fichier XAML donné ci-dessus mentionne différents types d'informations; tous sont brièvement décrits dans le tableau ci-dessous.
Information | La description |
---|---|
<UserControl | Fournit la classe de base pour définir un nouveau contrôle qui encapsule les contrôles existants et fournit sa propre logique. |
x: Class = "FirstExample.MainPage" | Il s'agit d'une déclaration de classe partielle, qui connecte le balisage à ce code de classe partiel derrière, défini dans celui-ci. |
xmlns = "http://schemas.microsoft.com / winfx / 2006 / xaml / presentation" | Mappe l'espace de noms XAML par défaut pour le client / framework Silverlight. |
xmlns: x = "http: //schemas.microsoft.c om / winfx / 2006 / xaml" | Espace de noms XAML pour le langage XAML, qui le mappe au préfixe x:. |
xmlns: d = "http://schemas.microsoft.com / expression / blend / 2008" | L'espace de noms XAML est destiné à la prise en charge des concepteurs, en particulier la prise en charge des concepteurs dans les surfaces de conception XAML de Microsoft Visual Studio et Microsoft Expression Blend. |
xmlns: mc = "http: //schemas.openxmlforma ts.org/markup-compatibility/2006" | Indique et prend en charge un mode de compatibilité de balisage pour la lecture de XAML. |
> | Fin de l'élément objet de la racine. |
<Grid> </Grid> | Ce sont les balises de début et de fin d'un objet de grille vide. |
</UserControl> | Fermeture de l'élément objet. |
Les règles de syntaxe pour XAML sont presque similaires à celles de XML. Si vous regardez un document XAML, vous remarquerez qu'il s'agit en fait d'un fichier XML valide. Son vice versa n'est pas vrai, car en XML, la valeur des attributs doit être une chaîne tandis qu'en XAML, il peut s'agir d'un objet différent appelé syntaxe d'élément Property.
La syntaxe d'un élément Object commence par un crochet à angle gauche (<) suivi du nom d'un objet, par exemple Button.
Les propriétés et les attributs de cet élément d'objet sont définis.
L'élément Object doit être fermé par une barre oblique (/) suivie immédiatement d'un crochet à angle droit (>).
Un exemple d'objet simple sans élément enfant est présenté ci-dessous.
<Button/>
Exemple d'élément objet avec quelques attributs -
<Button Content = "Click Me" Height = "30" Width = "60"/>
Exemple de syntaxe alternative pour définir les propriétés (syntaxe d'élément Property) -
<Button>
<Button.Content>Click Me</Button.Content>
<Button.Height>30</Button.Height>
<Button.Width>60</Button.Width>
</Button>
Exemple d'objet avec élément enfant: StackPanel contient Textblock comme élément enfant.
<StackPanel Orientation = "Horizontal">
<TextBlock Text = "Hello"/>
</StackPanel/>
Pourquoi XAML dans Silverlight
XAML n'a pas été inventé à l'origine pour Silverlight. Il provenait de WPF, la Windows Presentation Foundation. Silverlight est souvent décrit comme étant un sous-ensemble de WPF. Ce n'est pas strictement vrai, car Silverlight peut faire certaines choses que WPF ne peut pas. Même là où les fonctionnalités se chevauchent, les deux sont légèrement différents dans les détails.
Il est plus exact de dire que WPF et Silverlight sont très similaires à bien des égards. Malgré les différences, il est toujours instructif d'examiner la fonctionnalité XAML que Silverlight a empruntée à WPF. Par exemple, Silverlight propose des primitives graphiques pour les bitmaps et les formes évolutives.
Il fournit également des éléments pour le rendu vidéo et audio.
Il a un support de texte formaté simple et vous pouvez animer n'importe quel élément. Si vous connaissez WPF, cet ensemble de fonctionnalités vous sera familier.
Un point important, vous ne pouvez pas prendre WPF XAML et l'utiliser dans Silverlight.
Bien qu'il existe des similitudes, vous trouverez également de nombreuses petites différences.
XAML et code derrière
XAML définit l'apparence et la structure d'une interface utilisateur. Cependant, si vous souhaitez que votre application fasse quelque chose d'utile lorsque l'utilisateur interagit avec elle, vous aurez besoin de code.
Chaque fichier XAML est généralement associé à un fichier de code source, que nous appelons le code derrière. Divers frameworks Microsoft utilisent ce terme.
Le code derrière devra généralement utiliser des éléments définis dans le XAML, soit pour récupérer des informations sur l'entrée utilisateur, soit pour afficher des informations à l'utilisateur.
Dans le code XAML ci-dessous, TextBlock et Buttonsont définis. Par défaut, lorsque l'application est exécutée, elle affichera un texte "Hello World!»Sur la page Web et un bouton.
<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">
<StackPanel>
<TextBlock x:Name = "TextMessage"
Text = "Hello World!"
Margin = "5">
</TextBlock>
<Button x:Name = "ClickMe"
Click = "ClickMe_Click"
Content = "Click Me!"
Margin = "5">
</Button>
</StackPanel>
</Grid>
</UserControl>
Le code derrière peut accéder à tout élément nommé avec le x:Name directif.
Les éléments nommés deviennent disponibles via des champs dans le code derrière, permettant au code d'accéder à ces objets et à leurs membres de la manière habituelle.
le x:Prefix signifie que le nom n'est pas une propriété normale.
x:Name est un signal spécial au compilateur XAML que nous voulons avoir accès à cet objet dans le code derrière.
Vous trouverez ci-dessous l'implémentation de l'événement de clic de bouton dans lequel le TextBlock le texte est mis à jour.
using System.Windows;
using System.Windows.Controls;
namespace FirstExample {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void ClickMe_Click(object sender, RoutedEventArgs e) {
TextMessage.Text = "Congratulations! you have created your first Silverlight Applicatoin";
}
}
}
XAML n'est pas le seul moyen de concevoir les éléments de l'interface utilisateur. C'est à vous de déclarer des objets en XAML ou de déclarer / écrire dans un code.
XAML est facultatif, mais malgré cela, il est au cœur de Silverlight conception.
L'objectif du codage XAML est de permettre aux concepteurs visuels de créer directement les éléments de l'interface utilisateur. Par conséquent,Silverlight vise à permettre de contrôler tous les aspects visuels de l'interface utilisateur à partir du balisage.
Si vous créez un nouveau projet dans Visual Studio, vous verrez quatre types de projet dans le volet droit de la boîte de dialogue. Ils sont -
- Application Silverlight
- Bibliothèque de classes Silverlight
- Bibliothèque de classes (portable)
- Application de navigation Silverlight
Les deux premiers, Silverlight Application et Silverlight Class Library, sont assez simples. Ceux-ci sont analogues aux exécutables dans les DLL dans le monde des applications Windows classiques. Les deux créent des DLL en raison de la façon dont les applications Silverlight sont déployées.
Conceptuellement, un projet d'application Silverlight crée un programme qui peut être exécuté, tandis que le projet Bibliothèque de classes crée une bibliothèque conçue pour être incorporée dans d'autres applications.
Vous pouvez créer une bibliothèque de classes si vous prévoyez de créer plusieurs applications et souhaitez réutiliser le code commun. Si vous envisagez de vendre les contrôles que d'autres personnes utiliseront dans leurs applications, encore une fois, une bibliothèque est la chose à construire.
Les autres types de projets sont un peu moins évidents, nous allons donc les examiner en détail plus loin dans ce chapitre.
Applications Web Silverlight
Les applications Silverlight sont téléchargées à partir du Web, vous aurez donc normalement un projet Web associé au projet Silverlight. Il existe quelques fonctionnalités de Visual Studio, conçues pour gérer la relation entre ces projets.
Regardons à nouveau un exemple simple de projet d'application Silverlight.
Step 1 - Ouvert Visual Studio. Clique leFile menu, pointez sur New puis cliquez sur Project.
Step 2 - Un New Projectla boîte de dialogue s'ouvre. En dessous deTemplates, sélectionnez Visual C# et alors click Silverlight. Dans le volet droit, choisissez Application Silverlight.
Entrez un nom de projet et un emplacement sur votre disque dur pour enregistrer votre projet.
Le projet Silverlight lui-même ne fera que créer le contenu Silverlight, et ce contenu n'est qu'un atout parmi d'autres qui constitueront l'ensemble de l'application Web.
Cliquez sur OK.
Step 3 - Vérifiez le Host the Silverlight application checkbox. La valeur par défaut est un projet d'application Web ASP.NET.
Step 4- MS-Visual Studio a créé deux projets, le projet Silverlight et une application Web ASP.NET. Maintenant, nous avons besoin d'une application Web ASP.NET. Vous pouvez le voir dans leSolution Explorer comme indiqué ci-dessous.
Tout ce qui peut servir le contenu via HTTP fera l'affaire, mais c'est Visual Studio, et il comprend la technologie Web ASP.NET, c'est donc ce qu'il nous donne.
Pour démontrer que Silverlight ne dépend d'aucune technologie particulière côté serveur, supprimons ceci .aspx fichier, ne laissant que le fichier HTML statique.
Step 5- Cliquez avec le bouton droit sur FirstExampleTestpage.aspx. Dans la liste des options, cliquez surDelete.
Step 6 - Ensemble FirstExampleTestPage.html comme le Start page.
le MainPage.xamlfile définit l'interface utilisateur pour le contenu Silverlight. Soit vous pouvez écrire directement du code XAML, soit vous pouvez également utiliserToolbox pour faire glisser et déposer différents éléments de l'interface utilisateur.
Step 7 - Ci-dessous est un code simple en MainPage.xaml dans lequel un Button et un TextBlock sont définis à l'intérieur du StackPanel.
<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">
<StackPanel>
<TextBlock x:Name = "TextMessage" Text = "Hello World!"
Margin = "5"> </TextBlock>
<Button x:Name = "ClickMe" Click = "ClickMe_Click" Content = "Click
Me!" Margin = "5"> </Button>
</StackPanel>
</Grid>
</UserControl>
Step 8 - Cet exemple suppose que vous avez créé une méthode de gestion des événements nommée ClickMe_Click. Voici à quoi cela ressemble dans leMainPage.xaml.cs fichier.
using System.Windows;
using System.Windows.Controls;
namespace FirstExample {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void ClickMe_Click(object sender, RoutedEventArgs e) {
TextMessage.Text = "Congratulations! you have created your
first Silverlight Applicatoin";
}
}
}
Step 9 - Une application Silverlight peut être exécutée sur tous les navigateurs installés.
Step 10 - Lorsque le code ci-dessus est compilé et exécuté, vous verrez la page Web suivante.
Application de navigation Silverlight
Le modèle d'application de navigation Silverlight crée un projet similaire à une application Silverlight ordinaire. Il n'y a rien de fondamentalement différent entre les deux types de projets. Le modèle de navigation comprend uniquement du code supplémentaire que vous pouvez facilement ajouter vous-même. Comme son nom l'indique, il prend en charge la navigation de type Web dans l'application Silverlight.
Créons une application de navigation.
Step 1 - Sélectionnez Silverlight Navigation Application à partir du volet droit dans le New Project boite de dialogue.
Step 2 - Suivez les paramètres comme vous l'avez fait pour l'application Web Silverlight.
Step 3 - Cliquez sur le OKbouton. Une fenêtre s'ouvrira comme indiqué ci-dessous.
Ceux-ci ont généralement un projet Web associé, nous en aurons donc un. Il crée deux projets comme décrit précédemment, mais comme vous pouvez le voir, l'interface utilisateur par défaut semble un peu moins vide.
Step 4- Il fournit une application Chrome, y compris une barre de navigation. La solution contient quelques fichiers supplémentaires. CeStyles Le fichier définit l'aspect et la convivialité du Navigationbar. Dans ceViews dossier, nous voyons quelques pages, ainsi qu'une fenêtre pour afficher les erreurs.
Comme vous pouvez le voir, lorsque vous exécutez l'application, elle affiche une page d'accueil avec du contenu d'espace réservé.
Step 5 - Lorsque vous cliquez sur le About bouton, il naviguera vers le About page.
L'important est que vous puissiez ensuite utiliser le navigateur Back et Forward boutons pour revenir sur les étapes.
Normalement, lorsque vous faites cela, le navigateur Web passe d'une page Web à une autre, mais ici, ce n'est pas le cas. L'application Silverlight ne se décharge pas réellement; il continue de fonctionner et affiche simplement un contenu différent.
Par conséquent, du point de vue du navigateur, tout est en fait sur une seule page Web. Silverlight joue quelques tours avec les boutons de navigation pour s'assurer que la page Web ne se décharge pas lorsque nous naviguons.
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 des éléments enfants qui se chevauchent.
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 problème 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.
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 car 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, 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 tabulaire. 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 Les propriétés 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.
La mise en page dans Silverlight se produit toujours dans l'un des deux modes, soit contraint, soit sans contrainte. Une disposition contrainte en est une, où un conteneur impose la largeur ou la hauteur. Par exemple, le navigateur Web, généralement avec CSS, détermine toujours les dimensions globales des plug-ins Silverlight.
Certaines caractéristiques importantes sont -
La disposition des éléments de niveau supérieur est contrainte à la fois horizontalement et verticalement. Quelle que soit la mise en page qu'il produit, il doit toujours aboutir à des résultats de la taille imposée par le navigateur.
Certains éléments se retrouvent avec UnconstrainedMise en page, ce qui signifie que les éléments sont libres de choisir leur propre taille. Par exemple, des éléments à l'intérieur d'une verticaleStackPanel sont verticalement sans contrainte.
Le StackPanel leur donnera autant de hauteur que nécessaire. En fait, il le fera même s'il n'y a pas assez d'espace. Il indiquera aux éléments qu'ils ont la hauteur dont ils ont besoin, puis recadrera tout ce qui ne convient pas.
La plupart des interfaces utilisateur Silverlight contiennent un mélange de ces deux styles de disposition. Que son parent impose des contraintes ou non, unStackPanel performera toujours UnconstrainedDisposition dans le sens de l'empilement. Il en va de même pour une ligne ou une colonne de grille lorsque la hauteur ou la largeur est définie surAuto.
Supposons que vous ayez un élément, qui se trouve à l'intérieur d'un conteneur qui impose une largeur horizontale fixe. Par défaut, votre élément sera étiré pour remplir l'espace. Si vous définissez l'alignement sur Gauche, Droite ou Centre, cela supprimera la contrainte.
L'élément prendra uniquement la largeur dont il a besoin. Bien sûr, vous pouvez introduire une contrainte avec une largeur ou une hauteur fixe.
La mise en page sans contrainte est parfois appelée Size to Content, car la taille d'un élément sans contrainte est généralement déterminée par son contenu.
La taille au contenu est une idée importante dans la mise en page Silverlight. C'est ce qui permet à la mise en page de s'adapter à toutes les informations affichées.
Sr. No. | Commandes et description |
---|---|
1 | GridSplitter Les contraintes peuvent provenir du navigateur contenant ou de dimensions fixes dans votre conception. Cependant, il est parfois utile de laisser l'utilisateur imposer des contraintes. |
2 | ScrollViewer Certaines interfaces utilisateur finissent par avoir besoin d'afficher plus d'informations que l'espace disponible. Une solution courante à cela est de fournir une région défilable. Silverlight rend cela très facile avec ScrollViewer. |
3 | Frontière Un autre élément utile à garder à l'esprit lors de la présentation de l'interface utilisateur est Border. |
Mode plein écran
Le plug-in Silverlight est capable de prendre en charge la totalité de l'écran. Il existe une propriété que vous pouvez définir sur une classe d'assistance pour passer en mode plein écran. Cependant, il existe quelques contraintes pour des raisons de sécurité. Pour empêcher un site Web de pouvoir prendre le contrôle de l'écran à volonté et faire quelque chose de mal, comme simuler une invite demandant le mot de passe de l'utilisateur.
Pour entrer en mode plein écran, vous devez obtenir la propriété Host.Content de l'objet d'application et définir sa propriété IsFullScreen sur true.
Jetons un coup d'œil à un exemple simple qui bascule la propriété, de sorte qu'elle basculera entre plein écran et normal.
<UserControl x:Class = "FullScreenExample.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">
<Border BorderBrush = "Gray" BorderThickness = "4" CornerRadius = "30" Padding = "20">
<Border.Background>
<LinearGradientBrush StartPoint = "0,0" EndPoint = "0,1">
<GradientStop Offset = "0" Color = "Wheat" />
<GradientStop Offset = "1" Color = "BurlyWood" />
</LinearGradientBrush>
</Border.Background>
<Grid x:Name = "LayoutRoot">
<Button x:Name = "fullScreenButton" HorizontalAlignment = "Center"
VerticalAlignment = "Center" FontSize = "30" Width = "300"
Height = "100" Content = "Go Full Screen" Click = "Button_Click" />
</Grid>
</Border>
</UserControl>
Voici un code en C # qui initie le retour du plein écran à la normale. Vous pouvez savoir quand cela se produit en manipulant leHost.Content objets FullScreenChanged un événement.
using System;
using System.Windows;
using System.Windows.Controls;
namespace FullScreenExample {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
App.Current.Host.Content.FullScreenChanged += Content_FullScreenChanged;
}
void Content_FullScreenChanged(object sender, EventArgs e) {
if (Application.Current.Host.Content.IsFullScreen) {
fullScreenButton.Content = "Return to Normal";
} else {
fullScreenButton.Content = "Go Full Screen";
}
}
private void Button_Click(object sender, RoutedEventArgs e) {
var content = Application.Current.Host.Content;
content.IsFullScreen = !content.IsFullScreen;
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Lorsque l'utilisateur clique sur le Go Full Screen bouton, puis il passera en mode plein écran.
Notez que le texte du bouton a changé. Il dit maintenantReturn to Normal. Si vous cliquez à nouveau dessus ou en appuyant sur Echap, il reviendra hors du mode plein écran.
Étant donné que le contenu Silverlight s'exécute toujours à l'intérieur d'une page Web, la balise d'objet est soumise aux règles de mise en page CSS normales. Il n'y a aucun moyen pour le plug-in de pousser une taille préférée vers le navigateur, donc quelle que soit la taille du contenu Silverlight peut vouloir être, sa taille et sa position seront entièrement déterminées par la page Web contenant.
Le modèle de projet Silverlight par défaut place le CSS dans la page Web qui donne à la balise d'objet l'ensemble de la fenêtre du navigateur.
Le XAML par défaut semble avoir une taille fixe, mais si vous regardez de plus près, vous verrez que le modèle définit les propriétés de largeur et de hauteur de conception.
Ceux-ci indiquent à Visual Studio, ou Blend, la taille de l'interface utilisateur dans le concepteur, mais ils lui permettent de se redimensionner au moment de l'exécution.
Dans Solution Explorer tu verras {project name}TestPage.html fichier, qui est le code HTML par défaut que vous obtenez lorsque vous créez un nouveau projet Silverlight dans Visual Studio, comme indiqué ci-dessous.
Le CSS en haut ici définit le style HTML et corps à 100%, ce qui peut sembler un peu étrange.
Voici le fichier html complet, qui contient différents paramètres.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml" >
<head>
<title>FirstExample</title>
<style type = "text/css">
html, body {
height: 100%;
overflow: auto;
}
body {
padding: 0;
margin: 0;
}
#silverlightControlHost {
height: 100%;
text-align:center;
}
</style>
<script type = "text/javascript" src = "Silverlight.js"></script>
<script type = "text/javascript">
function onSilverlightError(sender, args) {
var appSource = "";
if (sender != null && sender != 0) {
appSource = sender.getHost().Source;
}
var errorType = args.ErrorType;
var iErrorCode = args.ErrorCode;
if (errorType == "ImageError" || errorType == "MediaError") {
return;
}
var errMsg = "Unhandled Error in Silverlight Application " + appSource + "\n" ;
errMsg += "Code: "+ iErrorCode + " \n";
errMsg += "Category: " + errorType + " \n";
errMsg += "Message: " + args.ErrorMessage + " \n";
if (errorType == "ParserError") {
errMsg += "File: " + args.xamlFile + " \n";
errMsg += "Line: " + args.lineNumber + " \n";
errMsg += "Position: " + args.charPosition + " \n";
} else if (errorType == "RuntimeError") {
if (args.lineNumber != 0) {
errMsg += "Line: " + args.lineNumber + " \n";
errMsg += "Position: " + args.charPosition + " \n";
}
errMsg += "MethodName: " + args.methodName + " \n";
}
throw new Error(errMsg);
}
</script>
</head>
<body>
<form id = "form1" runat = "server" style = "height:100%">
<div id = "silverlightControlHost">
<object data = "data:application/x-silverlight-2,"
type = "application/xsilverlight-2" width = "100%" height = "100%">
<param name = "source" value = "ClientBin/FirstExample.xap"/>
<param name = "onError" value = "onSilverlightError" />
<param name = "background" value = "white" />
<param name = "minRuntimeVersion" value = "5.0.61118.0" />
<param name = "autoUpgrade" value = "true" />
<a href = "http://go.microsoft.com/fwlink/?LinkID=149156&v=5.0.61118.0"
style = "textdecoration:none">
<img src = "http://go.microsoft.com/fwlink/?LinkId=161376"
alt = "Get Microsoft Silverlight" style = "border-style:none"/>
</a>
</object>
<iframe id = "_sl_historyFrame" style = "visibility:hidden;height:0px;
width:0px;border:0px"></iframe>
</div>
</form>
</body>
</html>
En regardant le silverlightControlHost, nous devons nous assurer qu'il a une hauteur fixe, disons 300 pixels, et une largeur de 400 pixels, ce qui correspond à la largeur et à la hauteur de conception par défaut dans le XAML. Vous pouvez également modifier ces paramètres en fonction des exigences de votre application.
Contenu superposé
Par défaut, les contenus Silverlight et HTML ne peuvent pas partager le même espace à l'écran. Si vous créez un contenu à partir des deux, de sorte qu'ils occupent le même espace, seul le contenu Silverlight sera visible.
En effet, par défaut, Silverlight demandera au navigateur sa propre fenêtre privée, restituant tout le contenu dans celle-ci. Il s'agit d'une fenêtre enfant à l'intérieur du navigateur, elle ressemble donc à une partie de la page Web, mais elle empêche le contenu de se chevaucher.
La principale raison en est la performance. En obtenant sa propre zone privée à l'écran, Silverlight n'a pas à coordonner son rendu avec un navigateur Web.
Cependant, il est parfois utile d'avoir un contenu qui se chevauche. Il y a un prix de performance à payer. Vous constaterez peut-être que les animations ne fonctionnent pas aussi bien lorsque Silverlight et HTML partagent l'espace à l'écran, mais la flexibilité de mise en page supplémentaire peut valoir le prix. Pour utiliser le contenu qui se chevauche, vous devez activer le mode sans fenêtre.
En mode sans fenêtre, le plug-in Silverlight effectue le rendu dans le même gestionnaire de fenêtre cible que le navigateur, ce qui permet au contenu de se mélanger.
L'index Zed ou l'index Z est significatif lorsque le contenu se chevauche. En ce qui concerne le HTML, le contenu Silverlight est un élément HTML unique, il apparaît donc exactement à un endroit dans l'ordre HTML Z.
Cela a un impact sur la manipulation de la souris. Si le plug-in Silverlight est en haut de la commande HMTL Z, toute activité de la souris n'importe où dans sa zone de délimitation sera transmise au plug-in.
Même si certaines zones du plug-in sont transparentes et que vous pouvez voir le code HTML derrière, vous ne pourrez pas cliquer dessus.
Cependant, si vous faites en sorte que l'index Z avec du contenu HTML soit au-dessus, il continuera à être interactif même s'il chevauche le contenu Silverlight.
Exemple
Jetez un œil à l'exemple simple donné ci-dessous dans lequel nous avons une disposition avec un conteneur, dans lequel trois divs ont tous été disposés pour se chevaucher à l'intérieur de ce div contenant.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml" >
<head>
<title>HtmlOverlap</title>
<style type = "text/css">
#container {
position: relative;
height: 300px;
font-size: small;
text-align:justify;
}
#silverlightControlHost {
position: absolute;
width: 400px;
height: 300px;
}
#underSilverlight {
position: absolute;
left: 4px;
width: 196px;
}
#overSilverlight {
position: relative;
left: 204px;
width: 196px;
}
</style>
<script type = "text/javascript" src = "Silverlight.js"></script>
<script type = "text/javascript">
function onSilverlightError(sender, args) {
var appSource = "";
if (sender != null && sender != 0) {
appSource = sender.getHost().Source;
}
var errorType = args.ErrorType;
var iErrorCode = args.ErrorCode;
if (errorType == "ImageError" || errorType == "MediaError") {
return;
}
var errMsg = "Unhandled Error in Silverlight Application " +
appSource + "\n" ;
errMsg += "Code: "+ iErrorCode + " \n";
errMsg += "Category: " + errorType + " \n";
errMsg += "Message: " + args.ErrorMessage + " \n";
if (errorType == "ParserError") {
errMsg += "File: " + args.xamlFile + " \n";
errMsg += "Line: " + args.lineNumber + " \n";
errMsg += "Position: " + args.charPosition + " \n";
} else if (errorType == "RuntimeError") {
if (args.lineNumber != 0) {
errMsg += "Line: " + args.lineNumber + " \n";
errMsg += "Position: " + args.charPosition + " \n";
}
errMsg += "MethodName: " + args.methodName + " \n";
}
throw new Error(errMsg);
}
</script>
</head>
<body>
<form id = "form1" runat = "server" style = "height:100%">
<div id = 'container'>
<div id = 'underSilverlight'>
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
This is below. This is below. This is below. This is below. This is below.
</div>
<div id = "silverlightControlHost">
<object data = "data:application/x-silverlight-2,"
type = "application/xsilverlight-2" width = "100%" height = "100%">
<param name = "source" value = "ClientBin/HtmlOverlap.xap"/>
<param name = "onError" value = "onSilverlightError" />
<param name = "background" value = "transparent" />
<param name = "windowless" value = "true" />
<param name = "minRuntimeVersion" value = "4.0.50401.0" />
<param name = "autoUpgrade" value = "true" />
<a href = "http://go.microsoft.com/fwlink/?LinkID=149156&v=4.0.50401.0"
style = "text-decoration:none">
<img src = "http://go.microsoft.com/fwlink/?LinkId=161376"
alt = "Get Microsoft Silverlight" style = "border-style:none"/> </a>
</object>
<iframe id = "_sl_historyFrame" style = "visibility:hidden; height:0px;
width:0px; border:0px"> </iframe>
</div>
<div id = 'overSilverlight'>
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
This is on top. This is on top.
This is on top. This is on top. This is on top. This is on top.
</div>
</div>
</form>
</body>
</html>
Ce div va vers la gauche, et il sera à l'arrière de l'ordre Z, car il vient en premier.
Ensuite, au milieu, nous avons le contenu Silverlight qui va remplir toute la largeur.
Ensuite, en plus de cela, il y a un div sur la droite contenant le texte- This is on top.
Vous trouverez ci-dessous le fichier XAML dans lequel un rectangle est ajouté avec certaines propriétés.
<UserControl x:Class = "HtmlOverlap.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">
<Rectangle Margin = "0,120" Fill = "Aquamarine" />
</Grid>
</UserControl>
Lorsque vous exécutez cette application, vous verrez deux colonnes, l'une indiquant ci-dessous à gauche et en haut à droite. Le plug-in Silverlight se trouve dans la même zone que les deux, et dans l'ordre Z, le contenu Silverlight est au milieu de ces deux.
Vous pouvez voir que le remplissage vert semi-transparent ici a légèrement teinté le texte à gauche parce qu'il est au-dessus de cela, mais il n'a pas teinté le texte à droite, car il est derrière ce texte.
Vous pouvez sélectionner le texte sur la droite. Si vous essayez cela avec ce texte à gauche, rien ne se passe, et c'est parce que, en ce qui concerne le navigateur, tout cet espace ici est occupé par le contrôle Silverlight. Puisqu'il est au-dessus du texte dans l'ordre Z, le contrôle Silverlight qui gère l'entrée.
Tous les contrôles ont un comportement interactif tel que la façon dont le bouton s'allume lorsque vous déplacez la souris dessus et le pousse lorsque vous appuyez dessus, le comportement de défilement et de sélection d'une zone de liste. Dans tous les cas, les contrôles vont au-delà de la simple visibilité. Cela pourrait être plus complexe qu'il n'y paraît. Ces contrôles sont une combinaison des parents et du code. Silverlight permet à un développeur de créer et de créer facilement des applications basées sur l'interface utilisateur visuellement enrichies. Les commandes distinguent Silverlight des autres éléments.
Certaines caractéristiques importantes sont -
Les éléments ou contrôles d'interface utilisateur classiques dans d'autres frameworks d'interface utilisateur sont également améliorés dans les applications silverlight.
Presque toutes les commandes Silverlight standard se trouvent dans la boîte à outils, qui fait partie de la System.Windows.Controls.
Ces contrôles peuvent également être créés en langage de balisage XAML.
La hiérarchie d'héritage complète des contrôles Silverlight est la suivante:
le ButtonLa classe représente le type le plus élémentaire de contrôle de bouton. Silverlight reconnaît trois types de boutons de contrôle: le familierButton, la CheckBox, et le RadioButton. Tous ces contrôles sont des contrôles de contenu dérivés deButtonBase. L'héritage hiérarchique de la classe Button est le suivant -
Ci-dessous sont les plus couramment utilisés Properties d'un bouton.
Sr. No. | Propriété et description |
---|---|
1 | Background Obtient ou définit un pinceau qui fournit l'arrière-plan du contrôle. (Hérité de Control) |
2 | BorderBrush Obtient ou définit un pinceau qui décrit le remplissage de bordure d'un contrôle. (Hérité de Control) |
3 | BorderThickness Obtient ou définit l'épaisseur de la bordure d'un contrôle. (Hérité de Control) |
4 | Content Obtient ou définit le contenu d'un ContentControl. (Hérité de ContentControl) |
5 | ClickMode Obtient ou définit une valeur qui indique quand l'événement Click se produit, en termes de comportement de l'appareil. (Hérité de ButtonBase) |
6 | ContentTemplate Obtient ou définit le modèle de données utilisé pour afficher le contenu de ContentControl. (Hérité de ContentControl) |
sept | FontFamily Obtient ou définit la police utilisée pour afficher le texte dans le contrôle. (Hérité de Control) |
8 | FontSize Obtient ou définit la taille du texte de ce contrôle. (Hérité de Control) |
9 | FontStyle Obtient ou définit le style dans lequel le texte est rendu. (Hérité de Control) |
dix | FontWeight Obtient ou définit l'épaisseur de la police spécifiée. (Hérité de Control) |
11 | Foreground Obtient ou définit un pinceau qui décrit la couleur de premier plan. (Hérité de Control) |
12 | Height Obtient ou définit la hauteur suggérée d'un FrameworkElement. (Hérité de FrameworkElement) |
13 | HorizontalAlignment Obtient ou définit les caractéristiques d'alignement horizontal qui sont appliquées à un FrameworkElement lorsqu'il est composé dans un parent de disposition, tel qu'un panneau ou un contrôle d'éléments. (Hérité de FrameworkElement) |
14 | IsEnabled Obtient ou définit une valeur indiquant si l'utilisateur peut interagir avec le contrôle. (Hérité de Control) |
15 | IsPressed Obtient une valeur qui indique si un ButtonBase est actuellement dans un état enfoncé. (Hérité de ButtonBase) |
16 | Margin Obtient ou définit la marge extérieure d'un FrameworkElement. (Hérité de FrameworkElement) |
17 | Name Obtient ou définit le nom d'identification de l'objet. Lorsqu'un processeur XAML crée l'arborescence d'objets à partir du balisage XAML, le code d'exécution peut faire référence à l'objet déclaré XAML par ce nom. (Hérité de FrameworkElement) |
18 | Opacity Obtient ou définit le degré d'opacité de l'objet. (Hérité de UIElement) |
19 | Resources Obtient le dictionnaire de ressources défini localement. En XAML, vous pouvez établir des éléments de ressource en tant qu'éléments d'objet enfant d'un élément de propriété frameworkElement.Resources, via la syntaxe de collection implicite XAML. (Hérité de FrameworkElement) |
20 | Style Obtient ou définit un Style d'occurrence qui est appliqué à cet objet pendant la disposition et le rendu. (Hérité de FrameworkElement) |
21 | Template Obtient ou définit un modèle de contrôle. Le modèle de contrôle définit l'apparence visuelle d'un contrôle dans l'interface utilisateur et est défini dans le balisage XAML. (Hérité de Control) |
22 | VerticalAlignment Obtient ou définit les caractéristiques d'alignement vertical qui sont appliquées à un FrameworkElement lorsqu'il est composé dans un objet parent tel qu'un panneau ou un contrôle d'éléments. (Hérité de FrameworkElement) |
23 | Visibility Obtient ou définit la visibilité d'un UIElement. Un UIElement qui n'est pas visible n'est pas rendu et ne communique pas sa taille souhaitée à la mise en page. (Hérité de UIElement) |
24 | Width Obtient ou définit la largeur d'un FrameworkElement. (Hérité de FrameworkElement) |
Ci-dessous sont les methods de Button.
Sr. No. | Méthode et description |
---|---|
1 | ClearValue Efface la valeur locale d'une propriété de dépendance. (Hérité de DependencyObject) |
2 | FindName Récupère un objet qui porte le nom d'identificateur spécifié. (Hérité de FrameworkElement) |
3 | OnApplyTemplate Appelé chaque fois que le code d'application ou les processus internes (tels qu'une passe de mise en page de reconstruction) appellent ApplyTemplate. En termes plus simples, cela signifie que la méthode est appelée juste avant qu'un élément d'interface utilisateur ne s'affiche dans votre application. Remplacez cette méthode pour influencer la logique post-modèle par défaut d'une classe. (Hérité de FrameworkElement) |
4 | OnContentChanged Appelé lorsque la valeur de la propriété Content change. (Hérité de ContentControl) |
5 | OnDragEnter Appelé avant l'événement DragEnter. (Hérité de Control) |
6 | OnDragLeave Appelé avant que l'événement DragLeave ne se produise. (Hérité de Control) |
sept | OnDragOver Appelé avant l'événement DragOver. (Hérité de Control) |
8 | OnDrop Appelé avant que l'événement Drop ne se produise. (Hérité de Control) |
9 | OnGotFocus Appelé avant que l'événement GotFocus ne se produise. (Hérité de Control) |
dix | OnKeyDown Appelé avant l'événement KeyDown. (Hérité de Control) |
11 | OnKeyUp Appelé avant l'événement KeyUp. (Hérité de Control) |
12 | OnLostFocus Appelé avant que l'événement LostFocus ne se produise. (Hérité de Control) |
13 | SetBinding Attache une liaison à un FrameworkElement, à l'aide de l'objet de liaison fourni. (Hérité de FrameworkElement) |
Ci-dessous sont les Events de Button.
Sr. No. | Description de l'évenement |
---|---|
1 | Click Se produit lorsque l'utilisateur clique sur un contrôle de bouton. (Hérité de ButtonBase) |
2 | DataContextChanged Se produit lorsque la valeur de la propriété FrameworkElement.DataContext change. (Hérité de FrameworkElement) |
3 | DragEnter Se produit lorsque le système d'entrée signale un événement de glissement sous-jacent avec cet élément comme cible. (Hérité de UIElement) |
4 | DragLeave Se produit lorsque le système d'entrée signale un événement de glissement sous-jacent avec cet élément comme origine. (Hérité de UIElement) |
5 | DragOver Se produit lorsque le système d'entrée signale un événement de glissement sous-jacent avec cet élément comme cible de dépôt potentielle. (Hérité de UIElement) |
6 | DragStarting Se produit lorsqu'une opération de glissement est lancée. (Hérité de UIElement) |
sept | GotFocus Se produit lorsqu'un UIElement reçoit le focus. (Hérité de UIElement) |
8 | Holding Se produit lorsqu'une interaction Hold autrement non gérée se produit sur la zone de test de positionnement de cet élément. (Hérité de UIElement) |
9 | IsEnabledChanged Se produit lorsque la propriété IsEnabled change. (Hérité de Control) |
dix | KeyDown Se produit lorsqu'une touche du clavier est enfoncée alors que UIElement a le focus. (Hérité de UIElement) |
11 | KeyUp Se produit lorsqu'une touche du clavier est relâchée alors que UIElement a le focus. (Hérité de UIElement) |
12 | LostFocus Se produit lorsqu'un UIElement perd le focus. (Hérité de UIElement) |
13 | SizeChanged Se produit lorsque la propriété ActualHeight ou ActualWidth change de valeur sur un FrameworkElement. (Hérité de FrameworkElement) |
Sr. No. | Boutons et description |
---|---|
1 | HyperlienButton Le HyperlinkButton ne dessine pas l'arrière-plan du bouton standard. Au lieu de cela, il restitue simplement le contenu que vous fournissez. |
2 | ToggleButton et RepeatButton Le contrôle RepeatButton se déclenche sur les événements Click en continu, tant que le bouton est maintenu enfoncé. Le contrôle ToggleButton représente un bouton qui a deux états (cliqué ou non). |
3 | CheckBox Un contrôle qu'un utilisateur peut sélectionner (cocher) ou désélectionner (décocher). Il fournit une liste d'options qu'un utilisateur peut sélectionner, comme une liste de paramètres à appliquer à une application. |
4 | Bouton radio Le RadioButton est un bouton qui permet à un utilisateur de sélectionner une seule option dans un groupe d'options. |
Les boutons offrent une forme de contenu au contenu du modèle. Les modèles apparaissent souvent dans les contrôles. L'idée est simple. Il acceptera n'importe quel contenu et pas seulement du texte. Si vous souhaitez créer un bouton vraiment exotique, vous pouvez même placer d'autres contrôles de contenu tels que des zones de texte et des boutons à l'intérieur (et y imbriquer des éléments fixes). Il est peu probable qu'une telle interface ait beaucoup de sens, mais c'est possible.
Jetons un coup d'œil à un exemple simple avec bouton, bouton à l'intérieur d'autres contrôles de contenu.
<UserControl x:Class = "ContentModel.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">
<Button Margin = "3" Height = "70" Width = "215">
<Grid Margin = "5">
<Polygon Points = "100,25 125,0 200,25 125,50" Fill = "LightSteelBlue" />
<Polygon Points = "100,25 75,0 0,25 75,50" Fill = "LightGray"/>
</Grid>
</Button>
</Grid>
</UserControl>
Lorsque le code ci-dessus est compilé et exécuté, vous verrez le bouton suivant.
RangeControl
Les commandes de la barre de défilement et du curseur sont étroitement liées. Ils permettent tous deux à l'utilisateur de choisir une valeur d'entrée dans une plage particulière. Classiquement, ces contrôles signifient des choses différentes. Les barres de défilement sont normalement utilisées pour définir la position dans une zone scrotale, tandis que le curseur est utilisé pour spécifier une valeur ou un paramètre. Ce ne sont que des conventions; les contrôles ont des comportements et des API similaires.
Les commandes de plage sont simples à utiliser. Vous spécifiez les valeurs minimale et maximale pour indiquer la plage de valeurs que vous souhaitez que le curseur représente. leValue la propriété variera à mesure que l'utilisation des dragues varie.
L'héritage hiérarchique de Slider la classe est la suivante -
Ci-dessous sont les properties de Slider.
Sr. No. | Propriété et description |
---|---|
1 | Header Obtient ou définit le contenu de l'en-tête du contrôle. |
2 | HeaderProperty Identifie la propriété de dépendance Header. |
3 | HeaderTemplate Obtient ou définit le DataTemplate utilisé pour afficher le contenu de l'en-tête du contrôle. |
4 | HeaderTemplateProperty Identifie la propriété de dépendance HeaderTemplate. |
5 | IntermediateValue Obtient ou définit la valeur du Slider pendant que l'utilisateur interagit avec lui, avant que la valeur ne soit alignée sur la valeur de graduation ou de pas. La propriété SnapsTo spécifie la valeur du curseur. |
6 | IntermediateValueProperty Identifie la propriété de dépendance IntermediateValue. |
sept | IsDirectionReversed Obtient ou définit une valeur qui indique le sens de l'augmentation de la valeur. |
8 | IsDirectionReversedProperty Identifie la propriété de dépendance IsDirectionReversed. |
9 | IsThumbToolTipEnabled Obtient ou définit une valeur qui détermine si la valeur du curseur est affichée dans une info-bulle pour le composant Thumb du Slider. |
dix | IsThumbToolTipEnabledProperty Identifie la propriété de dépendance IsThumbToolTipEnabled. |
11 | Orientation Obtient ou définit l'orientation d'un Slider. |
12 | OrientationProperty Identifie la propriété de dépendance Orientation. |
13 | StepFrequency Obtient ou définit la partie valeur d'une plage de valeurs pour laquelle les étapes doivent être créées. |
14 | StepFrequencyProperty Identifie la propriété de dépendance StepFrequency. |
15 | ThumbToolTipValueConverter Obtient ou définit la logique du convertisseur qui convertit la valeur de plage du curseur en contenu d'info-bulle. |
16 | ThumbToolTipValueConverterProperty Identifie la propriété de dépendance ThumbToolTipValueConverter. |
17 | TickFrequency Obtient ou définit l'incrément de la plage de valeurs pour laquelle les graduations doivent être créées. |
18 | TickFrequencyProperty Identifie la propriété de dépendance TickFrequency. |
19 | TickPlacement Obtient ou définit une valeur qui indique où dessiner les graduations par rapport à la piste. |
20 | TickPlacementProperty Identifie la propriété de dépendance TickPlacement. |
Ci-dessous sont les events dans Slider classe.
Sr. No. | Description de l'évenement |
---|---|
1 | ManipulationCompleted Se produit lorsqu'une manipulation sur le UIElement est terminée. (Hérité de UIElement) |
2 | ManipulationDelta Se produit lorsque le périphérique d'entrée change de position pendant une manipulation. (Hérité de UIElement) |
3 | ManipulationInertiaStarting Se produit lorsque le périphérique d'entrée perd le contact avec l'objet UIElement lors d'une manipulation et que l'inertie commence. (Hérité de UIElement) |
4 | ManipulationStarted Se produit lorsqu'un périphérique d'entrée commence une manipulation sur le UIElement. (Hérité de UIElement) |
5 | ManipulationStarting Se produit lorsque le processeur de manipulation est créé pour la première fois. (Hérité de UIElement) |
6 | ValueChanged Se produit lorsque la valeur de la plage change. (Hérité de RangeBase) |
Ci-dessous sont les methods in Classe de curseur.
Sr. No. | Méthode et description |
---|---|
1 | OnManipulationCompleted Appelé avant que l'événement ManipulationCompleted ne se produise. (Hérité de Control) |
2 | OnManipulationDelta Appelé avant que l'événement ManipulationDelta ne se produise. (Hérité de Control) |
3 | OnManipulationInertiaStarting Appelé avant que l'événement ManipulationInertiaStarting ne se produise. (Hérité de Control) |
4 | OnManipulationStarted Appelé avant que l'événement ManipulationStarted ne se produise. (Hérité de Control) |
5 | OnManipulationStarting Appelé avant que l'événement ManipulationStarting ne se produise. (Hérité de Control) |
6 | OnMaximumChanged Appelé lorsque la propriété Maximum change. (Hérité de RangeBase) |
sept | OnMinimumChanged Appelé lorsque la propriété Minimum change. (Hérité de RangeBase) |
8 | OnValueChanged Déclenche l'événement routé ValueChanged. (Hérité de RangeBase) |
9 | SetBinding Attache une liaison à un FrameworkElement, à l'aide de l'objet de liaison fourni. (Hérité de FrameworkElement) |
dix | SetValue Définit la valeur locale d'une propriété de dépendance sur un DependencyObject. (Hérité de DependencyObject) |
Exemple
Jetons un coup d'œil à un exemple simple dans lequel un curseur et une ellipse sont ajoutés et le curseur contrôle la largeur de l'ellipse.
<UserControl x:Class = "SliderExample.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:DesignWidth = "640" d:DesignHeight = "480">
<Grid x:Name = "LayoutRoot">
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition />
</Grid.RowDefinitions>
<Slider Minimum = "1" Maximum = "400" Value = "1"
ValueChanged = "Slider_ValueChanged" />
<Ellipse Grid.Row = "1" Fill = "Aqua" Width = "1" x:Name = "myEllipse" />
</Grid>
</UserControl>
Ci-dessous est le value changed event l'implémentation est C #.
using System.Windows;
using System.Windows.Controls;
namespace SliderExample {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void Slider_ValueChanged(object sender,
RoutedPropertyChangedEventArgs<double> e) {
if (myEllipse != null) {
myEllipse.Width = e.NewValue;
}
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante. Comme vous pouvez le voir, lorsque vous déplacez le curseur de gauche à droite, la largeur de l'ellipse augmente.
Listbox est un contrôle qui fournit une liste d'éléments à l'utilisateur pour la sélection d'un élément. Un utilisateur peut sélectionner un ou plusieurs éléments à partir d'une liste d'éléments prédéfinis à la fois. Dans unListBox, plusieurs options sont toujours visibles par l'utilisateur sans aucune interaction de l'utilisateur.
Une liste déroulante présente une liste déroulante d'éléments. Si un utilisateur sélectionne un élément, l'élément sélectionné change d'apparence pour indiquer la sélection. Il prend en charge une forme plus étendue de modèle de contenu et de bouton. Une différence majeure entre un bouton et une zone de liste est qu'un bouton contient un seul élément de contenu, tandis qu'une zone de liste autorise chaque élément de la liste.
L'héritage hiérarchique de la classe ListBox est le suivant -
Ci-dessous sont les Properties de ListBox classe.
Sr. No. | Propriété et description |
---|---|
1 | Background Obtient ou définit un pinceau qui fournit l'arrière-plan du contrôle. (Hérité de Control) |
2 | BorderThickness Obtient ou définit l'épaisseur de la bordure d'un contrôle. (Hérité de Control) |
3 | FontFamily Obtient ou définit la police utilisée pour afficher le texte dans le contrôle. (Hérité de Control) |
4 | FontSize Obtient ou définit la taille du texte de ce contrôle. (Hérité de Control) |
5 | FontStyle Obtient ou définit le style dans lequel le texte est rendu. (Hérité de Control) |
6 | FontWeight Obtient ou définit l'épaisseur de la police spécifiée. (Hérité de Control) |
sept | Foreground Obtient ou définit un pinceau qui décrit la couleur de premier plan. (Hérité de Control) |
8 | GroupStyle Obtient une collection d'objets GroupStyle qui définissent l'apparence de chaque niveau de groupes. (Hérité de ItemsControl) |
9 | Height Obtient ou définit la hauteur suggérée d'un FrameworkElement. (Hérité de FrameworkElement) |
dix | HorizontalAlignment Obtient ou définit les caractéristiques d'alignement horizontal qui sont appliquées à un FrameworkElement lorsqu'il est composé dans un parent de disposition, tel qu'un panneau ou un contrôle d'éléments. (Hérité de FrameworkElement) |
11 | IsEnabled Obtient ou définit une valeur indiquant si l'utilisateur peut interagir avec le contrôle. (Hérité de Control) |
12 | Item Obtient la collection utilisée pour générer le contenu du contrôle. (Hérité de ItemsControl) |
13 | ItemsSource Obtient ou définit une source d'objet utilisée pour générer le contenu de ItemsControl. (Hérité de ItemsControl) |
14 | Margin Obtient ou définit la marge extérieure d'un FrameworkElement. (Hérité de FrameworkElement) |
15 | Name Obtient ou définit le nom d'identification de l'objet. Lorsqu'un processeur XAML crée l'arborescence d'objets à partir du balisage XAML, le code d'exécution peut faire référence à l'objet déclaré XAML par ce nom. (Hérité de FrameworkElement) |
16 | Opacity Obtient ou définit le degré d'opacité de l'objet. (Hérité de UIElement) |
17 | SelectedIndex Obtient ou définit l'index de l'élément sélectionné. (Hérité de Selector) |
18 | SelectedItem Obtient ou définit l'élément sélectionné. (Hérité de Selector) |
19 | SelectedValue Obtient ou définit la valeur de l'élément sélectionné, obtenue à l'aide de SelectedValuePath. (Hérité de Selector) |
20 | Style Obtient ou définit un Style d'occurrence qui est appliqué à cet objet pendant la disposition et le rendu. (Hérité de FrameworkElement) |
21 | VerticalAlignment Obtient ou définit les caractéristiques d'alignement vertical qui sont appliquées à un FrameworkElement lorsqu'il est composé dans un objet parent tel qu'un panneau ou un contrôle d'éléments. (Hérité de FrameworkElement) |
22 | Width Obtient ou définit la largeur d'un FrameworkElement. (Hérité de FrameworkElement) |
Ci-dessous sont les plus couramment utilisés Events de ListBox.
Sr. No. | Description de l'évenement |
---|---|
1 | DragEnter Se produit lorsque le système d'entrée signale un événement de glissement sous-jacent avec cet élément comme cible. (Hérité de UIElement) |
2 | DragLeave Se produit lorsque le système d'entrée signale un événement de glissement sous-jacent avec cet élément comme origine. (Hérité de UIElement) |
3 | DragOver Se produit lorsque le système d'entrée signale un événement de glissement sous-jacent avec cet élément comme cible de dépôt potentielle. (Hérité de UIElement) |
4 | DragStarting Se produit lorsqu'une opération de glissement est lancée. (Hérité de UIElement) |
5 | Drop Se produit lorsque le système d'entrée signale un événement de dépôt sous-jacent avec cet élément comme cible de dépôt. (Hérité de UIElement) |
6 | DropCompleted Se produit à la fin d'une opération de glisser-déposer. (Hérité de UIElement) |
sept | GotFocus Se produit lorsqu'un UIElement reçoit le focus. (Hérité de UIElement) |
8 | IsEnabledChanged Se produit lorsque la propriété IsEnabled change. (Hérité de Control) |
9 | KeyDown Se produit lorsqu'une touche du clavier est enfoncée alors que UIElement a le focus. (Hérité de UIElement) |
dix | KeyUp Se produit lorsqu'une touche du clavier est relâchée alors que UIElement a le focus. (Hérité de UIElement) |
11 | LostFocus Se produit lorsqu'un UIElement perd le focus. (Hérité de UIElement) |
12 | SelectionChanged Se produit lorsque l'élément actuellement sélectionné change. (Hérité de Selector) |
13 | SizeChanged Se produit lorsque la propriété ActualHeight ou ActualWidth change de valeur sur un FrameworkElement. (Hérité de FrameworkElement) |
Ci-dessous sont les plus couramment utilisés Methods de ListBox.
Sr. No. | Méthode et description |
---|---|
1 | Arrange Positionne les objets enfants et détermine une taille pour un UIElement. Les objets parents qui implémentent une disposition personnalisée pour leurs éléments enfants doivent appeler cette méthode à partir de leurs implémentations de remplacement de disposition pour former une mise à jour de disposition récursive. (Hérité de UIElement) |
2 | FindName Récupère un objet qui porte le nom d'identificateur spécifié. (Hérité de FrameworkElement) |
3 | Focus Tente de définir le focus sur le contrôle. (Hérité de Control) |
4 | GetValue Renvoie la valeur effective actuelle d'une propriété de dépendance à partir d'un DependencyObject. (Hérité de DependencyObject) |
5 | IndexFromContainer Renvoie l'index de l'élément contenant le conteneur généré spécifié. (Hérité de ItemsControl) |
6 | OnDragEnter Appelé avant l'événement DragEnter. (Hérité de Control) |
sept | OnDragLeave Appelé avant que l'événement DragLeave ne se produise. (Hérité de Control) |
8 | OnDragOver Appelé avant l'événement DragOver. (Hérité de Control) |
9 | OnDrop Appelé avant que l'événement Drop ne se produise. (Hérité de Control) |
dix | OnKeyDown Appelé avant l'événement KeyDown. (Hérité de Control) |
11 | OnKeyUp Appelé avant l'événement KeyUp. (Hérité de Control) |
12 | OnLostFocus Appelé avant que l'événement LostFocus ne se produise. (Hérité de Control) |
13 | ReadLocalValue Renvoie la valeur locale d'une propriété de dépendance, si une valeur locale est définie. (Hérité de DependencyObject) |
14 | SetBinding Attache une liaison à un FrameworkElement, à l'aide de l'objet de liaison fourni. (Hérité de FrameworkElement) |
15 | SetValue Définit la valeur locale d'une propriété de dépendance sur un DependencyObject. (Hérité de DependencyObject) |
Regardons un exemple simple dans lequel différents éléments d'interface utilisateur sont ajoutés dans un ListBox.
<UserControl x:Class = "ListBoxExample.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:DesignWidth = "640" d:DesignHeight = "480">
<Grid x:Name = "LayoutRoot">
<ListBox x:Name = "myList">
<TextBlock Text = "First item" />
<Button Content = "Second item" />
<Path Fill = "Blue" Data = "M4,0 l-4,10 8,0z M15,0 l-4,10 8,0z M26,0 l4,10 8,0z"
Margin = "10" />
<StackPanel Orientation = "Horizontal">
<Ellipse Fill = "Red" Height = "30" Width = "100" />
<TextBlock Text = "Name: " />
<TextBox Width = "200" />
</StackPanel>
<TextBlock Text = "More..." />
</ListBox>
</Grid>
</UserControl>
Vous trouverez ci-dessous l'implémentation C #.
using System.Windows.Controls;
namespace ListBoxExample {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
myList.Items.Add("String entry");
myList.Items.Add(new Button { Content = "Content entry" });
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez une zone de liste qui contient un mélange de texte graphique et également un champ modifiable où vous pouvez taper le texte.
Sr. No. | Commandes et description |
---|---|
1 | Calendrier et DatePicker Calendar & DatePicker représente un contrôle qui permet à un utilisateur de sélectionner une date à l'aide d'un affichage de calendrier visuel. Il fournit une navigation de base à l'aide de la souris ou du clavier. |
2 | TabControl Un conteneur qui place les éléments dans des onglets séparés et permet à l'utilisateur d'afficher un seul onglet à la fois. Il permet à l'utilisateur de choisir parmi un certain nombre de vues différentes en cliquant sur les en-têtes des onglets. |
3 | Apparaitre Cette classe affiche le contenu par-dessus le contenu existant, dans les limites de la fenêtre d'application. Il s'agit d'un affichage temporaire sur l'autre contenu. |
4 | Info-bulle L'info-bulle représente un contrôle qui crée une fenêtre contextuelle qui affiche des informations sur un élément dans l'interface graphique. Silverlight vous permet d'attacher une info-bulle à n'importe quel contrôle. |
UNE Templatedécrit l'aspect général et l'aspect visuel du contrôle. Pour chaque contrôle, un modèle par défaut lui est associé, ce qui donne l'apparence à ce contrôle.
Dans l'application WPF, vous pouvez facilement créer vos propres modèles lorsque vous souhaitez personnaliser le comportement visuel et l'apparence visuelle d'un contrôle.
Certaines caractéristiques importantes sont -
Tous les éléments de l'interface utilisateur ont une sorte d'apparence ainsi qu'un comportement, par exemple Button a une apparence et un comportement.
Click événement ou mouse hover événement sont les comportements, qui sont déclenchés en réponse à un clic et au survol et il y a une apparence par défaut du bouton, qui peut être modifiée par le Control modèle.
Regardons à nouveau un exemple simple dans lequel un bouton est défini avec un modèle.
<UserControl x:Class = "ButtonTemplate.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:DesignWidth = "640" d:DesignHeight = "480">
<Grid x:Name = "LayoutRoot" HorizontalAlignment = "Center"
VerticalAlignment = "Center">
<Button Height = "100" Width = "100" Content = "Click!"
HorizontalContentAlignment = "Left" Click = "button_Click">
<Button.Template>
<ControlTemplate TargetType = "Button">
<Grid>
<Ellipse Fill = "Gray" Stroke = "Black"
StrokeThickness = "3" Margin = "-64,0,0,0" />
<ContentPresenter HorizontalAlignment = "{TemplateBinding
HorizontalContentAlignment}" VerticalAlignment = "Center"
Content = "{TemplateBinding Content}" />
</Grid>
</ControlTemplate>
</Button.Template>
</Button>
</Grid>
</UserControl>
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Connexion du modèle
Toutes les fonctionnalités de contrôle que nous souhaitons modéliser sont associées à des liaisons de modèle. Certains aspects sont un peu plus complexes. Par exemple, chaque fois que vous avez une forme de modèle de contenu, la liaison de modèle seule ne suffit pas à ce que vous voyiez sur le bouton. Nous devons également utiliser un présentateur de contenu comme indiqué dans l'exemple ci-dessus.
Il est bon que votre utilisateur sache quel élément d'une application est susceptible de répondre à l'entrée. Dans une certaine mesure, cela peut être fait en faisant en sorte que les boutons ressemblent à des boutons. Si quelque chose semble cliquable, c'est probablement le cas.
Cependant, une convention dans la conception d'interface utilisateur moderne est qu'un élément d'interface utilisateur doit également signaler une volonté de répondre en changeant de parents lorsque la souris passe dessus.
Par exemple, le contrôle de bouton intégré modifie légèrement son arrière-plan, lorsque la souris se déplace, pour indiquer qu'il est interactif, puis modifie davantage les parents lorsque vous cliquez dessus pour le faire ressembler à sa sélection. Presque tous les contrôles doivent le faire et les concepteurs ont besoin d'un moyen de créer et de modifier les animations pour que cela se produise.
État et groupe d'État
Regardons un exemple d'état visuel en action. Considérez une case à cocher. Il peut être décoché ou coché et si vous le souhaitez, il peut prendre en charge un troisième état indéterminé. Le contrôle doit avoir une apparence différente pour les trois cas. Par conséquent, nous avons trois états visuels.
Afin de démontrer qu'il est prêt à répondre à l'entrée de l'utilisateur, la case à cocher change légèrement d'apparence lorsque la souris se déplace dessus et elle change davantage lorsque la souris y est maintenue. Un quatrième état doit être pris en compte si la case à cocher est désactivée, elle a fière allure et signale qu'elle ne répondra pas à l'entrée de l'utilisateur.
Donc, nous avons quatre autres états ici. A tout moment, l'état visuel d'une case à cocher doit être soitNormal, Mouse over, Checked ou Disabled. En même temps, il doit être soitchecked, unchecked ou indeterminate.
Gestionnaire d'état visuel
Étant donné que ses modèles définissent l'apparence des contrôles, le modèle doit définir ce qui arrive à chacun des états visuels. Les modèles que nous avons examinés jusqu'à présent ne contiennent pas de telles informations. Par conséquent, l'apparence des contrôles reste statique, quel que soit son état actuel.
Pour ajouter des états visuels à un modèle, vous commencez par ajouter un élément de propriété.
La chose la plus simple que vous puissiez faire pour la gestion de l'état visuel est de définir une animation qui s'exécutera lorsque le contrôle entrera dans un état particulier.
Les contrôles notifient la classe de gestionnaire d'état visuel chaque fois qu'ils changent d'état.
Le gestionnaire d'état visuel regarde ensuite dans cette section du modèle et détermine quelle animation exécuter.
Ainsi, lorsque la case à cocher entre dans la surestimation de la souris, cette animation s'exécute, changeant la couleur d'une partie d'un modèle.
Jetons un coup d'œil à un exemple simple en utilisant les mécanismes d'état visuel pour créer un modèle personnalisé pour une case à cocher qui reflète les changements d'état.
Vous trouverez ci-dessous le code XAML pour le modèle personnalisé de case à cocher avec visual state.
<UserControl
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
x:Class = "CheckboxVisualState.Page"
Width = "640" Height="480"
xmlns:vsm = "clrnamespace:System.Windows;assembly = System.Windows"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<UserControl.Resources>
<ControlTemplate x:Key = "CheckBoxControlTemplate1" TargetType = "CheckBox">
<Grid>
<vsm:VisualStateManager.VisualStateGroups>
<vsm:VisualStateGroup x:Name = "FocusStates">
<vsm:VisualState x:Name = "ContentFocused"/>
<vsm:VisualState x:Name = "Focused"/>
<vsm:VisualState x:Name = "Unfocused"/>
</vsm:VisualStateGroup>
<vsm:VisualStateGroup x:Name = "CommonStates">
<vsm:VisualStateGroup.Transitions>
<vsm:VisualTransition GeneratedDuration = "00:00:00.5000000"/>
</vsm:VisualStateGroup.Transitions>
<vsm:VisualState x:Name = "MouseOver">
<Storyboard>
<ColorAnimationUsingKeyFrames BeginTime = "00:00:00"
Duration = "00:00:00.0010000" Storyboard.TargetName = "background"
Storyboard.TargetProperty = "(Shape.Fill).
(SolidColorBrush.Color)">
<SplineColorKeyFrame KeyTime = "00:00:00" Value = "#FFFF0000"/>
</ColorAnimationUsingKeyFrames>
</Storyboard>
</vsm:VisualState>
<vsm:VisualState x:Name = "Pressed">
<Storyboard>
<ColorAnimationUsingKeyFrames BeginTime = "00:00:00"
Duration = "00:00:00.0010000" Storyboard.TargetName = "background"
Storyboard.TargetProperty = "(Shape.Fill).
(SolidColorBrush.Color)">
<SplineColorKeyFrame KeyTime = "00:00:00" Value = "#FFCEFF00"/>
</ColorAnimationUsingKeyFrames>
</Storyboard>
</vsm:VisualState>
<vsm:VisualState x:Name = "Disabled"/>
<vsm:VisualState x:Name = "Normal"/>
</vsm:VisualStateGroup>
<vsm:VisualStateGroup x:Name = "CheckStates">
<vsm:VisualStateGroup.Transitions>
<vsm:VisualTransition GeneratedDuration = "00:00:00.5000000"/>
</vsm:VisualStateGroup.Transitions>
<vsm:VisualState x:Name = "Checked">
<Storyboard>
<DoubleAnimationUsingKeyFrames BeginTime = "00:00:00"
Duration = "00:00:00.0010000" Storyboard.TargetName = "checkPath"
Storyboard.TargetProperty = "(UIElement.Opacity)">
<SplineDoubleKeyFrame KeyTime = "00:00:00" Value = "1"/>
</DoubleAnimationUsingKeyFrames>
</Storyboard>
</vsm:VisualState>
<vsm:VisualState x:Name = "Unchecked"/>
<vsm:VisualState x:Name = "Indeterminate"/>
</vsm:VisualStateGroup>
</vsm:VisualStateManager.VisualStateGroups>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto"/>
<ColumnDefinition Width = "3.61782296696066"/>
<ColumnDefinition Width = "Auto"/>
</Grid.ColumnDefinitions>
<Canvas Height = "50" HorizontalAlignment = "Left" VerticalAlignment = "Top"
Width = "50">
<Rectangle Height = "33.746" x:Name = "background" Width = "33.746"
Canvas.Left = "8.452" Canvas.Top = "7.88" Fill = "#FFFFFFFF"
Stroke = "#FF000000"
RadiusX = "5.507" RadiusY = "5.507"/>
<Path Height = "40.25" x:Name = "checkPath" Width = "39.75" Opacity = "0"
Canvas.Left = "5.959" Canvas.Top = "7.903" Stretch = "Fill"
Stroke = "#FF1F9300" StrokeThickness = "3"
Data = "M1.5,1.5 C15.495283,8.7014561 27.056604,18.720875 33.75,33.75
M36,3.75 C22.004717,10.951456 10.443395,20.970875 3.7499986,36"/>
</Canvas>
<ContentPresenter HorizontalAlignment = "Left"
Margin = "{TemplateBinding Padding}"
VerticalAlignment = "{TemplateBinding VerticalContentAlignment}"
Grid.Column = "2" Grid.ColumnSpan = "1" d:LayoutOverrides = "Height"/>
</Grid>
</ControlTemplate>
</UserControl.Resources>
<Grid x:Name = "LayoutRoot" Background = "White" >
<CheckBox HorizontalAlignment = "Left"
Margin = "52.5410003662109,53.5970001220703,0,0" VerticalAlignment = "Top"
Template = "{StaticResource CheckBoxControlTemplate1}"
Content = "CheckBox"/>
</Grid>
</UserControl>
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la page Web suivante, qui en contient une checkbox.
Lorsque le curseur entre dans la zone de case à cocher, il change d'état.
Lorsque vous cliquez sur le checkbox, vous verrez l'état suivant.
Nous vous recommandons d'exécuter l'exemple ci-dessus pour une meilleure compréhension.
La liaison de données est un mécanisme dans l'application Silverlight, qui fournit un moyen simple et facile aux applications Windows Runtime d'utiliser des classes partielles pour afficher et interagir avec les données. La gestion des données est entièrement séparée de la manière dont les données sont affichées dans ce mécanisme. La liaison de données permet le flux de données entre les éléments de l'interface utilisateur et l'objet de données sur l'interface utilisateur. Lorsqu'une liaison est établie et que les données ou votre modèle d'entreprise changent, elle reflètera automatiquement les mises à jour des éléments de l'interface utilisateur et vice versa. Il est également possible de se lier, non pas à une source de données standard, mais plutôt à un autre élément de la page.
La liaison de données est des deux types suivants -
- Liaison de données unidirectionnelle
- Liaison de données bidirectionnelle
Liaison de données unidirectionnelle
Dans la liaison de données unidirectionnelle, les données sont liées de leur source (c'est-à-dire l'objet qui contient les données) à sa cible (c'est-à-dire l'objet qui affiche les données).
Jetons un coup d'œil à un exemple simple de liaison de données unidirectionnelle.
Vous trouverez ci-dessous le code XAML dans lequel deux étiquettes, deux zones de texte et un bouton sont créés avec certaines propriétés.
<UserControl x:Class = "DataBinding.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.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "Auto" />
<RowDefinition Height = "*" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto" />
<ColumnDefinition Width = "200" />
</Grid.ColumnDefinitions>
<TextBlock Name = "nameLabel" Margin = "2">Name:</TextBlock>
<TextBox Name = "nameText" Grid.Column = "1" Margin = "2"
Text = "{Binding Name, Mode=OneWay}"/>
<TextBlock Name = "ageLabel" Margin = "2" Grid.Row = "1">Age:</TextBlock>
<TextBox Name = "ageText" Grid.Column = "1" Grid.Row = "1" Margin="2"
Text = "{Binding Age, Mode = OneWay}"/>
<StackPanel Grid.Row = "2" Grid.ColumnSpan = "2">
<Button Content = "_Show..." Click = "Button_Click" />
</StackPanel>
</Grid>
</UserControl>
Nous observons les choses suivantes -
Les propriétés de texte des deux zones de texte sont liées à "Name" et "Age», Qui sont des variables de classe de Person classe comme indiqué ci-dessous.
Dans Person classe, nous n'avons que deux variables Name et Age, et son objet est initialisé dans MainPage classe.
Dans le code XAML, nous nous lions à une propriété Name et Age, mais nous n'avons pas sélectionné la propriété appartenant à l'objet.
Un moyen simple consiste à affecter un objet à DataContext dont nous lions les propriétés dans le code C # de MainPage constructeur comme indiqué ci-dessous.
using System.Windows;
using System.Windows.Controls;
namespace DataBinding {
public partial class MainPage : UserControl {
Person person = new Person { Name = "Salman", Age = 26 };
public MainPage() {
InitializeComponent();
this.DataContext = person;
}
private void Button_Click(object sender, RoutedEventArgs e) {
string message = person.Name + " is " + person.Age;
MessageBox.Show(message);
}
}
public class Person {
private string nameValue;
public string Name {
get { return nameValue; }
set { nameValue = value; }
}
private double ageValue;
public double Age {
get { return ageValue; }
set {
if (value != ageValue) {
ageValue = value;
}
}
}
}
}
Laissez-nous exécuter cette application et vous pouvez voir immédiatement sur votre page Web que nous avons lié avec succès le nom et l'âge de cet objet Personne.
Lorsque vous appuyez sur le Show bouton, il affichera le nom et l'âge dans la boîte de message.
Changeons le Name et Age dans la boîte de dialogue ci-dessus.
Maintenant, si vous cliquez sur le Show bouton, il affichera à nouveau le même message.
C'est parce que le data-bindingmode est défini sur oneeway dans le code XAML. Pour afficher le message mis à jour, vous devez comprendre la liaison de données bidirectionnelle.
Liaison de données bidirectionnelle
Dans two-way binding, l'utilisateur peut modifier les données via l'interface utilisateur et mettre ces données à jour dans la source. Si la source change pendant que l'utilisateur regarde la vue, vous voulez que la vue soit mise à jour.
Jetons un coup d'œil au même exemple, mais changeons uniquement le mode de liaison de liaison unidirectionnelle à bidirectionnelle dans le code XAML comme indiqué ci-dessous.
<UserControl x:Class = "DataBinding.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.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "Auto" />
<RowDefinition Height = "*" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto" />
<ColumnDefinition Width = "200" />
</Grid.ColumnDefinitions>
<TextBlock Name = "nameLabel" Margin = "2">_Name:</TextBlock>
<TextBox Name = "nameText" Grid.Column = "1" Margin = "2"
Text = "{Binding Name, Mode=TwoWay}"/>
<TextBlock Name = "ageLabel" Margin = "2" Grid.Row = "1">_Age:</TextBlock>
<TextBox Name = "ageText" Grid.Column = "1" Grid.Row = "1" Margin = "2"
Text = "{Binding Age, Mode = TwoWay}"/>
<StackPanel Grid.Row = "2" Grid.ColumnSpan = "2">
<Button Content = "_Show..." Click = "Button_Click" />
</StackPanel>
</Grid>
</UserControl>
Laissez-nous exécuter à nouveau cette application et vous pouvez voir le même résultat.
Changeons le Name et Age dans la boîte de dialogue ci-dessus.
Maintenant, si vous cliquez sur le Show il affichera le message mis à jour.
Dans ce chapitre, nous allons voir comment une application Silverlight peut fonctionner en conjonction avec une page Web en utilisant le support d'intégration de navigateur.
Nous pouvons explorer l'intégration de Silverlight avec le navigateur de deux manières:
Le code JavaScript exécuté dans le navigateur peut accéder aux fonctionnalités de votre application Silverlight.
Silverlight a la capacité de fournir des wrappers JavaScript pour les objets. Votre.NET le code exécuté dans le plug-in Silverlight a accès au DOM HTML et à d'autres fonctionnalités de script du navigateur grâce à Silverlight .NET wrappers pour les objets JavaScript.
Nous verrons comment une application logicielle basée sur un navigateur peut stocker des informations de manière permanente sur le client.
Silverlight et HTML
En ce qui concerne le monde du HTML, le contenu Silverlight n'est qu'un élément unique. Cela est vrai pour la mise en page. L'ensemble du plug-in Silverlight et tout son contenu ne ressemblent qu'à un seul élément objet.
Vous devez garder à l'esprit que -
Silverlight ne remplaçait pas le HTML, il a été conçu pour le compléter. Par conséquent, la possibilité d'accéder à un autre élément du DOM est importante.
Il vous permet d'utiliser Silverlight le cas échéant.
Sur une page qui utilise principalement du HTML, l'intégration de Silverlight avec le monde du navigateur va au-delà du simple fait d'exister en tant qu'élément DOM, sous réserve d'une mise en page HTML normale.
Accéder au DOM
Le contenu Silverlight doit pouvoir participer pleinement à une page Web. Par conséquent, il devrait pouvoir accéder au DOM HTML. Silverlight fournit les objets de pont qui enveloppent les objets de script de navigateur en tant qu'objets Dot Net, leScript objectclasse dans le système. L'espace de noms du navigateur fournit des méthodes qui vous permettent de lire et d'écrire des propriétés et de consacrer des fonctions à l'objet de script du navigateur.
Vous avez besoin d'un moyen de mettre la main sur un objet Script en premier lieu. Silverlight fournit une classe de page HTML qui vous donne accès à diverses pages des fonctionnalités telles que les objets Script.
Jetons un coup d'œil à un exemple simple dans lequel nous avons un script simple qui crée un objet avec quelques attributs. Certains d'entre eux ne sont que des valeurs et quelques-uns sont des fonctions.
<script type = "text/javascript">
myJsObject = {
answer: 42,
message: "Hello, world",
modifyHeading: function(title)
{ document.getElementById('heading').innerHTML = title; },
performReallyComplexCalculation: function(x, y) { return x + y; }
};
</script>
Ci-dessous, le code XAML dans lequel un bouton est ajouté.
<UserControl x:Class = "DomAccess.Page"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Width = "400" Height = "300">
<Grid x:Name = "LayoutRoot" Background = "White">
<Button x:Name = "useDomButton" Content = "Use DOM" Width = "75" Height = "30"
Click = "useDomButton_Click" />
</Grid>
</UserControl>
Voici l'implémentation du clic de bouton dans laquelle un script est appelé qui est créé dans un fichier HTML.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;
using System.Windows.Browser;
using System.Diagnostics;
namespace DomAccess {
public partial class Page : UserControl {
public Page() {
InitializeComponent();
}
private void useDomButton_Click(object sender, RoutedEventArgs e) {
ScriptObject myJsObject = HtmlPage.Window.GetProperty("myJsObject") as ScriptObject;
string[] propertyNames = { "answer", "message", "modifyHeading",
"performReallyComplexCalculation" };
foreach (string propertyName in propertyNames) {
object value = myJsObject.GetProperty(propertyName);
Debug.WriteLine("{0}: {1} ({2})", propertyName, value, value.GetType());
}
object result = myJsObject.Invoke("performReallyComplexCalculation", 11, 31);
HtmlElement h1 = HtmlPage.Document.GetElementById("heading");
h1.SetProperty("innerHTML", "Text from C# (without JavaScript's help)");
h1.SetStyleAttribute("height", "200px");
}
}
}
Vous trouverez ci-dessous le fichier HTML complet.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "
http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml" >
<!-- saved from url = (0014)about:internet -->
<head>
<title>DomAccess</title>
<script type = "text/javascript">
myJsObject = {
answer: 42,
message: "Hello, world",
modifyHeading: function(title) {
document.getElementById('heading').innerHTML = title; },
performReallyComplexCalculation: function(x, y) { return x + y; }
};
</script>
<style type = "text/css">
html, body {
height: 100%;
overflow: auto;
}
body {
padding: 0;
margin: 0;
}
#silverlightControlHost {
height: 100%;
}
</style>
<script type = "text/javascript" src = "Silverlight.js"></script>
<script type = "text/javascript">
function onSilverlightError(sender, args) {
var appSource = "";
if (sender != null && sender != 0) {
appSource = sender.getHost().Source;
}
var errorType = args.ErrorType;
var iErrorCode = args.ErrorCode;
var errMsg = "Unhandled Error in Silverlight 2 Application " +
appSource + "\n" ;
errMsg += "Code: "+ iErrorCode + " \n";
errMsg += "Category: " + errorType + " \n";
errMsg += "Message: " + args.ErrorMessage + " \n";
if (errorType == "ParserError") {
errMsg += "File: " + args.xamlFile + " \n";
errMsg += "Line: " + args.lineNumber + " \n";
errMsg += "Position: " + args.charPosition + " \n";
} else if (errorType == "RuntimeError") {
if (args.lineNumber != 0) {
errMsg += "Line: " + args.lineNumber + " \n";
errMsg += "Position: " + args.charPosition + " \n";
}
errMsg += "MethodName: " + args.methodName + " \n";
}
throw new Error(errMsg);
}
</script>
</head>
<body>
<!-- Runtime errors from Silverlight will be displayed here.
This will contain debugging information and should be removed or hidden when
debugging is completed -->
<div id = 'errorLocation' style = "font-size: small;color: Gray;"></div>
<h1 id = 'heading'></h1>
<div id = "silverlightControlHost">
<object data = "data:application/x-silverlight-2,"
type = "application/x-silverlight-2" width = "100%" height = "100%">
<param name = "source" value = "ClientBin/DomAccess.xap"/>
<param name = "onerror" value = "onSilverlightError" />
<param name = "background" value = "white" />
<param name = "minRuntimeVersion" value = "2.0.30923.0" />
<param name = "autoUpgrade" value = "true" />
<a href = "http://go.microsoft.com/fwlink/?LinkID=124807"
style = "text-decoration: none;">
<img src = "http://go.microsoft.com/fwlink/?LinkId=108181"
alt = "Get Microsoft Silverlight" style = "border-style: none"/>
</a>
</object>
<iframe style = 'visibility:hidden;height:0;width:0;border:0px'></iframe>
</div>
</body>
</html>
Lorsque le code ci-dessus est compilé et exécuté, vous verrez toutes les valeurs dans la fenêtre de sortie, qui sont extraites du fichier HTML.
Nous allons maintenant explorer la prise en charge de Silverlight pour les applications qui peuvent être installées sur la machine de l'utilisateur final pour s'exécuter en dehors du navigateur Web comme une application Windows normale. Il y a trois raisons principales pour lesquelles vous voudrez peut-être que votre application puisse s'exécuter hors du navigateur -
- Interaction
- Offline
- Confiance élevée
Interaction
Cela peut permettre une meilleure conception d'interaction. Un modèle de navigation du Web ne convient pas particulièrement à certaines applications. Par exemple, la barre d'adresse et le bouton Retour peuvent être une perte d'espace et inutile.
L'importance de Silverlight est donnée ci-dessous -
Les applications Web peuvent utiliser des technologies côté client, telles que Silverlight, Flash ou AJAX pour fournir des mises à jour continues sur une seule page, supprimant peut-être tout besoin de naviguer vers d'autres pages.
Dans certaines applications, un utilisateur peut passer de nombreuses minutes, voire des heures, sur ce que le navigateur considère comme une seule page.
Pour ce type d'application, le Back Le bouton peut finir par avoir un effet assez surprenant de quitter l'application car il vous redirigera vers la page sur laquelle vous étiez avant d'entrer dans l'application.
De manière distincte, les applications non Web sont généralement mieux servies en manquant du navigateur, car cela élimine le navigateur Chrome. En général, la convivialité n'est pas la seule raison de manquer de navigateur.
Hors ligne
Une autre raison d'utiliser cette fonctionnalité est d'activer l'exécution hors ligne. Lorsqu'une application Silverlight est installée pour une opération hors navigateur, elle est copiée dans un référentiel par utilisateur sur la machine locale et devient disponible via les mécanismes habituels du système d'exploitation pour lancer des applications, comme le menu Démarrer de Windows, par exemple.
L'application sera alors disponible même si l'utilisateur ne dispose pas de connexion Internet.
De toute évidence, cela n'est utile que pour les applications qui ne dépendent pas entièrement des informations côté serveur.
Par exemple, une application de suivi automatique pour un service de livraison de colis ne serait pas d'une grande utilité sans la connectivité réseau.
Pour certaines applications, la possibilité de continuer à travailler lors de pannes de connectivité occasionnelles est très utile.
Confiance élevée
La version 4 de Silverlight a ajouté la prise en charge des applications de confiance. Le sandbox de sécurité de Silverlight bloque normalement certaines opérations privilégiées, telles que l'accès aux fichiers de l'utilisateur.
Cependant, une application hors navigateur peut demander une élévation. Si l'utilisateur accepte cette demande, l'application est en mesure de faire plus du type de travail que n'importe quelle application Windows normale pourra faire, comme l'utilisation de COM Automation ou la personnalisation de la bordure de la fenêtre.
Les applications qui s'exécutent à l'intérieur du navigateur ne sont jamais fiables, vous devez donc écrire une application hors navigateur si vous souhaitez utiliser ces fonctionnalités.
Activer OOB
Comment écrire une application hors navigateur? C'est très facile. Nous devons modifier un paramètre unique dans les propriétés du projet de Silverlight et cela ajoute simplement un paramètre approprié à laAppManifest.xaml.
Voyons comment cela fonctionne.
Lorsque votre manifeste indique que l'exécution hors navigateur est prise en charge, cela n'a aucun effet initial. L'application s'exécutera dans le navigateur comme d'habitude.
Cependant, si l'utilisateur clique avec le bouton droit de la souris, le Silverlight standard ContextMenu propose un élément supplémentaire pour installer l'application sur l'ordinateur.
Si l'utilisateur sélectionne cet élément, une boîte de dialogue apparaît demandant une confirmation. Il demande également si l'application doit être accessible à partir du menu Démarrer, du bureau ou des deux.
Vous n'avez pas besoin de vous fier au menu contextuel. Vous pouvez également proposer un bouton sur lequel l'utilisateur peut cliquer pour installer l'application, car il existe une API que vous pouvez appeler pour lancer l'installation.
Lorsque vous lancez l'installation par programme, l'utilisateur voit toujours la boîte de dialogue. Vous ne pouvez pas installer votre application sans le consentement de l'utilisateur.
Une application Silverlight
Voici une application Silverlight très simple. Ci-dessous, son code XAML.
<UserControl x:Class = "SimpleOob.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">
<Border BorderBrush = "Blue" BorderThickness = "4" CornerRadius = "20" >
<Border.Background>
<LinearGradientBrush StartPoint = "0,0" EndPoint = "0,1">
<GradientStop Offset = "0.0" Color = "White" />
<GradientStop Offset = "0.15" Color = "#cef" />
<GradientStop Offset = "1.0" Color = "White" />
</LinearGradientBrush>
</Border.Background>
<TextBlock HorizontalAlignment = "Center" VerticalAlignment = "Center"
Text = "Silverlight Application" TextOptions.TextHintingMode = "Animated"
TextAlignment = "Center" TextWrapping = "Wrap"
FontSize = "72" FontFamily = "Trebuchet MS" >
<TextBlock.Effect>
<DropShadowEffect Color = "#888" />
</TextBlock.Effect>
</TextBlock>
</Border>
</Grid>
</UserControl>
Step 1 - Pour activer l'exécution hors navigateur, accédez à la page du projet Properties, puis cliquez sur l'onglet Silverlight. Tout ce que nous devons faire est de vérifierEnable running application out of the browser case à cocher.
Si vous exécutez cette application, vous remarquerez que vous n'obtiendrez pas du tout de navigateur Web.
En fait, Visual Studio a pris une décision en votre nom. Lorsque vous avez activéout-of-browser exécution, il a injustement modifié vos paramètres de débogage.
Step 2 - Alors, ici dans le Solution Explorer, notez que le projet Silverlight est maintenant en gras, indiquant qu'il s'agit d'un projet de démarrage.
Ce n'était pas le cas avant. C'était le projet Web. Pour le moment, nous ne voulons pas de cela, car nous voulons montrer comment cette case à cocher change les choses pour l'utilisateur final.
Step 3 - Nous redéfinirons le projet Web en tant que projet de démarrage.
Step 4 - Exécutez à nouveau l'application et vous verrez que l'application est de retour dans le navigateur maintenant.
Step 5- Cliquez avec le bouton droit sur la page Web. Vous remarquerez l'entrée Silverlight habituelle dans le menu contextuel et un élément supplémentaire à installer.
Step 6 - Lorsque vous sélectionnez la deuxième option, la boîte de dialogue Installer l'application apparaît comme indiqué ci-dessous.
Notez qu'il affiche l'URL racine du site Web d'où provient l'application. Nous utilisons le serveur Web de débogage local fourni par Visual Studio, c'est pourquoi il indique localhost.
Step 7 - Cliquez OKet l'application s'exécute dans sa propre fenêtre distincte du navigateur.
Il peut être naturel de penser que cette fenêtre est en quelque sorte la propriété ou connectée au navigateur, mais ce n'est pas le cas. Vous pouvez fermer le navigateur et cette fenêtre reste active. Plus important encore, vous pouvez fermer cette fenêtre, puis réexécuter l'application sans utiliser le navigateur du tout.
Step 8 - Si vous ouvrez le Search boîte de dialogue dans le Start et commencez à taper le nom de l'application, il apparaît comme n'importe quelle application Windows normale.
Step 9 - Vous pouvez l'exécuter sans que le navigateur ne soit visible.
Pour désinstaller l'application
Le menu contextuel par défaut de l'application offre un moyen simple de le faire. Un utilisateur peut raisonnablement s'attendre à le désinstaller de la même manière qu'il le ferait pour toute autre application.
Vous pouvez également supprimer en cliquant avec le bouton droit sur la page Web et en sélectionnant Remove this application….
Paramètres OOB
Bien que nous n'ayons dû modifier qu'un seul paramètre pour activer le fonctionnement hors navigateur, en pratique, vous voudrez normalement faire un peu plus que cela. leAppManifest.xaml le fichier peut contenir plusieurs paramètres liés à out-of-browser opération, que nous configurons généralement via Visual Studio.
Comme vous l'avez peut-être remarqué, lorsque vous avez coché la case pour activer running out-ofbrowser, Visual Studio a activé un bouton intitulé Out-of-Browser Settings.
Jetons-y un coup d'œil en cliquant sur le bouton. Il produira la boîte de dialogue suivante.
La première chose que nous pouvons configurer est le texte qui apparaît comme Window Title.
Nous avons également la possibilité de corriger les dimensions et les emplacements des fenêtres, mais nous les laisserons automatiquement pour le moment.
Ce nom de raccourci apparaît dans le Start et le lien Bureau de l'application une fois qu'elle est installée.
C'est également le texte qui apparaît dans le menu contextuel et la boîte de dialogue d'installation de l'application.
Cette description de l'application apparaît dans l'info-bulle lorsque je survole les raccourcis.
Nous arrivons à fournir des icônes de différentes tailles. Ceux-ci doivent être intégrés à votre projet.
Dans ce chapitre, nous allons examiner les problèmes courants liés à la création et au déploiement d'applications et des ressources dont elles ont besoin.
Chargement du plug-in
La configuration minimale requise pour exécuter une application Silverlight est l'hébergement d'une page Web contenant une balise d'objet pour charger le plug-in Silverlight et le contenu Silverlight compilé lui-même.
Comme vous l'avez vu, nous avons utilisé param balises dans le object balise pour pointer vers le contenu.
HTML <Object> tag
Il existe d'autres paramètres que nous pouvons transmettre pour contrôler des fonctionnalités telles que l'interface utilisateur à afficher lors du téléchargement du contenu, le code JavaScript à exécuter en cas d'erreur et le contenu de secours à afficher si Silverlight n'est pas installé.
<Objet> en HTML
Voici un exemple de balise d'objet qui charge du contenu Silverlight. Vous avez déjà vu cela, mais nous allons examiner quelques choses un peu plus en détail, en commençant par les attributs de la balise objet elle-même.
Attribut de type
L'attribut type contient un type MIME l'identifiant comme un élément Silverlight. C'est ainsi que le navigateur sait quel type de contenu intégré nous utilisons. La balise d'objet est étonnamment flexible. Ce n'est pas seulement pour les plug-ins. Vous pouvez l'utiliser pour héberger des images intégrées, ou HTML, ainsi que du contenu basé sur des plug-ins, tel que Silverlight ou Flash.
Si le plug-in Silverlight est installé, cela le chargera. Sinon, le comportement de format standard est que le navigateur affiche tout contenu HTML à l'intérieur de la balise d'objet comme si les balises d'objet et de paramètres n'étaient pas là.
<object data = "data:application/x-silverlight-2," type = "application/x-silverlight-2"
width = "100%" height = "100%">
<param name = "source" value = "ClientBin/DataBinding.xap"/>
<param name = "onError" value = "onSilverlightError" />
<param name = "background" value = "white" />
<param name = "minRuntimeVersion" value = "5.0.61118.0" />
<param name = "autoUpgrade" value = "true" />
<a href = "http://go.microsoft.com/fwlink/?LinkID=149156&v=5.0.61118.0"
style = "textdecoration:none">
<img src = "http://go.microsoft.com/fwlink/?LinkId=161376"
alt = "Get Microsoft Silverlight" style = "border-style:none"/>
</a>
</object>
Attribut de données
L'attribut suivant, les données, est un peu moins évident. La virgule à la fin est censée être là. Certaines caractéristiques importantes sont -
Cet attribut n'est pas techniquement nécessaire, mais Microsoft vous recommande de l'ajouter car certains navigateurs Web ont un comportement assez surprenant lors du chargement des plugins.
le object tag est conçu pour héberger du contenu intégré, donc les navigateurs s'attendent à ce qu'une chaîne binaire soit impliquée, un fichier bitmap, ou une vidéo, ou un flux audio, ou quelque chose.
Vous vous attendez normalement à mettre une URL dans l'attribut data, et le navigateur à télécharger ces données et à les transmettre au plug-in.
L'attribut data prend un URI, et généralement il sera pointé vers certaines données, comme un fichier JPEG, mais ici, nous utilisons un schéma d'URI légèrement inhabituel.
Balises <param>
Nous avons divers param balises à l'intérieur de l'objet, en commençant par la source param.
<param name = "source" value = "ClientBin/DataBinding.xap"/>
Il donne le plug-in d'où télécharger le contenu Silverlight.
Vous devez fournir un gestionnaire d'erreurs JavaScript. Cela sera appelé si le processus de téléchargement échoue. Il sera également appelé si une exception non gérée est levée, une fois que le code Silverlight est opérationnel.
<param name = "onError" value = "onSilverlightError" />
Ce n'est donc pas seulement pour les échecs de charge. Vous devez également spécifier la version minimale de Silverlight requise par votre code.
Microsoft encourage les utilisateurs à se tenir à jour, donc une fois qu'une machine a installé le plug-in Silverlight, de nouvelles versions seront proposées via la mise à jour Windows, mais il est toujours possible qu'un utilisateur exécute une version plus ancienne que celle dont vous avez besoin. .
<param name = "minRuntimeVersion" value = "5.0.61118.0" />
<param name = "autoUpgrade" value = "true" />
Ce minRuntimeVersionLe paramètre vous permet de dire de quelle version vous avez besoin. Si la version installée est plus ancienne, le gestionnaire onError sera appelé.
Silverlight transmet les codes d'erreur numériques à la fonction JavaScript de gestion des erreurs, et il existe un code d'erreur distinct, '8001'comme cela se produit, pour indiquer que le plug-in est obsolète.
Vous pouvez écrire du code JavaScript pour répondre au problème, ou vous pouvez simplement demander au plug-in d'essayer de mettre à niveau pour vous.
Ici le autoUpgrade le paramètre est défini sur 'True', ce qui signifie que si le plugin installé est obsolète, Silverlight affichera automatiquement un message indiquant à l'utilisateur qu'une version plus récente est nécessaire, lui proposant de l'installer pour eux.
Contenu HTML de remplacement
Après les balises param, vient le fallback HTML content à utiliser si Silverlight n'est pas installé.
Le comportement standard du navigateur pour les balises d'objet dont MIMEle type est inconnu, c'est agir comme si l'objet et les balises param n'étaient pas du tout là. Donc, cette balise et son contenu seront affichés dans les systèmes qui n'ont pas le plug-in Silverlight.
<a href = "http://go.microsoft.com/fwlink/?LinkID=149156&v=5.0.61118.0"
style = "text-decoration:none">
<img src = "http://go.microsoft.com/fwlink/?LinkId=161376"
alt = "Get Microsoft Silverlight" style = "border-style:none"/>
</a>
Notez les deux URL vers le go.microsoft.com site, un lien hypertexte et une image.
Le lien d'image se résout en une image bitmap avec une certaine marque Silverlight et un texte proposant d'installer Silverlight. Le point de terminaison du lien hypertexte est modérément intelligent. Le serveur inspecte l'agent utilisateur pour décider où rediriger.
Il peut renvoyer l'exécutable d'installation de Silverlight, ou si l'utilisateur se trouve sur une plate-forme non prise en charge, il dirigera le navigateur vers une page contenant des informations sur Silverlight.
Silverlight.js
Il existe une alternative à la balise d'objet HTML pour charger le contenu Silverlight. Microsoft fournit un fichier JavaScript appeléSilverlight.js qui permet de gérer le processus de chargement à partir du script du navigateur.
Visual Studio ajoute une copie lorsque vous créez un projet Web pour héberger un projet Silverlight nouvellement créé. Le SDK Silverlight contient également une copie de ce fichier.
Le principal avantage de Silverlight.js est qu'il permet plus de flexibilité lorsque Silverlight n'est pas installé.
Ressources XAML
Silverlight propose également un mécanisme de création object resourcesen XAML. Il existe certains types d'objets généralement corrigés via XAML que vous souhaiterez peut-être pouvoir utiliser à plusieurs endroits dans votre application. Il est très courant de vouloir utiliser des modèles à plusieurs endroits.
Si vous avez défini une apparence personnalisée pour un bouton, vous souhaiterez peut-être l'appliquer à plusieurs boutons, voire à tous les boutons de votre application. Le système de ressources XAML fournit un moyen de le faire. Vous pouvez définir unnamed resource, puis utilisez-le ailleurs dans le XAML.
Outre les modèles, il est également courant de vouloir le faire pour les ressources graphiques, telles que les pinceaux et les formes. Si vous utilisez un jeu de couleurs particulier dans votre application, vous pouvez définir les couleurs et les pinceaux de ce jeu en tant que ressources.
Voici une application simple pour le SolidColorBrush Ressource.
<UserControl x:Class = "XAMLResources.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">
<UserControl.Resources>
<SolidColorBrush x:Key = "brushResource" Color = "AliceBlue" />
</UserControl.Resources>
<Grid x:Name = "LayoutRoot" Background = "White">
<StackPanel>
<Rectangle Height = "50" Margin = "20" Fill = "{StaticResource brushResource}" />
<Rectangle Height = "50" Margin = "20" Fill = "{StaticResource brushResource}"/>
</StackPanel>
</Grid>
</UserControl>
Dans le code XAML ci-dessus, vous pouvez voir que les deux rectangles ont StaticResource La couleur de brushResource est AliceBlue.
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
App.xaml
Toutes les applications Silverlight ont un fichier appelé App.xaml. Il contient des informations à l'échelle de l'application. Par exemple, il a une propriété Resources comme le font les éléments de l'interface utilisateur.
Les ressources que vous définissez dans le App.xamlsont disponibles dans tous les fichiers XAML du projet. Alors plutôt que d'encombrer monMainPage.xaml avec ces types de ressources, nous pouvons les déplacer vers le champ d'application.
<Application
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
x:Class = "XAMLResources.App" >
<Application.Resources>
<SolidColorBrush x:Key = "brushResource" Color = "AliceBlue" />
</Application.Resources>
</Application>
Classe d'application
Comme la plupart des fichiers XAML, le App.xaml fichier et son correspondant code behindfichier définir une classe. Cette classe Application est le point d'entrée de l'application Silverlight. leApp.xamltraite généralement des ressources de portée d'application; son code derrière le fichier contient le code de gestion de démarrage et d'arrêt.
Peu de temps après avoir créé une instance de votre classe Application, Silverlight lève son Application.Startup un événement.
Ici, nous créons l'interface utilisateur. Nous devons créer un élément d'interface utilisateur et l'attribuer à la propriété RootVisual des objets d'application dans leStartup et qui deviendra l'interface utilisateur affichée par le plug-in Silverlight.
public partial class App : Application {
public App() {
this.Startup += this.Application_Startup;
this.Exit += this.Application_Exit;
this.UnhandledException += this.Application_UnhandledException;
InitializeComponent();
}
private void Application_Startup(object sender, StartupEventArgs e) {
this.RootVisual = new MainPage();
}
private void Application_Exit(object sender, EventArgs e) {}
private void Application_UnhandledException(object sender,
ApplicationUnhandledExceptionEventArgs e) {
if (!System.Diagnostics.Debugger.IsAttached) {
e.Handled = true;
Deployment.Current.Dispatcher.BeginInvoke(delegate { ReportErrorToDOM(e); });
}
}
private void ReportErrorToDOM(ApplicationUnhandledExceptionEventArgs e) {
try {
string errorMsg = e.ExceptionObject.Message + e.ExceptionObject.StackTrace;
errorMsg = errorMsg.Replace('"', '\'').Replace("\r\n", @"\n");
System.Windows.Browser.HtmlPage.Window.Eval("throw new Error
(\"Unhandled Error in Silverlight Application " + errorMsg + "\");");
} catch (Exception) {}
}
}
Points à noter
Notez que vous ne pouvez pas modifier le RootVisual. Vous devez le définir exactement une fois. Si vous souhaitez modifier l'interface utilisateur pendant que votre application est en cours d'exécution, vous devez le faire en modifiant le contenu de votreMainPage, plutôt que d'essayer de remplacer le MainPage avec un autre.
Les autres événements d'application sont Exit, qui est votre chance de dernière minute d'exécuter le shutdown code lorsque l'interface utilisateur est sur le point de disparaître, et UnhandledException, qui est déclenchée si votre code lève une exception non gérée.
Si vous ne fournissez pas de gestionnaire pour le UnhandledException événement, ou si ce gestionnaire ne marque pas l'événement comme étant géré, UnhandledExceptions arrêtera efficacement votre application Silverlight.
La zone des plug-ins à l'écran deviendra vide et une erreur de script sera signalée au navigateur.
Dans ce chapitre, nous verrons comment les applications Silverlight peuvent accéder aux fichiers sur l'ordinateur de l'utilisateur final. Il existe trois façons principales d'accéder aux fichiers dans Silverlight. Le choix dépendra de la raison pour laquelle vous devez utiliser des fichiers et du fait que vous écrivez ou non une application approuvée.
L'option la plus flexible consiste à utiliser file dialogDes classes. Avec leOpen et Saveboîtes de dialogue de fichier, vous pouvez accéder à tout fichier choisi par l'utilisateur final, à condition que l'utilisateur dispose des autorisations appropriées. Le consentement de l'utilisateur est au cœur de cette approche. L'utilisateur doit choisir le fichier à lire, ou lors de l'enregistrement, il choisit un fichier à écraser ou choisit un emplacement et un nom de fichier pour vous.
La deuxième option consiste à utiliser les différentes classes du System.IOespace de noms. Silverlight propose des cours tels queFileStream, StreamWriter, FileInfo, Directory, et DirectoryInfo, qui permettent tous d'écrire du code qui ouvre et accède aux fichiers sans avoir besoin d'impliquer l'utilisateur. Cela peut être plus pratique pour le développeur, mais bien sûr, la plupart des utilisateurs ne voudraient pas qu'un ancien code téléchargé dans le cadre d'une page Web puisse rechercher dans leurs fichiers.
La troisième option est Isolated Storage, dont nous discuterons plus tard.
Boîtes de dialogue Ouvrir et enregistrer un fichier
SaveFileDialog
le SaveFileDialog classe affiche l'interface utilisateur standard fournie par le système d'exploitation pour choisir où enregistrer un fichier.
Certaines caractéristiques importantes sont -
Pour l'utiliser, nous créons une instance du SaveFileDialog classe.
Appel ShowDialog, le fait apparaître et le code de retour nous indique si l'utilisateur a sélectionné un emplacement pour enregistrer le fichier ou annulé la boîte de dialogue.
Vous vous interrogez peut-être sur la comparaison redondante avec TrueLà. SiShowDialog Retour Truevalue, ce qui signifie que l'utilisateur a sélectionné un fichier. Ainsi nous pouvons continuer à appeler leOpenFile méthode, qui nous renvoie un Stream.
Si nous le voulons, nous pouvons découvrir le nom choisi par l'utilisateur. La boîte de dialogue fournit une propriété appeléeSafeFileName, mais cela n'inclut pas le chemin. Dans tous les cas, la seule façon d'écrire des données est d'utiliser leStreamrenvoyé par la boîte de dialogue. Du point de vue d'un développeur, il s'agit simplement d'un.NET stream, afin que nous puissions l'envelopper dans un StreamWriter, pour y écrire du texte.
OpenFileDialog
OpenFileDialog est similaire à l'utilisation du SaveFileDialog. De toute évidence, vous choisissez toujours un fichier existant plutôt qu'un nouveau, mais il existe une autre différence importante.
Il propose une propriété appelée MultiSelect. Si vous définissez cela surTrue, l'utilisateur peut choisir plusieurs fichiers. Cela signifie que la boîte de dialogue a besoin d'une API légèrement plus complexe.
le SaveFileDialog ne traite qu'un seul fichier à la fois, mais OpenFileDialog est capable de faire face à plus, donc il n'offre pas de OpenFileméthode. Nous devons étendre le code. Selon que la boîte de dialogue est ensingle file mode, ou MultiSelect mode, vous utilisez soit son File, ou Files propriété.
Ici, dans l'exemple ci-dessous, nous sommes en mode fichier unique. Par conséquent, nous utilisonsFile, et nous appelons OpenRead sur le FileInfo objet qui retourne.
Dans multiselect mode, nous utiliserions Files à la place, qui renvoie une collection de FileInfo objets.
FileStream
La deuxième approche de file access comme mentionné ci-dessus est d'utiliser le FileStream classe ou des types associés dans le System.IOespace de noms directement. Il n'y a pas grand-chose à dire à ce sujet, car pour la plupart, c'est similaire à l'accès aux fichiers avec le.NET Framework.
Cependant, il y a quelques rebondissements spécifiques à Silverlight.
Premièrement, cette approche vous permet d'accéder aux fichiers à tout moment sans intervention de l'utilisateur, et sans aucune indication visible évidente de l'activité des fichiers, seules les applications de confiance sont autorisées à utiliser cette technique. N'oubliez pas que vous devez manquer de navigateur pour obtenir une confiance accrue.
Le deuxième problème est que seuls les fichiers de certains dossiers spécifiques sont disponibles. Vous ne pouvez lire et écrire que les fichiers sous leUser's Documents, Music, Pictures, or Video files. L'une des raisons à cela est que Silverlight fonctionne sur plusieurs plates-formes et que la structure du système de fichiers pour, par exemple, un Mac Apple, est très différente de celle de Windows. Par conséquent, l'accès aux fichiers multiplateforme doit fonctionner en termes d'un ensemble limité de dossiers disponibles sur tous les systèmes pris en charge par Silverlight.
Étant donné que ces dossiers se trouveront à des emplacements différents sur différents systèmes d'exploitation et que leur emplacement variera généralement d'un utilisateur à l'autre, vous devez utiliser le Environment.GetFolderPath méthode pour découvrir l'emplacement réel au moment de l'exécution.
Vous pouvez inspecter la structure des répertoires sous les points de départ. leDirectory et DirectoryInfo classes dans le System.IO namespace vous permet d'énumérer des fichiers et des répertoires.
Prenons un exemple simple dans lequel le fichier peut s'ouvrir via OpenFileDialog et enregistrez du texte dans le fichier via SaveFileDialog.
Ci-dessous, le code XAML dans lequel deux boutons et un text box sont créées.
<UserControl x:Class = "FileDialogs.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.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "265*" />
</Grid.RowDefinitions>
<Button
x:Name = "saveFileButton"
Content = "Save"
Width = "75" FontSize = "20"
HorizontalAlignment = "Left" VerticalAlignment = "Top"
Margin = "12,12" Click = "saveFileButton_Click" />
<Button
x:Name = "openFileButton"
Content = "Open"
Width = "75" FontSize = "20"
HorizontalAlignment = "Left" VerticalAlignment = "Top"
Margin = "101,12,0,0" Click = "openFileButton_Click" />
<TextBox
x:Name = "contentTextBox"
Grid.Row = "1"
Margin = "12" FontSize = "20" />
</Grid>
</UserControl>
Vous trouverez ci-dessous le code C # pour l'implémentation des événements de clic dans lequel le fichier est ouvert et enregistré.
using System;
using System.Diagnostics;
using System.IO;
using System.Windows;
using System.Windows.Controls;
namespace FileDialogs {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void saveFileButton_Click(object sender, RoutedEventArgs e) {
var save = new SaveFileDialog();
save.Filter = "Text Files (*.txt)|*.txt|All Files (*.*)|*.*";
save.DefaultExt = ".txt";
if (save.ShowDialog() == true) {
Debug.WriteLine(save.SafeFileName);
using (Stream saveStream = save.OpenFile())
using (var w = new StreamWriter(saveStream)) {
var fs = saveStream as FileStream;
if (fs != null) {
w.Write(contentTextBox.Text);
}
}
}
}
private void openFileButton_Click(object sender, RoutedEventArgs e) {
var open = new OpenFileDialog();
if (open.ShowDialog() == true) {
using (Stream openStream = open.File.OpenRead()) {
using (var read = new StreamReader(openStream)) {
contentTextBox.Text = read.ReadToEnd();
}
}
}
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la page Web suivante, qui contient deux boutons.
Clique le Open bouton, qui ouvrira OpenFileDialog pour sélectionner un fichier texte.
Sélectionnez un fichier texte et cliquez sur Open, vous verrez le texte sur la zone de texte.
Pour enregistrer le texte dans le fichier, mettez à jour le texte.
Clique le Save pour enregistrer les modifications dans un nouveau fichier texte ou un fichier existant.
Pour enregistrer les modifications apportées au fichier texte existant, sélectionnez le fichier texte dans SaveFileDialog, mais si vous souhaitez enregistrer les modifications apportées au nouveau fichier, écrivez le nom du fichier et cliquez sur le bouton Save bouton.
Dans ce chapitre, nous examinerons une technique importante du développement logiciel de Silverlight, l'utilisation de View Models.
le view model est un élément clé, qui introduit une technique appelée présentation séparée en gardant la vue séparée du modèle.
View Models offrent un moyen d'obtenir une présentation séparée, et nous verrons comment ils exploitent la liaison de données de Silverlight pour réduire la quantité de code nécessaire dans votre interface utilisateur.
Défis de développement de l'interface utilisateur
View Modelssont conçus pour résoudre certains problèmes fréquemment rencontrés lors du développement d'un logiciel d'interface utilisateur. Le plus important est peut-être que le code de l'interface utilisateur est souvent difficile à tester de manière inextricable, en particulier avec les tests unitaires automatisés. Il existe également des problèmes de qualité du code qui peuvent affecter la flexibilité et la maintenabilité continues de votre code.
Si vous suivez le chemin de moindre résistance que les outils de conception de Visual Studio vous conduisent, vous pouvez finir par mettre beaucoup trop de code dans le code.
Il est très courant de voir de grandes quantités de fonctionnalités d'application sont ajoutées dans le code derrière.
Peu de développeurs envisagent de placer la logique métier dans une classe d'interface utilisateur, mais comme c'est là que Visual Studio place vos gestionnaires d'événements, il devient un endroit trop pratique pour faire avancer les choses.
Il est largement admis que les logiciels sont plus faciles à développer et à maintenir si les classes ont des responsabilités bien définies et raisonnablement étroites.
Le travail de code derrière est d'interagir directement avec les objets qui composent l'interface utilisateur là où c'est nécessaire.
Dès que vous commencez à mettre du code qui prend des décisions sur le comportement de votre application, ce qui a tendance à poser des problèmes.
Non seulement la logique de l'application peut couler dans le code censé être concerné par l'interface utilisateur, mais certains développeurs commencent à s'appuyer sur des contrôles et d'autres objets d'interface utilisateur pour conserver un état d'application important.
Le modèle contient simplement les données, la vue contient simplement la date formatée et le contrôleur (ViewModel) sert de liaison entre les deux. Le contrôleur peut prendre une entrée de la vue et la placer sur le modèle et vice versa.
Présentation séparée
Pour éviter les problèmes causés par l'insertion de la logique d'application dans le code derrière ou XAML, il est préférable d'utiliser une technique appelée separated presentation. Ayant XAML et code derrière avec le minimum requis pour travailler directement avec des objets d'interface utilisateur, les classes d'interface utilisateur contiennent également du code pour les comportements d'interaction complexes, la logique d'application et tout le reste, comme indiqué ci-dessous sur le côté gauche.
Caractéristiques importantes de la présentation séparée -
Avec une présentation séparée, la classe d'interface utilisateur est beaucoup plus simple. Il a XAML bien sûr, mais le code derrière fait aussi peu que pratique.
La logique d'application appartient à une classe distincte, souvent appelée model.
De nombreux développeurs tentent d'utiliser la liaison de données pour connecter des éléments dans le XAML directement aux propriétés du modèle.
Le problème est le model est entièrement préoccupé par ce que fait l'application, et non par la façon dont l'utilisateur interagit avec l'application.
La plupart des interfaces utilisateur ont un état qui n'appartient pas au modèle d'application. Par exemple, si votre interface utilisateur utilise un glisser-déposer, quelque chose doit garder une trace de choses comme l'endroit où l'élément à glisser est maintenant, comment son apparence devrait changer lorsqu'il se déplace sur les cibles de dépôt possibles, et comment ces cibles de dépôt pourraient également changer au fur et à mesure que l'élément est glissé dessus.
Ce type d'état peut devenir étonnamment complexe et doit être minutieusement testé.
En pratique, vous voulez normalement une autre classe assise entre l'interface utilisateur et le modèle. Cela a deux rôles importants.
Tout d'abord, il adapte votre modèle d'application à une vue d'interface utilisateur particulière.
Deuxièmement, c'est là que réside toute logique d'interaction non triviale, et par là, je veux dire le code nécessaire pour que votre interface utilisateur se comporte comme vous le souhaitez.
Modèle / Vue / VueModèle
View Modelest un exemple de l'approche de présentation séparée, mais soyons clairs sur le type de chose que nous avons dans chaque couche. Il y a trois couches -
- Model
- View
- ViewModel
Modèle
C'est un classic modèle d'objet comprenant des classes C # ordinaires qui n'ont pas de relation directe avec l'interface utilisateur.
Vous vous attendez généralement à ce que vos codes de modèle puissent être compilés sans références à aucune bibliothèque d'interface utilisateur. En fait, vous seriez probablement en mesure de prendre exactement le même code source et de le compiler dans une application Silverlight, une application de console .NET ordinaire ou même un code Web côté serveur.
Les types du modèle doivent représenter les concepts avec lesquels votre application fonctionne.
Vue
Une vue est normalement un UserControl, ce peut être votre MainPage ou simplement une partie de votre page.
Dans la plupart des applications Silverlight, il est judicieux de diviser votre interface utilisateur en petits morceaux définissant un UserControl ou une vue pour chaque élément.
Les applications Silverlight ne sont pas uniques à cet égard. Quelque chose qui est évidemment spécifique à Silverlight est la vue. Plus votre interface utilisateur est fine, meilleures sont les choses. Non seulement vous êtes moins susceptible de trébucher sur d'autres développeurs travaillant sur les mêmes fichiers, mais garder les choses petites et simples décourage naturellement les raccourcis qui mènent à un code de type spaghetti.
Par exemple, il est très courant de définir un View pour représenter un élément individuel dans une liste.
VoirModèle
Enfin, pour chaque View, vous écrivez un ViewModel. C'est donc l'une des caractéristiques importantes d'unViewModel classe.
Il existe pour servir une vue particulière. leViewModel est spécialisé pour une manière particulière de présenter les choses, comme un élément de données particulier tel qu'il apparaît dans les listes.
C'est pourquoi cela s'appelle un ViewModel; il adapte le modèle sous-jacent en particulier pour une vue particulière. Comme le modèle, leViewModelest également une classe C # ordinaire. Il n'a pas besoin de dériver d'un type particulier.
En l'occurrence, certains développeurs trouvent pratique de mettre des fonctionnalités communes dans une classe ViewModel de base, mais le modèle ne l'exige pas. En particulier, votreViewModelne dérive d'aucun type spécifique à Silverlight. Cependant, contrairement au modèle, il peut utiliser des types Silverlight dans ses propriétés.
Par exemple, votre ViewModel peut choisir de rendre certaines parties de votre interface utilisateur visibles uniquement dans certaines conditions, et vous pouvez donc fournir une propriété de type System.Windows.Visibility, qui est le type que les éléments Silverlight utilisent pour leur propriété Visibility. Cela permet de lier la visibilité d'un élément, tel qu'un panneau, directement au ViewModel.
Exemple
Regardons un exemple simple dans lequel nous utiliserons Model-View-ViewModel (MVVM) approche.
Step 1 - Créer un nouveau projet d'application Silverlight SilverlightMVVMDemo.
Step 2 - Ajoutez les trois dossiers (Model, ViewModel et Views) dans votre projet comme indiqué ci-dessous.
Step 3 - Ajoutez une classe StudentModel dans le dossier Model et collez le code ci-dessous dans cette classe.
using System.ComponentModel;
namespace SilverlightMVVMDemo.Model {
public class StudentModel {}
public class Student : INotifyPropertyChanged {
private string firstName;
private string lastName;
public string FirstName {
get { return firstName; }
set {
if (firstName != value) {
firstName = value;
RaisePropertyChanged("FirstName");
RaisePropertyChanged("FullName");
}
}
}
public string LastName {
get { return lastName; }
set {
if (lastName != value) {
lastName = value;
RaisePropertyChanged("LastName");
RaisePropertyChanged("FullName");
}
}
}
public string FullName {
get {
return firstName + " " + lastName;
}
}
public event PropertyChangedEventHandler PropertyChanged;
private void RaisePropertyChanged(string property) {
if (PropertyChanged != null) {
PropertyChanged(this, new PropertyChangedEventArgs(property));
}
}
}
}
Step 4 - Ajoutez une autre classe StudentViewModel dans le dossier ViewModel et collez le code suivant.
using SilverlightMVVMDemo.Model;
using System.Collections.ObjectModel;
namespace SilverlightMVVMDemo.ViewModel {
public class StudentViewModel {
public ObservableCollection<Student> Students {
get;
set;
}
public void LoadStudents() {
ObservableCollection<Student> students = new ObservableCollection<Student>();
students.Add(new Student { FirstName = "Mark", LastName = "Allain" });
students.Add(new Student { FirstName = "Allen", LastName = "Brown" });
students.Add(new Student { FirstName = "Linda", LastName = "Hamerski" });
Students = students;
}
}
}
Step 5 - Ajouter Silverlight User Control en faisant un clic droit sur Views dossier et sélectionnez Add New Item….
Step 6- Cliquez sur Ajouter. Vous verrez maintenant le fichier XAML. Ajoutez le code suivant dansStudentView.xaml fichier, qui contient différents éléments de l'interface utilisateur.
<UserControl x:Class = "SilverlightMVVMDemo.Views.StudentView"
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 HorizontalAlignment = "Left">
<ItemsControl ItemsSource = "{Binding Path=Students}">
<ItemsControl.ItemTemplate>
<DataTemplate>
<StackPanel Orientation = "Horizontal">
<TextBox Text = "{Binding Path = FirstName, Mode = TwoWay}"
Width = "100" Margin = "3 5 3 5"/>
<TextBox Text = "{Binding Path = LastName, Mode = TwoWay}"
Width = "100" Margin = "0 5 3 5"/>
<TextBlock Text = "{Binding Path = FullName, Mode=OneWay}"
Margin = "0 5 3 5"/>
</StackPanel>
</DataTemplate>
</ItemsControl.ItemTemplate>
</ItemsControl>
</StackPanel>
</Grid>
</UserControl>
Step 7 - Maintenant, ajoutez le StudentView Dans votre MainPage.xaml fichier comme indiqué ci-dessous.
<UserControl x:Class = "SilverlightMVVMDemo.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"
xmlns:views = "clr-namespace:SilverlightMVVMDemo.Views"
mc:Ignorable = "d"
d:DesignHeight = "576.316" d:DesignWidth = "863.158">
<Grid x:Name = "LayoutRoot" Background = "White">
<views:StudentView x:Name = "StudentViewControl" Loaded = "StudentViewControl_Loaded"/>
</Grid>
</UserControl>
Step 8 - Voici la mise en œuvre de Loaded événement dans le MainPage.xaml.cs fichier, qui mettra à jour le View du ViewModel.
using System.Windows;
using System.Windows.Controls;
namespace SilverlightMVVMDemo {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
}
private void StudentViewControl_Loaded(object sender, RoutedEventArgs e) {
SilverlightMVVMDemo.ViewModel.StudentViewModel
studentViewModelObject = new SilverlightMVVMDemo.ViewModel.
StudentViewModel();
studentViewModelObject.LoadStudents();
StudentViewControl.DataContext = studentViewModelObject;
}
}
Step 9 - Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante sur votre page Web.
UI vs ViewModel
L'une des parties les plus difficiles de l'approche MVVM consiste à déterminer où doit se situer la ligne de démarcation. Il n'est pas toujours évident de savoir à quelles choses appartiennent.
En particulier, certains éléments de l'interface utilisateur fournissent des fonctionnalités qui, selon une vue stricte, devraient sans doute appartenir au ViewModel.
En général, tous les comportements mis en œuvre dans le View sont tellement ViewModel amical.
Cela s'explique en partie par le fait qu'il n'existe aucun moyen standard de conditionner le comportement de ViewModel pour la réutilisation, en particulier si vous souhaitez utiliser un environnement de conception, tel que Visual Studio ou Blend.
Avantages de MVVM
MVVM offre les avantages suivants -
Séparation des problèmes de présentation (View, ViewModel, Model)
Code propre testable et gérable. Peut inclure une logique de niveau de présentation dans les tests unitaires.
Aucun code derrière le code, donc la couche de présentation et la logique sont faiblement couplées.
Meilleure méthode de liaison de données.
Inconvénients de MVVM
Pour les interfaces utilisateur simples, MVVM peut être exagéré. Le débogage serait un peu difficile lorsque nous avons des liaisons de données complexes.
Dans ce chapitre, nous allons apprendre à gérer les entrées utilisateur dans les applications Silverlight. Silverlight fournit une API puissante à l'aide de laquelle une application peut obtenir des entrées de divers appareils tels que la souris, le clavier et le tactile, etc.
Types d'entrée
Un utilisateur peut interagir avec votre application de différentes manières. Le moyen le plus évident est d'utiliser une souris. Silverlight propose des événements pour le suivi -
- Mouvements de souris
- Le bouton clique, et
- Activité de la roue
Il y a aussi le clavier, bien sûr, et Silverlight prend également en charge la saisie par écran tactile. Si vous êtes familiarisé avec la prise en charge tactile dans Windows, vous savez que la saisie tactile peut être représentée soit comme des événements de bas niveau fournissant des informations détaillées, soit elle peut être résumée en événements de haut niveau appelés gestes.
Événements de souris
Commençons par examiner les événements d'entrée de souris proposés par Silverlight. Certains événements concernent le mouvement du pointeur de la souris.
le MouseMove L'événement est déclenché à chaque fois que le pointeur se déplace alors qu'il se trouve sur les éléments auxquels vous avez attaché le gestionnaire.
Vous obtenez également MouseEnter et MouseLeave événements pour vous avertir lorsque la souris entre et sort de l'élément.
Vous trouverez ci-dessous le code XAML dans lequel l'ellipse et TextBlock sont ajoutés.
<UserControl x:Class="MouseInput.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">
<TextBlock x:Name = "mouseText" FontSize = "40"
VerticalAlignment = "Top" Height = "76" Margin = "0,10,0,0" />
<Ellipse
Name = "myEllipse"
Width = "320" Height = "150" HorizontalAlignment = "Left"
VerticalAlignment = "Top" Margin = "27,103,0,0"
Stroke = "Black" StrokeThickness = "10" Fill = "#00FF0000"
MouseEnter = "myEllipse_MouseEnter"
MouseLeave = "myEllipse_MouseLeave"
MouseMove = "myEllipse_MouseMove" />
</Grid>
</UserControl>
Ci-dessous est la mise en œuvre pour différents mouse input événements.
using System.Windows.Controls;
using System.Windows.Input;
using System.Windows.Media;
namespace MouseInput {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void myEllipse_MouseEnter(object sender, MouseEventArgs e) {
mouseText.Text = "Mouse Enter";
myEllipse.Stroke = new SolidColorBrush(Colors.Blue);
}
private void myEllipse_MouseLeave(object sender, MouseEventArgs e) {
mouseText.Text = "Mouse Leave";
myEllipse.Stroke = new SolidColorBrush(Colors.Black);
}
private void myEllipse_MouseMove(object sender, MouseEventArgs e) {
mouseText.Text = "Mouse Move: " + e.GetPosition(myEllipse);
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Lorsque la souris entre dans l'ellipse, vous verrez le changement de couleur et de coordonnées.
Lorsque la souris quitte l'ellipse, elle affichera un message 'mouse leave'et changera à la couleur par défaut.
Clavier
Le moyen le plus simple pour un utilisateur de saisir des données textuelles dans votre application consiste à utiliser le clavier, le cas échéant. N'oubliez pas que tous les appareils mobiles n'ont pas de clavier, à l'exception des ordinateurs portables et des ordinateurs de bureau.
Silverlight propose deux événements simples pour la saisie au clavier, KeyUp et KeyDown.
Ces deux passent un KeyEventArgs au gestionnaire et la propriété Key indique quelle touche a été enfoncée.
Dans l'exemple ci-dessous, certaines entrées du clavier sont gérées.
L'exemple suivant définit un gestionnaire pour l'événement Click et un gestionnaire pour le KeyDown un événement.
Vous trouverez ci-dessous le code XAML dans lequel différents éléments d'interface utilisateur sont ajoutés.
<UserControl x:Class = "KeyboardInput.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 Orientation = "Horizontal" KeyDown = "OnTextInputKeyDown">
<TextBox Width = "400" Height = "30" Margin = "10"/>
<Button Click = "OnTextInputButtonClick"
Content = "Open" Margin = "10" Width = "50" Height = "30"/>
</StackPanel>
</Grid>
</UserControl>
Vous trouverez ci-dessous le code C # dans lequel différents événements de clavier et de clic sont gérés.
using System.Windows;
using System.Windows.Controls;
using System.Windows.Input;
namespace KeyboardInput {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void OnTextInputKeyDown(object sender, KeyEventArgs e) {
if (e.Key == Key.O) {
handle();
e.Handled = true;
}
}
private void OnTextInputButtonClick(object sender, RoutedEventArgs e) {
handle();
//e.Handled = true;
}
public void handle() {
MessageBox.Show("Do you want to open a file?");
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez ce qui suit -
Si vous cliquez sur le Open ou cliquez dans la zone de texte et cliquez sur OK, puis il affichera le même message.
Nous vous recommandons d'exécuter l'exemple ci-dessus pour une meilleure compréhension.
Le troisième mécanisme d'accès aux fichiers est Isolated Storagemécanisme, qui fournit le stockage associé à l'utilisateur connecté. L'API présente les données via leStream classe de .NET System.IOespace de noms. Par conséquent, comme pour les autres mécanismes que nous avons examinés jusqu'à présent, vous pouvez utiliser les autres types dansSystem.IO pour travailler avec les flux, vous permettant de stocker des données textuelles ou binaires.
Certaines caractéristiques importantes sont -
Ce mécanisme de stockage est appelé Isolated Storage car le magasin est partitionné et une application Silverlight n'a accès qu'à certaines parties.
Vous ne pouvez accéder à aucune ancienne donnée stockée. Tout d'abord, le magasin est partitionné par utilisateur. Une application Silverlight ne peut pas accéder au magasin pour un utilisateur différent de celui connecté et exécutant l'application.
Cela n'a rien à voir avec les mécanismes d'identification que votre application Web peut utiliser. C'est un point important à retenir car certaines personnes qui partagent des ordinateurs ne s'embarrassent pas avec des comptes Windows séparés et sont habituées à se connecter et à se déconnecter des sites Web qu'elles utilisent.
Utilisation du stockage isolé
Le stockage isolé n'est pas unique à Silverlight. L'API a été initialement introduite pourWindows Formspour permettre aux applications lancées à partir du Web de stocker des données localement dans des scénarios de confiance partielle. L'implémentation est différente et il n'y a aucun moyen d'accéder à l'intégralité.NET Stockage isolé de Framework de Silverlight, ou vice versa.
Cependant, si vous l'avez utilisé, les étapes ici vous sembleront très familières.
Vous commencez par demander le magasin spécifique à l'utilisateur. Dans ce cas, nous demandons celui de l'application. Si nous voulions que le magasin par site soit partagé par tous les XAP du site, nous appellerionsGetUserStoreForSite au lieu.
Chaque méthode renvoie un IsolatedStorageFile object, qui est un nom assez inutile car il représente un répertoire, pas un fichier.
Pour accéder à un fichier, vous devez demander au IsolatedStorageFile pour un Stream.
Nous utilisons le IsolatedStorageFileStream class, et son constructeur vous oblige à passer le IsolatedStorageFile objet comme argument.
Nous créons donc un nouveau fichier dans le magasin. L'emplacement exact du fichier sur le disque est inconnu.
Le répertoire contenant a des éléments aléatoires afin de rendre impossible de deviner le nom du fichier.
Sans cela, il pourrait être possible pour des sites Web malveillants de placer un fichier sur l'ordinateur de l'utilisateur, puis de construire une URL de fichier pour l'ouvrir, dans l'espoir de tromper l'utilisateur en cliquant sur un lien qui exécute un programme localement.
Il existe diverses autres mesures de protection intégrées à Windows qui tentent d'empêcher que cela se produise, mais il s'agit d'une autre couche de défense au cas où les autres auraient été désactivées ou contournées.
Le fichier sera stocké quelque part dans le profil de l'utilisateur, mais c'est tout ce que vous pouvez en savoir. VotreIsolatedStorageFileStream ne rapportera pas son emplacement réel.
Jetons un coup d'œil à un exemple simple qui suit le nombre de fois que l'application a été exécutée. Le code XAML est donné ci-dessous.
<UserControl x:Class = "StoreRunCount.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">
<TextBlock x:Name = "runCountText" FontSize = "20" />
</Grid>
</UserControl>
Voici le code C # dans lequel Isolated storage sont utilisés.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;
using System.IO.IsolatedStorage;
using System.IO;
namespace StoreRunCount {
public partial class MainPage : UserControl {
const string RunCountFileName = "RunCount.bin";
public MainPage() {
InitializeComponent();
int runCount = 0;
using (var store = IsolatedStorageFile.GetUserStoreForApplication()) {
if (store.FileExists(RunCountFileName)) {
using (var stm = store.OpenFile(RunCountFileName,
FileMode.Open, FileAccess.Read))
using (var r = new BinaryReader(stm)) {
runCount = r.ReadInt32();
}
}
runCount += 1;
using (var stm = store.OpenFile(RunCountFileName,
FileMode.Create, FileAccess.Write))
using (var w = new BinaryWriter(stm)) {
w.Write(runCount);
}
}
runCountText.Text = "You have run this application " + runCount.ToString() + " time(s)";
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la page Web suivante qui vous montrera combien de fois vous exécutez cette application.
Augmenter votre quota
Les applications peuvent demander plus d'espace si le montant initial est insuffisant pour une raison quelconque. Il n'y a aucune garantie que la demande aboutira. Silverlight demandera à l'utilisateur s'il souhaite accorder plus d'espace à l'application.
En passant, vous n'êtes autorisé à demander plus de stockage qu'en réponse à une entrée utilisateur, telle qu'une click. Si vous essayez de le demander à un autre moment, par exemple lors du chargement du plug-in ou dans un gestionnaire de minuterie, Silverlight échouera automatiquement la demande sans même en avertir l'utilisateur. Le quota supplémentaire n'est disponible que pour les applications avec lesquelles l'utilisateur interagit.
le IsolatedStorageFile object fournit trois membres pour gérer le quota -
- AvailableFreeSpace
- IncreaseQuotaTo
- Quota
Espace libre
La propriété AvailableFreeSpace vous indique la part de votre quota restant libre.
Notez que même un sous-répertoire vide consomme une partie de votre quota car le système d'exploitation doit allouer de l'espace sur le disque pour représenter le répertoire. Ainsi, l'espace disponible peut être inférieur au quota total, moins la taille totale de tous vos fichiers.
Augmenter le quota
Si vous ne disposez pas de suffisamment d'espace pour continuer, demandez plus en appelant le IncreaseQuotaTo méthode.
Quota
Ici, nous utilisons la troisième propriété, Quota, pour découvrir la taille actuelle du quota, puis nous ajoutons le montant supplémentaire dont nous avons besoin pour obtenir notre nouveau quota demandé.
La méthode renvoie soit True ou Falsepour indiquer si nous recevons ce que nous avons demandé. Notez que Silverlight peut décider d'allouer plus d'espace que vous n'en avez demandé.
Voici un exemple simple pour augmenter le quota, lorsque vous cliquez sur le bouton. Le code XAML est donné ci-dessous.
<UserControl x:Class = "ChangeQuota.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">
<TextBlock x:Name = "infoText" FontSize = "20" TextWrapping = "Wrap" />
<Button x:Name = "increaseQuota" Content = "Increase" HorizontalAlignment = "Center"
FontSize = "20"
VerticalAlignment = "Center" Click = "increaseQuota_Click" />
</Grid>
</UserControl>
Voici la mise en œuvre de click événement au cours duquel le quota est augmenté.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;
using System.IO.IsolatedStorage;
namespace ChangeQuota {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void increaseQuota_Click(object sender, RoutedEventArgs e) {
using (IsolatedStorageFile isoStore =
IsolatedStorageFile.GetUserStoreForApplication()) {
long newQuota = isoStore.Quota + 10240;
if (isoStore.IncreaseQuotaTo(newQuota)) {
infoText.Text = "Quota is " + isoStore.Quota + ", free space: " +
isoStore.AvailableFreeSpace;
} else {
infoText.Text = "Meanie!";
}
}
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Lorsque vous cliquez Increase, l'invite apparaît. Il demande d'augmenter leQuota être 10KB plus grand que ce qu'il est déjà.
Lorsque vous cliquez Yes, il imprime ensuite la quantité de quota disponible.
Nous vous recommandons d'exécuter les exemples ci-dessus pour une meilleure compréhension.
Dans ce chapitre, nous examinerons ce que Silverlight propose pour afficher du texte. Le bloc de texte est utilisé pour tout le rendu de texte et Silverlight. D'autres caractéristiques importantes sont -
- Il peut être utilisé pour du texte simple ou vous pouvez appliquer un mélange de styles de mise en forme.
- Silverlight prend en charge un ensemble standard de polices intégrées.
- Vous pouvez également télécharger des polices personnalisées lorsque le style visuel de vos applications nécessite quelque chose de moins ordinaire.
TextBlock
Pour afficher du texte, nous utilisons l'élément de manuel Silverlight, qui est un contrôle léger pour afficher de petites quantités de texte en lecture seule. En fait, nous l'avons déjà beaucoup vu car son utilisation de base ne nécessite pas vraiment beaucoup d'explications. Vous venez de définir la propriété text et elle affiche ce texte pour vous.
<TextBlock Text = "Print Testing" HorizontalAlignment Center" FontFamily = "Georgia"/>
L'héritage hiérarchique de la classe TextBlock est le suivant,
Ci-dessous sont les properties de TextBlock classe.
Sr. No. | Propriété et description |
---|---|
1 | ContentEnd Obtient un objet TextPointer pour la fin du contenu de texte dans TextBlock. |
2 | ContentStart Obtient un objet TextPointer pour le début du contenu de texte dans TextBlock. |
3 | IsTextSelectionEnabled Obtient ou définit une valeur qui indique si la sélection de texte est activée dans TextBlock, soit via l'action de l'utilisateur, soit en appelant l'API liée à la sélection. |
4 | IsTextSelectionEnabledProperty Identifie la propriété de dépendance IsTextSelectionEnabled. |
5 | LineHeight Obtient ou définit la hauteur de chaque ligne de contenu. |
6 | MaxLines Obtient ou définit le nombre maximal de lignes de texte affichées dans TextBlock. |
sept | SelectedText Obtient une plage de texte du texte sélectionné. |
8 | SelectionEnd Obtient la position de fin du texte sélectionné dans TextBlock. |
9 | SelectionHighlightColor Obtient ou définit le pinceau utilisé pour mettre en évidence le texte sélectionné. |
dix | SelectionStart Obtient la position de départ du texte sélectionné dans TextBlock. |
11 | Text Obtient ou définit le contenu de texte d'un TextBlock. |
12 | TextAlignment Obtient ou définit une valeur qui indique l'alignement horizontal du contenu du texte. |
13 | TextTrimming Obtient ou définit le comportement de découpage de texte à utiliser lorsque le contenu déborde de la zone de contenu. |
14 | TextWrapping Obtient ou définit la façon dont TextBlock encapsule le texte. |
Les données ci-dessous sont couramment utilisées events de TextBlock classe.
Sr. No. | Description de l'évenement |
---|---|
1 | ContextMenuOpening Se produit lorsque le système traite une interaction qui affiche un menu contextuel. |
2 | SelectionChanged Se produit lorsque la sélection de texte a changé. |
Ci-dessous sont les methods dans TextBlock classe.
Sr. No. | Méthode et description |
---|---|
1 | Focus Concentre le TextBlock, comme s'il s'agissait d'un contrôle focalisable de manière conventionnelle. |
2 | Select Sélectionne une plage de texte dans TextBlock. |
3 | SelectAll Sélectionne tout le contenu du TextBlock. |
Courir
Parfois, vous voulez un contrôle précis sur la mise en forme et la définition d'un style pour un bloc de texte entier. Il est parfois utile de formater des mots individuels ou même des lettres, et si vous le souhaitez, au lieu d'utiliser leText propriété, vous mettez le texte dans le TextBlockcomme contenu. Si vous utilisez un code, cela correspond à l'ajout d'éléments auTextBlock propriété en ligne.
En utilisant cette approche, vous pouvez ajouter une série d'éléments d'exécution. Chaque tirage prend en charge la même famille de polices, l'épaisseur avant, le premier plan, etc. pour contrôler le style de texte. Bien que Run soit un élément distinct, cela ne perturbe pas le flux.
Jetons un coup d'œil à un exemple simple, qui contient plusieurs Run élément à l'intérieur TextBlock. Le code XAML est donné ci-dessous.
<UserControl x:Class = "SilverlightRunDemo.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">
<TextBlock Width = "192" TextWrapping = "Wrap" FontFamily = "Verdana">
<Run Text = "Hello, " />
<Run FontWeight = "Bold" Text = "world!" />
<Run Text = "You" />
<Run FontStyle = "Italic" Text = " are " />
<Run Text = "learning" FontSize = "40" FontFamily = "01d English Text MT" />
<Run Text = " the " />
<Run Text = "basics of " Foreground = "Blue" />
<Run Text = " Silverlight." FontSize = "30" />
</TextBlock>
</Grid>
</UserControl>
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Comme vous pouvez le voir, ce bloc de texte est organisé avec différents styles de mise en forme en utilisant le Run élément.
En passant, vous n'avez pas besoin d'encapsuler chaque bit de texte dans une course. Vous pouvez laisser la majeure partie du contenu d'un bloc de texte sous forme de texte brut et simplement appliquerrun aux pièces qui nécessitent un formatage différent, comme indiqué ci-dessous.
<TextBlock> Hello,
<Run FontWeight = "Bold" Text =" world!"/>
</TextBlock>
Saut de ligne
Silverlight ignore généralement les sauts de ligne dans le XAML. Cela suppose que la plupart des espaces blancs sont là pour les rendre plus faciles à lire, car vous voulez en fait que cet espace apparaisse.
Jetons un coup d'œil à ce code XAML, qui contient trois lignes de texte distinctes.
<TextBlock>
This is not the end.
It is not even the beginning of the end.
But it is, perhaps, the end of the beginning
</TextBlock>
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Comme vous pouvez le voir, il a ignoré les sauts de ligne et exécuté tout le texte ensemble.
Si vous activez text wrapping, il placera les sauts de ligne là où il doit être pour adapter le texte, mais il ignorera les sauts de ligne dans votre exemple.
Si vous souhaitez simplement ajouter des sauts de ligne explicites, vous devez ajouter une balise de saut de ligne à l'intérieur de votre bloc de texte. Le texte qui suit commencera sur une nouvelle ligne.
Reprenons le même exemple en ajoutant le LineBreak marque.
<TextBlock FontSize = "16">
This is not the end.
<LineBreak/>
It is not even the beginning of the end.
<LineBreak/>
But it is, perhaps, the end of the beginning
</TextBlock>
Lorsque le code ci-dessus est exécuté, vous verrez le à quoi il ressemble maintenant comme spécifié en XAML.
Polices intégrées
Silverlight a un ensemble fixe de familles de polices intégrées. Les polices ont en fait des noms de famille différents pour des raisons historiques. La famille par défaut est techniquement différente sur Mac OS et Windows comme sur Mac OS, c'est Lucida Grande, tandis que sur Windows, c'est la presque identique mais nommée Lucida Sans Unicode.
Certaines des polices les plus couramment utilisées sont indiquées ci-dessous.
Polices |
---|
Arial |
Noir arial |
Comic Sans MS |
Courier Nouveau |
Géorgie |
Lucida Grande (Mac) ou Lucida Sans Unicode (Windows) |
Times New Roman |
Trébuchet MS |
Verdana |
L'animation vous permet de créer des interfaces utilisateur vraiment dynamiques. Il est souvent utilisé pour appliquer des effets, par exemple, des icônes qui grandissent lorsque vous les survolez, des logos qui tournent, du texte qui défile dans la vue, etc.
Parfois, ces effets semblent être des paillettes excessives. Si elles sont utilisées correctement, les animations peuvent améliorer une application de plusieurs manières. Ils peuvent rendre une application plus réactive, naturelle et intuitive.
Par exemple, un bouton qui se glisse lorsque vous cliquez, il ressemble à un vrai bouton physique, pas simplement à un autre rectangle gris. Les animations peuvent également attirer l'attention sur des éléments importants et guider l'utilisateur à travers les transitions vers un nouveau contenu.
L'approche de Silverlight en matière d'animation est déclarative plutôt que de se concentrer sur des séquences d'animations d'images.
Définition des animations
Les animations sont généralement définies dans les sections de ressources. En fait, ils sont généralement enveloppés dans un élément de story-board, que nous verrons en détail sous peu.
Il fournit une méthode Begin (), de sorte que l'animation peut être appelée à partir du code.
Les animations peuvent également être placées à l'intérieur des éléments d'état visuel dans un modèle de contrôle.
Animation déclarative
Les animations dans Silverlight sont déclaratives. Ils décrivent ce qui aurait voulu arriver. Laissez à Silverlight le soin de déterminer comment y parvenir. Ainsi, les animations suivent généralement le modèle que nous indiquons à Silverlight ce que nous aimerions changer.
C'est toujours une propriété sur certains éléments nommés ie TargetName et TargetProperty.
<DoubleAnimation
Storyboard.TargetName = "myRectangle"
Storyboard.TargetProperty = "Opacity"
From = "0" To = "1"
Duration = "0:0:5"
/>
Nous disons comment nous aimerions que cette propriété change dans ce cas, nous changeons l'opacité d'une valeur de zéro à une valeur de un. En d'autres termes, nous aimons que les éléments cibles passent d'opaque à transparent.
Enfin, nous disons combien de temps nous aimerions que cela prenne, dans ce cas, cela prendra cinq secondes.
la signification du double dans cette double animation est qu'il cible une propriété de type double, donc une valeur à virgule flottante.
Si vous souhaitez animer une propriété représentant une couleur, utilisez plutôt une animation de couleur.
Jetons un œil à un exemple simple de double animation. Vous trouverez ci-dessous le code XAML dans lequel deux boutons, un rectangle et deux story-boards sont ajoutés.
<UserControl x:Class = "DoubleAnimationExample.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:DesignWidth = "640" d:DesignHeight = "480">
<UserControl.Resources>
<Storyboard x:Name = "fadeDown">
<DoubleAnimation
Storyboard.TargetName = "myRectangle"
Storyboard.TargetProperty = "Opacity"
From = "1" To = "0"
Duration = "0:0:5" />
</Storyboard>
<Storyboard x:Name = "fadeUp">
<DoubleAnimation
Storyboard.TargetName = "myRectangle"
Storyboard.TargetProperty = "Opacity"
From = "0" To = "1"
Duration = "0:0:5" />
</Storyboard>
</UserControl.Resources>
<Grid x:Name = "LayoutRoot">
<Rectangle x:Name = "myRectangle"
Fill = "Blue" Width = "300" Height = "100"
HorizontalAlignment = "Center"
VerticalAlignment = "Top" Margin = "0,30" />
<Button x:Name = "fadeUpButton" Content = "Up" Width = "80"
Height = "30" HorizontalAlignment = "Left"
VerticalAlignment = "Top" Margin = "50,140,0,0"
Click = "fadeUpButton_Click" />
<Button x:Name = "fadeDownButton" Content = "Down"
Width = "80" Height = "30" HorizontalAlignment = "Left"
VerticalAlignment = "Top" Margin = "50,180,0,0"
Click = "fadeDownButton_Click" />
</Grid>
</UserControl>
Voici l'implémentation pour différents événements en C #.
using System.Windows;
using System.Windows.Controls;
namespace DoubleAnimationExample {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void fadeUpButton_Click(object sender, RoutedEventArgs e) {
fadeUp.Begin();
}
private void fadeDownButton_Click(object sender, RoutedEventArgs e) {
fadeDown.Begin();
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Répéter et inverser
Les animations offrent certaines propriétés à répéter automatiquement et toutes les animations inversées.
Si vous définissez la propriété de comportement de répétition sur une heure de spam, l'animation se répétera jusqu'à ce que le temps spécifié se soit écoulé ou vous pouvez simplement lui indiquer combien de fois vous souhaitez qu'elle se répète.
Cela prend en charge les points décimaux afin que vous puissiez répéter quatre fois et demie.
Vous pouvez répéter indéfiniment et vous pouvez également dire à l'animation qu'une fois qu'elle atteint la fin, elle doit s'exécuter en sens inverse jusqu'au début.
Animation d'images clés
Souvent, une simple animation de A à B est un peu trop simple. Par exemple, vous souhaitez animer une balle rebondissant sur le sol. Ce n'est pas un simple mouvement de point à point. La balle tombe, accélère progressivement puis inverse sa direction lorsqu'elle touche le fond. Ralentissez à nouveau en revenant au sommet de sa course.
Jetons un coup d'œil à un exemple simple de Key Frame animation.
Vous trouverez ci-dessous le code XAML, qui contient une ellipse et une double animation avec des images clés.
<UserControl x:Class = "LinearKeyFrames.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"
Width = "400" Height = "300">
<UserControl.Resources>
<Storyboard x:Name = "ballAnim" SpeedRatio = "0.2">
<DoubleAnimation From = "0" Duration = "00:00:03" To = "96"
Storyboard.TargetName = "ellipse"
Storyboard.TargetProperty = "(Canvas.Left)" />
<DoubleAnimationUsingKeyFrames
Storyboard.TargetName = "ellipse"
Storyboard.TargetProperty = "(Canvas.Top)">
<LinearDoubleKeyFrame KeyTime = "00:00:00" Value = "0"/>
<LinearDoubleKeyFrame KeyTime = "00:00:00.5" Value = "16" />
<LinearDoubleKeyFrame KeyTime = "00:00:01" Value = "48"/>
<LinearDoubleKeyFrame KeyTime = "00:00:01.5" Value = "112"/>
<LinearDoubleKeyFrame KeyTime = "00:00:02" Value = "48"/>
<LinearDoubleKeyFrame KeyTime = "00:00:02.5" Value = "16"/>
<LinearDoubleKeyFrame KeyTime = "00:00:03" Value = "0"/>
</DoubleAnimationUsingKeyFrames>
</Storyboard>
</UserControl.Resources>
<Grid x:Name = "LayoutRoot" Background = "White">
<Canvas>
<Ellipse x:Name = "ellipse" Fill = "Aqua" Width = "50" Height = "50" />
</Canvas>
</Grid>
</UserControl>
Voici la mise en œuvre pour mouse left événement button down, qui commencera l'animation lorsque l'utilisateur appuiera sur le bouton gauche de la souris sur la page Web.
using System.Windows.Controls;
using System.Windows.Input;
namespace LinearKeyFrames {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
this.MouseLeftButtonDown += new MouseButtonEventHandler(Page_MouseLeftButtonDown);
}
void Page_MouseLeftButtonDown(object sender, MouseButtonEventArgs e) {
ballAnim.Begin();
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Lorsque vous cliquez sur la page Web, vous verrez que la balle commence à bouger.
Dans ce chapitre, nous verrons comment les installations Silverlight lisent la vidéo et l'audio. leMediaElementest le cœur de toute la vidéo et de l'audio dans Silverlight. Cela vous permet d'intégrer l'audio et la vidéo dans votre application. leMediaElement la classe fonctionne de la même manière que Imageclasse. Il vous suffit de le pointer vers le média et il rend l'audio et la vidéo.
La principale différence est que ce sera une image en mouvement, mais si vous la pointez vers le fichier qui ne contient que de l'audio et aucune vidéo comme un MP3, il la lira sans rien afficher à l'écran.
MediaElement comme élément d'interface utilisateur
MediaElementdérive de l'élément framework, qui est la classe de base de tous les éléments de l'interface utilisateur Silverlight. Cela signifie qu'il offre toutes les propriétés standard, vous pouvez donc modifier son opacité, définir le clip ou le transformer, etc.
Jetons un coup d'œil à un exemple simple de MediaElement.
Ouvrez Microsoft Blend pour Visual Studio et créez un nouveau projet d'application Silverlight.
Maintenant, faites glisser un fichier vidéo ou audio dans la surface de conception Blend.
Il ajoutera un MediaElement à la surface et ajoutera également une copie du fichier vidéo dans votre projet. Vous pouvez le voir dans l'explorateur de solutions.
Vous pouvez le déplacer, changer sa taille, vous pouvez faire des choses comme appliquer une rotation, etc.
Maintenant, il générera le XAML associé pour vous dans MainPage.xaml fichier comme indiqué ci-dessous.
<UserControl x:Class = "MediaElementDemo.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">
<MediaElement x:Name = "Microsoft_Silverlight_DEMO_mp4"
Margin = "51,49,53,53"
Source = "/Microsoft Silverlight DEMO.mp4"
Stretch = "Fill" RenderTransformOrigin = "0.5,0.5">
<MediaElement.RenderTransform>
<CompositeTransform Rotation = "-18.384"/>
</MediaElement.RenderTransform>
</MediaElement>
</Grid>
</UserControl>
Lorsque l'application ci-dessus est compilée et exécutée, vous verrez que la vidéo est en cours de lecture sur votre page Web.
Contrôle
le MediaElementprésente juste les médias. Il n'offre aucun contrôle de lecteur standard. Il commence à jouer automatiquement et s'arrête lorsqu'il atteint la fin, et il n'y a rien qu'un utilisateur puisse faire pour le mettre en pause ou le contrôler. Donc, dans la pratique, la plupart des applications voudront fournir à l'utilisateur un peu plus de contrôle que cela.
Vous pouvez désactiver la lecture automatique en réglant AutoPlay à False. Cela signifie que le lecteur multimédia ne lit rien tant que vous ne le demandez pas.
<MediaElement x:Name = "Microsoft_Silverlight_DEMO_mp4"
AutoPlay = "False"
Margin = "51,49,53,53"
Source = "/Microsoft Silverlight DEMO.mp4"
Stretch = "Fill" RenderTransformOrigin = "0.5,0.5">
Ainsi, lorsque vous souhaitez lire la vidéo, vous pouvez simplement appeler le MediaElement Play() method. Il propose également des méthodes d'arrêt et de pause.
Regardons à nouveau le même exemple et modifions-le un peu pour permettre un peu de contrôle. Joindre leMouseLeftButtonDown gestionnaire dans MediaElement comme indiqué dans le code XAML ci-dessous.
<UserControl x:Class = "MediaElementDemo.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">
<MediaElement x:Name = "Microsoft_Silverlight_DEMO_mp4"
AutoPlay = "False"
MouseLeftButtonDown = "Microsoft_Silverlight_DEMO_mp4_MouseLeftButtonDown"
Margin = "51,49,53,53"
Source = "/Microsoft Silverlight DEMO.mp4"
Stretch = "Fill" RenderTransformOrigin = "0.5,0.5">
</MediaElement>
</Grid>
</UserControl>
Voici l'implémentation sur le MouseLeftButtonDown gestionnaire d'événements dans lequel il vérifiera que si l'état actuel de l'élément multimédia est plaqué, il mettra en pause la vidéo, sinon il commencera à lire la vidéo.
using System.Windows.Controls;
using System.Windows.Input;
using System.Windows.Media;
namespace MediaElementDemo {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void Microsoft_Silverlight_DEMO_mp4_MouseLeftButtonDown
(object sender, MouseButtonEventArgs e) {
if (Microsoft_Silverlight_DEMO_mp4.CurrentState == MediaElementState.Playing) {
Microsoft_Silverlight_DEMO_mp4.Pause();
} else {
Microsoft_Silverlight_DEMO_mp4.Play();
}
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la page Web vierge car nous avons défini le AutoPlay propriété à False. Lorsque vous cliquez sur la page Web, la vidéo démarre.
Lorsque vous cliquez à nouveau sur la page Web, la vidéo est mise en pause.
L'impression est une capacité importante pour certains types d'applications. Dans ce chapitre, nous examinerons les fonctionnalités pertinentes de Silverlight.
API d'impression et les étapes de base que toutes les applications Silverlight doivent effectuer si elles souhaitent imprimer. Diverses options pour choisir l'impression à l'eau.
Le plus simple est d'imprimer une copie des éléments de l'interface utilisateur qui sont déjà à l'écran.
La plupart des applications voudront être un peu plus avancées que cela et générer un contenu adapté spécifiquement à l'impression, et dans certains cas, il sera nécessaire de diviser le contenu sur plusieurs pages.
Étapes d'impression
Que vous imprimiez un instantané ou quelque chose déjà à l'écran, ou que vous optiez pour une sortie d'impression multipages entièrement personnalisée, les mêmes étapes de base sont nécessaires.
Au cœur de l'API d'impression se trouve la classe PrintDocument.
Vous commencez par en construire un et lorsque vous appelez sa méthode Print, elle affiche l'interface utilisateur standard pour démarrer un travail d'impression.
L'utilisateur peut sélectionner une imprimante et configurer les paramètres comme d'habitude. Si l'utilisateur décide alors de continuer en cliquant surPrint, la PrintDocument soulèvera immédiatement son PrintPage événement, et votre gestionnaire pour cet événement fournit le contenu à imprimer.
L'argument événement offre un PageVisual propriété à cet effet.
Vous pouvez le définir sur n'importe quel élément de l'interface utilisateur Silverlight, soit un élément déjà visible à l'écran, soit un nouveau que vous avez créé spécialement pour l'impression.
Impression d'éléments existants
Éléments L'option la plus simple consiste à imprimer le contenu déjà affiché à l'écran dans votre application Silverlight. Depuis lePrintPage arguments d'événement PageVisual, accepte tous les éléments de l'interface utilisateur, vous pouvez choisir n'importe quoi dans votre interface utilisateur et l'imprimer.
Il ne s'agit que d'un petit pas en avant par rapport à l'utilisation de la touche PrintScreen pour prendre une capture d'écran. C'est légèrement mieux que cela car l'utilisateur n'a pas à coller manuellement la capture d'écran dans un autre programme pour la recadrer et l'imprimer. Ce n'est encore qu'une légère amélioration.
L'impression de contenu déjà affiché à l'écran est problématique.
Tout d'abord, rien ne garantit qu'une mise en page qui fonctionne à l'écran fonctionnera bien pour le papier.
Prenons un exemple simple dans lequel le ScrollViewercontient quelques éléments de l'interface utilisateur et sa mise en page adaptée à l'écran. Il se redimensionne en fonction de la taille de la fenêtre du navigateur et propose des barres de défilement pour s'assurer que tout est accessible même s'il ne rentre pas.
Le code XAML est donné ci-dessous.
<UserControl
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"
xmlns:sdk = "http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk"
x:Class = "SilverlightPrinting.MainPage"
mc:Ignorable = "d"
d:DesignHeight = "300" d:DesignWidth = "500">
<Grid x:Name = "LayoutRoot" Background = "White">
<Button x:Name = "print" Content = "Print" Click = "print_Click" Width = "60"
Height = "20" Margin = "10,10,430,270"/>
<ScrollViewer x:Name = "myScrollViewer"
HorizontalScrollBarVisibility = "Auto"
VerticalScrollBarVisibility = "Auto"
Width = "400" Margin = "90,0,10,0">
<StackPanel>
<Rectangle Fill = "Gray" Width = "100" Height = "100" />
<Button x:Name = "button" Content = "Button" Width = "75"/>
<sdk:Calendar Height = "169" Width = "230"/>
<Rectangle Fill = "AliceBlue" Width = "475" Height = "100" />
</StackPanel>
</ScrollViewer>
</Grid>
</UserControl>
Voici la Print button l'implémentation de l'événement click, qui imprimera le ScrollViewer et ses données visibles.
using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Printing;
namespace SilverlightPrinting {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void print_Click(object sender, RoutedEventArgs e) {
PrintDocument pd = new PrintDocument();
pd.PrintPage += new System.EventHandler<PrintPageEventArgs>(pd_PrintPage);
pd.Print("Print Screen Content");
}
private void pd_PrintPage(object sender, PrintPageEventArgs e) {
e.PageVisual = myScrollViewer;
}
}
}
Comme vous pouvez le voir, dans Print button click event cette PrintDocument objet est créé, nous attachons un gestionnaire à son événement PrintPage.
Vous pouvez définir le PageVisual propriété à laquelle se référer ScrollViewer.
ensuite Print methodest appelé. Cela prend une chaîne, qui apparaîtra comme le nom du travail dans la file d'attente d'impression.
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.
Lorsque vous cliquez sur le Print bouton, vous verrez la boîte de dialogue d'impression standard.
Maintenant, sélectionnez l'imprimante par défaut. Aux fins de démonstration, sélectionnonsOneNote et cliquez sur le Printbouton. Vous verrez queScrollViewer est imprimé.
Notez que les barres de défilement sont toujours visibles sur le ScrollViewer.
Arborescence de l'interface utilisateur personnalisée
Au lieu d'imprimer du contenu déjà affiché à l'écran, il est généralement plus judicieux de créer une arborescence d'éléments d'interface utilisateur spécifiquement pour l'impression. De cette façon, vous pouvez vous assurer que vous n'utilisez que des éléments non interactifs sur papier et vous pouvez créer une mise en page spécialisée mieux adaptée à la forme et au format du papier. Vous pouvez créer un UserControl juste pour l'impression.
Jetons un coup d'œil à un exemple simple en créant un projet Silverlight et en ajoutant un UserControl appelé PrintLayout.
Définissez la largeur et la hauteur de l'heure de conception pour qu'elles soient approximativement en forme de papier. Le code XAML dePrintLayout.xaml fichier.
<UserControl x:Class = "PrintCustomUI.PrintLayout"
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 = "768" d:DesignWidth = "960">
<Grid x:Name = "LayoutRoot" Background = "White">
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition />
<RowDefinition Height = "Auto" />
</Grid.RowDefinitions>
<TextBlock Text = "Silverlight" HorizontalAlignment = "Center"
FontSize = "60" FontWeight = "Bold" FontFamily = "Georgia" />
<TextBlock Grid.Row = "2" Text = "Print Testing"
HorizontalAlignment = "Center" FontFamily = "Georgia"
FontSize = "24" Margin = "0,10"/>
<Rectangle Grid.Row = "2" Height = "1" Fill = "Black"
VerticalAlignment = "Top"/>
<Ellipse Grid.Row = "1" Stroke = "Black" StrokeThickness = "10" Margin = "10">
<Ellipse.Fill>
<RadialGradientBrush
GradientOrigin = "0.2,0.2"
Center = "0.4,0.4">
<GradientStop Color = "Aqua" Offset = "0.006" />
<GradientStop Color = "AntiqueWhite" Offset = "1" />
</RadialGradientBrush>
</Ellipse.Fill>
</Ellipse>
</Grid>
</UserControl>
Ci-dessous est le code dans le MainPage.xaml fichier, qui contient un Print bouton uniquement.
<UserControl x:Class = "PrintCustomUI.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">
<Button Content = "Print..." Height = "23" HorizontalAlignment = "Left"
Margin = "12,28,0,0" Name = "printButton"
VerticalAlignment = "Top" Width = "75"
Click = "printButton_Click" />
</Grid>
</UserControl>
Voici la Click event mise en œuvre pour le bouton d'impression.
using System;
using System.Collections.Generic;
using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Printing;
namespace PrintCustomUI {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void printButton_Click(object sender, RoutedEventArgs e) {
PrintDocument pd = new PrintDocument();
pd.PrintPage += new EventHandler<PrintPageEventArgs>(pd_PrintPage);
pd.Print("Custom");
}
void pd_PrintPage(object sender, PrintPageEventArgs e) {
var pl = new PrintLayout();
pl.Width = e.PrintableArea.Width;
pl.Height = e.PrintableArea.Height;
e.PageVisual = pl;
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante sur la page Web.
Cliquez sur Print et sélectionnez OneNotepour imprimer la mise en page. Vous verrez que la mise en page est imprimée.
Vous pouvez voir qu'il a rempli l'espace disponible. Nous vous recommandons d'exécuter les exemples ci-dessus pour une meilleure compréhension.