Toujours dans ma petite série sur les nouveautés de Silverlight 3 je vais vous présenter aujourd'hui une feature plaisante : les styles cascadés.
En soi rien de nouveau à l'ouest puisque c'est le principe même des feuilles de styles CSS (qui y puisent d'ailleurs leur nom). Mais le CSS s'applique à quelques éléments simples HTML alors que là nous parlons de styles Silverlight, c'est à dire d'objet complexes pouvant définir tout un visuel, animations comprises.
[silverlight:source=/SLSamples/BasedOnStyle/BasedOnStyle.xap;width=405;height=150]
Dans l'application Sivlerlight 3 ci-dessus (fonctionnelle, ce n'est pas une capture écran), vous voyez 4 boutons. Tous sont des boutons standard du framework.
-
Le premier, intitulé "Base SL" possède le style Silverlight par défaut
-
Le second, "Normal" est décoré par le style "BoutonNormal"
-
Le troisième "Gros" est décoré par le style "BoutonGros"
-
Et le quatrième "Alarme" est décoré par le style "BoutonGrosAlarme"
Visuellement c'est plutôt moche, je vous l'accorde, mais le but du jeu est de voir l'effet du cascading styling...
Le style "BoutonNormal" est défini comme suit :
<Style x:Key="BoutonNormal" TargetType="Button">
<Setter Property="Width" Value="90" />
<Setter Property="Height" Value="30" />
<Setter Property="HorizontalAlignment" Value="Left" />
<Setter Property="VerticalAlignment" Value="Bottom" />
<Setter Property="BorderThickness" Value="2"/>
</Style>
Là où les choses deviennent plus intéressantes, c'est dans le style "BoutonGros" ci-dessous où l'on voit apparaître l'attribut BasedOn qui permet de fonder le style courant sur celui qu'on indique :
<Style x:Key="BoutonGros"
BasedOn="{StaticResource BoutonNormal}"
TargetType="Button">
<Setter Property="Width" Value="180" />
<Setter Property="Height" Value="60" />
<Setter Property="FontFamily" Value="Comic Sans MS"/>
</Style>
Enfin, le dernier style se fonde lui-même sur le précédent par le même mécanisme, le niveau de cascading n'étant pas limité. On peut voir notamment que le changement de famille de fonte introduit dans le style "BoutonGros" s'est propagé au style "BoutonGrosAlarme" (fonte Comic).
<Style x:Key="BoutonGrosAlarme"
BasedOn="{StaticResource BoutonGros}"
TargetType="Button">
<Setter Property="Width" Value="160" />
<Setter Property="Height" Value="40" />
<Setter Property="FontSize" Value="18"/>
<Setter Property="FontWeight" Value="Bold"/>
<Setter Property="Foreground" Value="Red"/>
<Setter Property="BorderThickness" Value="4"/>
<Setter Property="BorderBrush" Value="#FFFF0202"/>
</Style>
Voilà, c'est tout simple, mais cela peut radicalement simplifier la création de gros templates pour des applications. Tous les avantages du Cascading Style Sheet de HTML dont l'intérêt ne se démontre plus, mais appliqué à des objets et à la sophistication de Silverlight. Que du bonheur...
Bon Styling,
...Et Stay Tuned !