Skip to main content

Intégration Blend et WPF

C'est une question qui revient souvent: pour faire travailler efficacement un développeur et un designer ensemble, comment faire en sorte d'intégrer Expression Blend et WPF ou Silverlight ensemble. C'est à dire avoir notamment:

  • Un aperçu réaliste en vue design sous Expression Blend et Visual Studio 2008;
  • L'assistance du designer par Blend pour la liaison de données (data-binding);
  • Un aperçu des données réelles en mode design sous Blend.

La bonne nouvelle, c'est qu'avec Expression Blend 2 SP1 et Visual Studio 2008 SP1, d'énormes progrès ont été faits. Je viens d'avoir plusieurs expériences extrèmement positives sur le sujet avec plusieurs clients.

Il convient de respecter certaines astuces pour que tout se passe au mieux. Les voici.

1. Instancier les objets d'accès aux données dans le XAML. Par exemple, si j'ai une classe DAL.Facture:

<Window ...
   xmlns:data="clr-namespace=DAL;assembly=DAL"
>
    <Window.DataContext>
        <data:Facture Numero="10">
    </Window.DataContext>
    <ListBox ItemsSource="{Binding Details}" />
</Window>

2. Si la déclaration XAML n'est pas suffisante, il suffit d'injecter les données réelles dans le code, du moment qu'elles sont du même type que l'objet déclaré dans le XAML. Par exemple, dans le constructeur de la fenêtre ci-dessus, on peut écrire juste après l'appel à InitializeComponent:

ServiceDistant proxy = new ServiceDistant();
this.DataContext = proxy.GetLatestInvoices();

Dans ce cas, c'est ce code qui prendra le dessus sur le DataContext qui a été indiqué en mode Design

3. Eviter d'hériter de classes autres que Page et Window pour les classes qui sont déclarées en XAML. Même si c'est techniquement possible et bien accepté par WPF, Expression Blend comme Visual Studio ne s'y retrouvent plus.

4. Utiliser les expressions de liaison de données déclaratives. Et si la syntaxe du {Binding} est encore mystérieuse, suivre une formation.

5. Placer le plus d'éléments possible dans le XAML. Bien sûr, il est possible de faire en C# ou VB.NET tout ce qui peut être fait en XAML, mais ce qui est mis dans le C# ou VB.NET n'est pas pris en compte par la vue design.

Corollaire: n'utiliser C# et VB.NET que pour ce qui ne doit pas être vu du designer, comme la logique de l'interface utilisateur (exemple "si l'utilisateur clique sur ce bouton, il faut aller chercher tel jeu de données dans tel service WCF").

6. Si besoin, je peux intervenir quelques heures sur votre projet pour vous aider à intégrer Expression Blend et Visual Studio en WPF ou Silverlight.

Comments

Popular posts from this blog

Gift idea : help your loved ones take their IT skills to the next level

You surely know a special person who works in IT. Learn Kubernetes & Docker enables them to quickly ramp up on those two technologies that one doesn't want to miss in 2021. With smoother operations, better scaling and availability, DevOps tooling, containers and containers orchestration smartly solve many problems that developers and system administrators commonly face. Don't let your loved ones face problems in their IT job : offer them the book that takes them from zero to productive in a matter of days. Grab it now! Get the ebook from Leanpub , Amazon or choose from many retailers . Get the print edition from Lulu .  

Learn Meteor book available

I'm pleased to announce the general release of my Learn Meteor book. It is now available as an ebook or print book from various sources: Learn Meteor print (paperback) on Lulu Learn Meteor ebook on LeanPub Learn Meteor ebook on Barnes & Noble Learn Meteor ebook on iBooks Learn Meteor ebook on Kobo Learn Meteor ebook on Scribd Learn Meteor ebook on Inktera Page Foundry Learn Meteor ebook on 24symbols Learn Meteor ebook on Amazon US Learn Meteor ebook on Amazon UK Learn Meteor ebook on Amazon France Learn Meteor ebook on Amazon Deutschland Learn Meteor ebook on Amazon Canada Learn Meteor ebook on Amazon India Learn Meteor ebook on Amazon Brasil Learn Meteor ebook on Amazon Mexico Learn Meteor ebook on Amazon España Learn Meteor ebook on Amazon Italia Learn Meteor ebook on Amazon Netherlands Learn Meteor ebook on Amazon Japan Learn Meteor ebook on Amazon Australia More sources are coming soon for the print version. Learn Meteor has been a fun expe...

Learn ASP.NET Core: read the book as it is being written

     TL;DR: get the discounted book now using the coupon , then get the full version for free. Thanks to the great acceptance of my previous books, ( Learn WPF MVVM ,  Learn ASP.NET MVC and Learn Meteor ), I'm in the process of writing a fourth one. Learn ASP.NET Core - MVC and DI with .NET Core 1.1 using Visual Studio 2017 teaches you how to quickly get coding using that technology. Just as I did previously, I'm publishing it before it is even finished. Would you like to read it? You can get it for half the price: 50% off the book using that coupon (limited to the first 100 readers and up to august 1st 2017): http://leanpub.com/netcore/c/K9mHH0IzfI2F About 50% of the book is already written, yet it is already available for download as an ebook: PDF, EPUB, MOBI: you choose your format. Over the next days I'll be writing the rest of the book, and publishing updates often. The final book will be ready by au...