Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

Benjamin Roux

Silverlight Expert - Silverlight Fan - MVP Client App Dev

Actualités

  • Mon statut Live Messenger :





    View Benjamin Roux's profile on LinkedIn



    Benjamin Roux's Facebook Profile


    MVP Blog Badge.
[Silverlight] Astuce du jour #02 - Mettre son application en Fullscreen

silverlight Dans cette nouvelle astuce nous allons voir comment mettre son application en fullscreen (plein écran) en Silverlight 2.

Pour cela une simple ligne de code suffit

Application.Current.Host.Content.IsFullScreen = true/false;

Il y a seulement un petit problème, notre application a exactement la même taille qu'en mode normal (pour une application avec une taille fixe), il faut donc la redimensionner.

Pour cela nous allons tout d'abord ajouter une transformation de type ScaleTransform à notre Grid principal.

<Grid.RenderTransform> 
    <ScaleTransform x:Name="LayoutRootScaleTransform" /> 
</Grid.RenderTransform>

On ajoute ensuite des membres à notre classe pour stocker la taille initiale de notre application.

double mInitialWidth = 0; 
double mInitialHeight = 0; 
 
public Page() 
{ 
    InitializeComponent(); 
 
    mInitialWidth = this.Width; 
    mInitialHeight = this.Height; 
    [...] 
}

On s'abonne ensuite à l'évènement FullScreenChanged.

Application.Current.Host.Content.FullScreenChanged += new EventHandler(Content_FullScreenChanged);

Et dans la callback on effectue notre transformation.

void Content_FullScreenChanged(object sender, EventArgs e) 
{ 
    double currentWidth = Application.Current.Host.Content.ActualWidth; 
    double currentHeight = Application.Current.Host.Content.ActualWidth; 
 
    double minRatio = Math.Min((currentWidth / mInitialWidth), (currentHeight / mInitialHeight)); 
 
    LayoutRootScaleTransform.ScaleX = LayoutRootScaleTransform.ScaleY = minRatio; 
}

On n'oublie pas de faire en sorte que notre application garde le même ratio en taille (Math.Min) et on applique la transformation.

Remarque : On ne peut pas mettre son application en fullscreen à son instantiation (à l'évènement Loaded par exemple), en effet la mise en plein écran d'une application doit être la volonté de l'utilisateur, de ce fait cela ne fonctionne que dans des évènements mettant en scène ce dernier (clavier [KeyDown...], souris [MouseLeftButtonDown, Click...]).

Contraintes : Une fois l'application en fullscreen, les fonctionnalités du clavier sont réduites, on ne peut capter que les touches directionnelles (flèches), et la barre d'espace.

C'est fini pour cette nouvelle astuce consacrée à Silverlight 2.

Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :
Posted: jeudi 19 février 2009 18:55 par broux
Classé sous : , ,

Commentaires

Pas de commentaires

Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- [SharePoint] Les sessions TechDays 2012… par Le blog de Patrick [MVP SharePoint] le il y a 6 heures et 39 minutes

- TechDays Paris 2012 : Session pleinière jour 3 par Blog Technique de Romelard Fabrice le 02-09-2012, 11:01

- Mishra Reader : un lecteur RSS très Zune Style en Open Source ! par Cyril Sansus le 02-09-2012, 08:28

- [framework 4] Les Tasks et le Thread UI par Fathi Bellahcene le 02-09-2012, 00:33

- Workflow Foundation 3 a un pied dans la tombe par Blog de Jérémy Jeanson le 02-08-2012, 22:15

- TechDays Paris 2012 : Nouvelles tendances du poste de travail - Bring Your own PC par Blog Technique de Romelard Fabrice le 02-08-2012, 19:42

- TechDays Paris 2012 : System Center Service Manager 2012 Vue d’ensemble par Blog Technique de Romelard Fabrice le 02-08-2012, 17:32

- TechDays Paris 2012 : Pleinière second jour par Blog Technique de Romelard Fabrice le 02-08-2012, 16:23

- TechDays Paris 2012 : Retour d'expérience sur la mise en place d'un Cloud Privé par Blog Technique de Romelard Fabrice le 02-08-2012, 16:04

- TechDays Paris 2012 : Comment SharePoint a sauvé mes TechDays par Blog Technique de Romelard Fabrice le 02-07-2012, 23:59