# Tuesday, December 15, 2009

Une conférence sur le C++ et Visual C++ 2010 aux Techdays 2010 ! Dans la partie Architecture et développement, section Outils, langages et Frameworks :

Venez découvrir dans cette session les nouveautés que vous offre Visual Studio C++ tant en termes de développement d'interface graphique qui adhère à Windows 7, qu'en termes de nouveautés du langage qui colle à la norme C++0X. Nous parcourons également quelques fonctionnalités de l'IDE qui permettent à un développeur C++ d'être plus productif.

On dirait que la conférence de Boris Jabes du PDC 09 dont j'ai déjà parlé va être reprise aux techdays. Super !

 

Tags  |  | 
 15 December 2009, 18:59
# Friday, November 27, 2009

J'ai déjà parlé de la conférence Microsoft PDC, et plus particulièrement d'une session sur la manière d'écrire des applications modernes avec Visual Studio 2010.

Malheureusement, elle est en anglais. Alors j'en ai écrit les sous-titres ! Plus d'excuse pour ne pas vous remettre à C++ !

Pour voir cette conférence avec les sous-titres, il faut télécharger la vidéo sur le site microsoftPDC au format Windows Media Video, puis télécharger les sous-titres ici sur mon Skydrive (fichier type TXT de 60 Ko). Il faut que le fichier des sous-titres soit dans le même dossier que la vidéo, et qu'il portent le même nom, à l'extension près. Puis, lire la vidéo avec VLC Media player, le lecteur media bien connu. C'est dommage, Windows Media Player ne permet pas à ma connaissance de lire une vidéo WMV avec des sous-titres. Téléchargez VLC ici sur 01net.net par exemple.


Le fichier sous-titres au format SRT (fichier texte de 60 Ko)

Microsoft PDC presentation Visual Studio 2010 C++

Au menu de cette vidéo, qui présente de nombreuses de façons de moderniser du code C++ :

- Comment utiliser Direct 2D très facilement en C++/MFC pour ajouter des animations et effets visuels "à la WPF".

- Comment ajouter des extensions à Visual Studio dans le nouvel outil d'extension de Visual Studio 2010, plus simple et plus puissant.

- La navigation dans le code et intellisense ont été améliorés pour C++, y compris avec des gros projets. Intellisense fonctionnait beaucoup moins bien avec C++ qu'avec C# dans Visual C++ 2008 .

- Comment utiliser les "r-value" et "move constructors" de C++0x pour améliorer les performances des listes d'objets. Je ne sais pas comment on dit "move constructor" ou "move assignment operator" en français ? A ce sujet, petite précision : il existe deux types d'expressions en C++ : les l-values (left-values, à gauche du signe =, qu'on modifie) et les r-values (right values, à droite du signe =, qu'on ne modifie pas).

- Comment appeler très simplement en C++ une méthode d'un Web Service (WCF, SOAP, Ruby, C++...) défini par son fichier WSDL, et se connecter au Web en quelques lignes de code C++. Ici le programme se connecte au moteur de recherche bing.com. (Ne fonctionne que sous Windows 7)

- Comment étendre MSBuild, le système de génération de projet C++, plutôt qu'utiliser un "post build step", beaucoup moins pratique.

- Comment utiliser le designer de ruban de Visual Studio 2010 pour générer une interface ruban C++/MFC sans écrire de code.

- Le nouveau Class-wizard, qui revient de Visual C++ 6, encore plus puissant et plus agréable à utiliser !

- Comment effectuer facilement certains traitement en parallèle et en tâche de fond pour les rendre plus rapides et agréables à l'utilisateur de l'application avec le nouveau namespace C++ "concurrency". Le traitement parallèle rendu simple pour le programmeur !

- Comment utiliser les expressions lambda de C++0x. C'est un élément incontournable de C++...

- Comment C++ est plus rapide, puissant, et précis que C#. Je crois que Boris Jabe n'aime pas beaucoup C# : en effet, en C# on ne pense pas vraiment à la performance ni à la qualité du code généré... en C++ il faut réfléchir un peu plus ;-)

- A quoi servent les shared_pointers de C++0x et comment utiliser des types de données thread-safe en environnement parallèle.

- Comment utiliser le gestionnaire de crash de Vista et Windows 7 pour récupérer les documents non enregistrés après un plantage. En deux lignes de code avec les MFC !

A suivre...

 

Tags
 27 November 2009, 18:10

Il y a pas mal d'applications qui ont été écrites en C++ natif, avec les MFC. Ou bien avec ATL.

La bonne nouvelle c'est que Visual Studio 2010 nous donne les moyens de moderniser ce genre d'application, et de les remettre au goût du jour.

Avant Visual Studio 2010 on se disait :

" Bon, on a cette application C++/MFC dont l'écriture a commencé il y a 6 ou 10 ans. Maintenant la tendance et les derniers gadgets à la mode sont dans .NET : Winforms ou WPF. Alors on va migrer l'application vers .NET. "

Et commençait un long périple qui avait plusieurs issues possibles, selon les cas. Les exemples cités ici sont de vrais cas, seuls les noms ont été changés ;-) :

1ère solution : les devs prennent la décision de tout réécrire from scratch en WPF (ou en Winform) et arrivent à convaincre leur hiérarchie. Effet tunnel, ça prend deux ans. Il faut payer l'équipe de développement pendant ce temps parce que rien ne sort. Et à la fin, si ça aboutit (des fois ça n'aboutit pas), on a les mêmes fonctionnalités qu'avant. Avec un look and feel plus sympa et moderne quand même. Le marketing râle après le développement : "Quoi ?! Il vous a fallu deux ans pour faire ça ? Et on a quoi de neuf nous à vendre aux clients ? On avait déjà toutes ces fonctionnalités avant". Les développeurs ont passé leurs nuits pour tout refaire en C#. Au moins le code est en .NET, et il est propre. Mais ça a coûté très cher. Entrer dans ce genre d'aventure et s'en sortir n'est possible qu'avec de bons développeurs et un excellent encadrement technique.

2eme solution : Le chef déclare qu'il faut faire une migration vers .NET petit à petit, écran par écran. Pour éviter l'effet tunnel. Alors commence une longue souffrance pour l'équipe de développement. Les écrans vont être réécrits en .NET un par un, et intégrés dans le projet C++ natif avec de l'interop. Au bout de quelques semaines, le chef voit qu'il a des boîtes de dialogue en .NET (Winform par exemple) dans son application. Il a l'air content. Mais il ne voit pas l'usine à gaz en dessous. Si certains développeurs comprennent ce qu'ils font et le font proprement, il peut arriver que d'autres ne comprennent pas bien. Réaliser ce genre d'intégration avec de l'interop n'est pas si simple qu'il n'y paraît. J'ai vu du code C++ natif appeler du code C#, qui rappelait du code natif, qui à son tour appelait du code C#. Je n'ai pas vu de projet conséquent de ce genre arriver à terme. Ca a fini dans un mélange infâme de code natif et managé. Mais des fonctionnalités on pu être ajoutées au projet pendant que des écrans étaient réécrits en C#, et le marketing est content.

Heureusement Visual Studio 2010 propose une autre approche avec de nouvelles fonctionnalités pour les projets C++. Une troisième solution devient possible pour mettre à jour une vieille application C++ ! La mettre au goût du jour avec les nouvelles fonctionnalités proposées dans Visual Studio 2010 !

3eme solution : Quelques programmeurs C++ vont pouvoir changer l'interface utilisateur, connecter l'application au Web, ajouter quelques gadgets sexy, gérer le parallélisme pour profiter des processeurs modernes, etc. Et tout ça en quelques semaines seulement.

La conférence sur Visual C++ 2010 que j'ai citée dans le billet précédent sur la conférence PDC résume comment faire. 

Et puis, j'effectue moi-même en ce moment la migration d'un projet C++/MFC commencé il y a... 16 ans ! Il fonctionne toujours, est très rapide, et consomme très peu de mémoire.

Voici une capture d'écran d'un logiciel écrit proprement en C++ depuis 16 ans, toujours en cours de développement avec VS 2010, et qui ne fait pas son âge.

Oui, on ne dirait pas une application dont l'essentiel du code date de plus de 15 ans...

Je détaillerai très bientôt les étapes à effectuer pour une migration de ce genre dans des billets à venir.

 

 

Tags  |  | 
 27 November 2009, 16:47
# Thursday, November 19, 2009

En ce moment se tient la conférence microsoft pour les développeurs, vous le savez sans doute. Les conférences sont déjà disponibles en streaming HD (merci Silverlight !) ou en téléchargement WMV.

Pendant que tout le monde est en train de parler de Silverlight 4, j'ai quand même noté que Microsoft apporte pas mal de nouveautés à Visual Studio 2010 concernant C++, et qu'il y a plusieurs conférences sur le sujet ! En anglais of course...

Le point d'entrée est sans doute la conférence de Boris Jabe, Accelerated Windows Application Development with Microsoft Visual C++ 2010, qui est à mon sens indispensable pour tout utilisateur du langage C++. Oui c'est en anglais mais je peux faire des sous-titres en français si vous me le demandez ?

Ce développeur de Visual C++ passe en revue les nouveautés de Visual C++, de l'IDE en passant par le langage, et parle notamment des nouveautés concernant le développement parallèle. Je me posais des questions dans mon précédent post sur Visual C++ 2010, des réponses y sont apportées. J'y reviendrai.

Par exemple, les expressions lambda de C++0x facilitent réellement la programmation multitâche. Au sujet du partage de variables entre threads, je voudrais citer de mémoire une phrase de Boris qui m'a bien fait rire : "Une manière de faire est de le faire à la C#, en passant tout en paramètre sans se soucier des performances ni de l'occupation de la mémoire" ;)

D'autres conférence sur le sujet promettent d'être intéressantes, Boris Jabe nous en sélectionne quelques unes dans une de ses slides. Slide affichée dans une application MFC, évidemment ! :D


Boris Jabe présente Visual C++ 2010, et sélectionne quelques conférences que tout développeur C++ devrait regarder !

Rendez-vous sur www.microsoftpdc.com pour les regarder.

 

Tags  |  | 
 19 November 2009, 15:00
# Saturday, October 24, 2009

Visual Studio 2010 apporte son lot de nouveautés pour les développeurs C++ natif avec une nouvelle version des MFC !

Les développeurs en C++ natifs ne sont pas abandonnés, même si la plupart d'entre eux sont morts depuis longtemps ! ;-) Déjà, Visual Studio 2008 avait apporté son lot de nouveautés avec le service pack 1. Peut-être que Microsoft considère que les vrais développeurs, en plus de ne pas manger de quiche, programment en code C++ natif ?

Ribbon Designer

Le plus spectaculaire est le nouveau Ribbon designer. Il permet d'intégrer une interface de type Ribbon (comme celle d'Office 2007, ou de Paint dans Windows 7) dans une application C++/MFC sans coder, de la même manière qu'on intègre un menu. Visual C++ 2010 possède un nouveau type de ressource : le Ribbon. Au même titre que les toolbars, boîtes de dialogues...

Visual Studio 2010 Screenshot Ribbon MFC
Le ribbon-designer de Visual Studio 2010 pour les MFC

(Oui, il faudrait que je refasse la maquette de ce blog !)

Ribbon... mais de quel ribbon parle-t'on ?

Précision : ce ribbon-designer n'est pas destiné à créer des interfaces utilisateurs se basant sur le nouveau contrôle Ribbon-Scenic livré avec Windows 7. Il n'est utilisable qu'en C++ et en utilisant les MFC. L'avantage est que l'application peut s'exécuter à la fois sous Windows XP, Vista et Windows 7.

Comment ça marche ?

La première étape est de créer un Ribbon dans les ressources du projet. Cela crée automatiquement un fichier XML associé. Dans ce seront ajoutés les descriptions des onglets, groupes et contrôles du Ribbon. Un fichier XML, oui. Pas un fichier XAML ! En fait le XML suffit j'imagine...

En éditant le Ribbon, on ouvre le Ribbon-designer. Dans cette fenêtre, on peut glisser-déplacer des onglets, des groupes, des contrôles, créer des sous-menus, affecter des images à des boutons, créer les commandes pour associer le code à l'interface... bref, effectuer le design de l'interface.

Visual Studio 2010 Screenshot Ribbon MFC
Modification des propriétés d'un bouton du ribbon

L'éditeur de Ribbon génère un fichier XML décrivant l'interface utilisateur. Lors de la compilation du projet, ce fichier XML est inclus dans les ressources, et donc dans le binaire. Pour charger le ribbon dans la fenêtre principale, trois lignes de code suffisent :

CMFCRibbonBar m_wndRibbon;

m_wndRibbon.Create(this);
m_wndRibbon.LoadFromResource(IDR_RIBBON);

On dirait du code C# tellement c'est simple, n'est-ce pas ? :-D Et puis, pour une fois dans la rubrique "je crée une interface en 5 minutes", les développeurs C++ natifs sont privilégiés par rapport à leurs homologues C# car ce designer n'existe que pour du code C++. Il n'en existe pas de version pour Winform ni pour WPF/Silverlight dans Visual Studio 2010 .

Le Ribbon est disponible avec plusieurs looks. En plus des looks présents dans Visual Studio 2008 (ceux avec les bouton rond, comme dans Office 2007), un nouveau look ressemblant au Ribbon de Windows 7 a été ajouté. Et, fin du fin, il est possible de changer de look à la volée, pendant l'exécution du programme.

Voici deux captures d'écran de la même application. Le look a été modifié grâce au menu Style en haut à droite du ribbon.


Application C++/MFC avec Ribbon look Office 2007 black

 


Application C++/MFC avec Ribbon look Windows 7

 

Sauvegarde automatique des documents en cas de plantage

Imaginez, vous saisissez un document et votre application C++/MFC plante. Votre travail est perdu ? Non ! Les classes MFC de Visual Studio 2010 contiennent un gestionnaire de sauvegarde automatique (sérialisation automatique des documents toutes les 5 minutes par défaut si l'option est activée). En cas de plantage, le crash est intercepté et le travail en cours est copié dans des fichiers temporaires. Au prochain lancement du programme, les MFC proposeront automatiquement d'ouvrir les fichiers temporaires et de restaurer le travail interrompu.

Cette fonctionnalité est très simple à mettre en oeuvre si l'on respecte l'architecture générale des MFC. Il s'agit de mettre en place quelques callbacks. Je ne l'ai pas encore testée, mais dès que je le fais je mets le code en ligne. Ce filet anti-plantage est supporté sous Vista et Windows 7, pas sous Windows XP : le système d'exploitation effectue une partie du travail en interceptant le plantage.

 

Support dans les MFC des interactions avec la barre des tâches de Windows 7

Encapsulation des interactions avec la taskbar win7 dans les MFC pour faciliter l'intégration avec Win7.

Une nouvelle fonction toute simple a été ajoutée à la class CWinApp :

   EnableTaskbarInteraction(TRUE);

Elle permet d'afficher dans la barre des tâches de Windows 7 les différentes fenêtres MDI de l'application dans des miniatures différentes, comme Internet Explorer 8 le fait, ainsi que la liste des documents récents En une seule ligne de code !

Cette fonctionnalité n'a pas l'air d'être complètement terminée dans cette version béta 2. En attendant la version finale, pour illustrer l'intégration d'une application dans la barre des tâches de Windows 7, voici une capture d'écran de MSN Messenger !

 

Les TaskDialog aussi simples à utiliser que les MessageBox

Les MFC incluent le support des Task Dialogs apparues avec Windows Vista d'une manière élégante et très simple à mettre en oeuvre. Il est recommandé de les utiliser le plus souvent possible à la place des MessageBox.

Voici le code correspondant :

INT_PTR nResult = CTaskDialog::ShowDialog(
   _T(
"Choisissez si vous souhaitez enregistrer vos modifications ou non."), 
   _T(
"Vous n'avez pas sauvegardé votre travail."), 
   _T(
"Budget"), IDS_SAVE_YES, IDS_SAVE_CANCEL, TDCBF_CANCEL_BUTTON);

Plus d'infos sur le site MSDN.

 

Autres fonctionnalités, intégration des applications dans le système

En vrac :

  • Les MFC sont compatibles avec les périphériques multitouch. Les MFC génèrent correctement les évènements correspondants à ces périphériques.
  • Intéractions avec le système de recherche de Windows : les types de documents propriétaires gérés par une application MFC peuvent être indexés par Windows pour la recherche dans les documents de Windows.
  • Les MFC peuvent générer des miniatures des documents compatibles avec les miniatures de l'explorateur de Windows.

C'est tout. Pour le moment.

 

Tags  |  | 
 24 October 2009, 00:34
# Wednesday, October 21, 2009

Il a été annoncé que les abonnés MSDN pouvaient obtenir la béta 2 de Visual Studio 2010 sur le site MSDN. Quant à ceux qui n'ont pas d'abonnement MSDN, ils peuvent télécharger la béta 2 ici sur le site Microsoft.com.

Il est possible d'installer VS 2010 à côté de VS 2008, sur la même machine. Les deux environnements fonctionnent indépendamment sans problème. Pratique (indispensable ?) pour migrer les projets.

Cependant il y a un petit bug dans le setup de VS2010 qui se produit si vous avez installé le SDK de Silverlight 3 RTM. A la fin de l'install, vous aurez ce message d'erreur :

Visual Studio 2010 setup problem with Silverlight

Tout s'est bien passé, sauf que VS 2010 veut installer "Silverlight 3 SDK GDR 2" (General Distribution Release 2, qui date de fin août 2009), et qu'il n'arrive pas à l'installer si vous avez déjà "Silverlight 3 SDK RTM". Problème de conflit de version donc. Car il existe déjà 3 versions de Silverlight 3 (voir les détails sur le blog de Tim Heuer) :

  • RTM: 3.0.40624 (La version dont "tout le monde" a installé le SDK)
  • GDR 1: 3.0.40723
  • GDR 2: 3.0.40818 (La dernière version que "personne" n'a vu passer)

    La solution... est de désinstaller "Microsoft Silverlight 3 SDK" par le panneau de contrôle AVANT d'installer VS 2010 beta 2.

    Si vous avez déjà installé VS 2010 et obtenu ce message d'erreur, vous avez peut-être constaté que Silverlight a l'air de fonctionner correctement avec VS 2010. En fait, tout est OK, sauf que vous n'avez pas la toute toute dernière version du SDK de Silverlight. Microsoft conseille de désinstaller Silverlight 3 SDK et de réinstaller VS 2010... Voir sur le blog de Mike Snow.

    Mais j'imagine qu'on peut simplement installer le SDK Silverlight 3 GDR2 après avoir désinstallé le SDK Silverlight 3 RTM si on désire vraiment avoir le tout dernier SDK de Silverlight 3...

  •  21 October 2009, 22:50
    # Thursday, July 23, 2009

    Depuis le Feature Pack (et SP1) de Visual C++ 2008, les MFC contiennent un ruban ("ribbon") similaire à celui que l'on trouve dans Office 2007. On pouvait écrire des applications en utilisant cette fonctionnalité des MFC, comme cet exemple :


    Le contrôle "ribbon" des MFC

    Il se murmurait à l'époque de la sortie de ce Service Pack, que l'interface de type Ruban serait très courante sous Windows 7, comme je l'écrivais ici il y a plus d'un an.

    Eh bien Windows 7 contient un contrôle Ribbon par défaut, le "ScenicRibbon". Il n'a pas tout a fait le même look que celui des MFC. Le problème, c'est que le Ribbon de Windows 7 n'est pas le même que celui des MFC !


    Le contrôle "Ribbon" de Windows 7

    Ces deux éléments sont totalement distincts et ne se programment pas de la même façon. Celui de Windows 7 utilise un fichier XML pour décrire les onglets, boutons... Par exemple, pour créer deux bouton "Copier" et "Coller" dans un groupe :

       <Group CommandName="cmdEdit" SizeDefinition="TwoButtons">
          <
    Button CommandName="cmdCopy" />
          <
    Button CommandName="cmdPaste" />
       </
    Group>

    Le SDK de Windows 7 inclus un outil pour compiler ce fichier XML de description d'interface. Ca ressemble à du XAML, mais ce n'en est pas ! C'est une sorte de fichier Ressource en XML, utilisé en code natif ! La documentation du ScenicRibbon de Windows 7 est ici sur MSDN.

     

    Par contre, pour ajouter un bouton ou un groupe dans le Ribbon des MFC, il faut écrire du code "en dur" dans le programme, comme par exemple :

       // Crer le panneau "Presse-papiers":
       strTemp.LoadString(IDS_RIBBON_CLIPBOARD);
       CMFCRibbonPanel* pPanelClipboard = pCategoryHome->AddPanel(strTemp, m_PanelImages.ExtractIcon(27));

       // Crée le bouton "Coller"
       strTemp.LoadString(IDS_RIBBON_PASTE);
       CMFCRibbonButton* pBtnPaste =
    new
    CMFCRibbonButton(ID_EDIT_PASTE, strTemp, 0, 0);
       pPanelClipboard->Add(pBtnPaste);

       // Crée le bouton "Couper"
       strTemp.LoadString(IDS_RIBBON_CUT);
       pPanelClipboard->Add(
    new CMFCRibbonButton(ID_EDIT_CUT, strTemp, 1));

    Le contrôle "Ribbon" devient presque incontournable. Celui de Windows 7 est beaucoup plus flexible à programmer. Il est quand même plus facile et souple de décrire une interface utilisateur en XML que d'écrire du code C++ en dur ! Au point que si une DLL redistribuable du Ribbon Windows 7 était disponible pour Vista et XP, on jetterait bien vite le Ribbon des MFC à la poubelle. Le problème est qu'apparamment le Scenic Ribbon ne sera disponible que pour Vista et 7, pas pour XP (http://channel9.msdn.com/pdc2008/PC14/).

    Et, pour une fois, les programmeurs natifs C++ sont avantagés par rapport aux programmeurs Winform. Le framework .NET ne contient pas (encore) de ribbon. Mais Microsoft propose un Ribbon en add-in pour WPF, que l'on peut télécharger, en plus de .NET 3.5 : http://windowsclient.net/wpf/wpf35/wpf-35sp1-ribbon-walkthrough.aspx

    Evidemment je ne mentionne pas les différents éditeurs de composants payants pour MFC (Codejock, BCG) ou .NET (Infragistics...) qui proposent des ribbons.

    Tags  |  | 
     23 July 2009, 17:23
    # Saturday, March 21, 2009
    La nouvelle version de Silverlight 3 vient d'être dévoilée en version beta depuis quelques jours. Le site www.silverlight.net centralise toutes les infos et outils de développement.

    Découvrir Silverlight 3 : l'ebook !

    Laurence Moroney (son blog ici) a publié il y a quelques mois un livre sur Silverlight 2 en anglais, traduit en français chez Microsoft Press. Un bon bouquin pour découvrir Silverlight.

    Découvrir Silverlight 2, de Laurence Moroney

    Incroyable, une suite de ce livre est déjà disponible sous la forme d'un ebook en PDF pour Silverlight 3 : First look : Microsoft Silverlight 3.

    Sommaire de "First look : Microsoft Silverlight 3" :
    • 3D Effects with Perspective Transforms
    • Animation Easing
    • H264 Video Support
    • Pixel Shaders
    • Out-of-Browser Applications
    • Save File Dialog Box
    • XAML Element Databinding

    Les applications Silverlight arrivent sur le desktop (pour remplacer WPF ?)

    La possibilité d'installer des applications Silverlight sur le PC, et de les exécuter comme des applications indépendantes est une petite révolution dans le monde du développement d'applications desktop. Silverlight se met à marcher sur les plates-bandes des applications desktop C#/.NET classiques (Winforms ou WPF)... et peut-être même des applications MFC/C++ natives.

    Evidemment, Winforms, WPF, et C++ natif ont leur spécificités et peuvent être des environnements irremplaçables dans certains cas.

    Mais pour le développement d'une nouvelle application, ou la migration d'une application existante, Silverlight peut être envisagé comme une alternative crédible à Winforms, WPF et même C++. Surtout si l'application doit être disponible à la fois en ligne et hors ligne.

    Pour caricaturer, on pourrait dire qu'une application Winforms est déjà démodée, qu'une application WPF ne sera pas forcément très rapide et nécessitera de grosses configurations matérielles pour fonctionner, et que l'application C++ aura beaucoup de mal à fonctionner via Internet. Mais Silverlight 3 aura des limitations dans ses fonctionnalités qui pourront être rédhibitoires.

    Winforms, WPF, C++ natif, Silverlight : 4 technos de développement d'applications. Sans parler d'Adobe Flex !

    D'ailleurs il se murmure que WPF pourrait être une victime collatérale de la guerre que se livrent Microsoft avec Silverlight, et Adobe avec Air : WPF est un Silverlight en beaucoup plus lourd, et son seul avantage est qu'il a un runtime plus puissant (voir l'article : Silverlight 3 might kill WPF par exemple). Tim Sneath a écrit un article très intéressant sur les différences entre les runtime Silverlight et .NET classique. En le lisant je me dis que ma foi, Silverlight a l'air bien fichu de l'intérieur.

    Tags  |  | 
     21 March 2009, 00:15
    # Friday, February 20, 2009

    Vous le savez peut-être, le moteur de recherche et hébergeur Lycos a fermé ses portes. Ils ont fait piquer le chien. Pauvre bête.

    Le problème c'est que le nom de domaine blogmfc.com était enregistré chez eux ; j'utilisais Lycos comme registrar. Du coup ce site n'était plus accessible pendant plusieurs jours. Il a fallu que je change de registrar. C'est moins facile que de changer d'hébergeur. Enfin c'est fait.

    BlogMFC is back, même si mon travail actuel ne porte plus qu'en partie sur le C++ et les MFC. Eh oui, .NET et Internet déciment les projets C++. Ces derniers ne sont pas tous morts, mais ils deviennent de plus en plus réservés à certains domaines particuliers. Ou alors ils survivent le temps de migrer vers .NET, et/ou vers Internet...?

     

    Tags
     20 February 2009, 14:14
    # Thursday, January 08, 2009
    Vous le savez bien sûr : il existe plusieurs façons de compter les années, en fonction du calendrier que l'on utilise. Dans notre calendrier grégorien, nous sommes en 2009. Mais il existe d'autres calendriers : hébreux, islamique, révolutionnaire, et, celui que l'on consulte tous les jours, le calendrier Windows :


    Le calendrier Windows affiche l'an 7 beta 1

    Dans le calendrier Windows, nous sommes en l'an 7 béta 1 depuis hier, quand Steve Balmer a officiellement annoncé la disponibilité de Windows 7 beta 1. Alors bonne année 7 béta 1 ! Et, également, comme ce blog a été un peu désert ces derniers temps, bonne année grégorienne 2009 !

    La durée d'une année Windowsienne est maintenant d'exactement trois années terrestres, grâce à la poigne de Steven Sinovsky[^] : la Terre effectue exactement 3 rotations autour du soleil entre deux versions de Windows. Avant, c'était beaucoup plus aléatoire, et il fallait attendre la fin de l'année Windowsienne pour savoir qu'elle touchait à sa fin.

    Bonne et joyeuse année 2009 7 beta 1


    Tags  | 
     8 January 2009, 15:38
    # Sunday, August 31, 2008
    Il y a deux semaines j'avais râlé parce que le code source de .NET n'était plus disponible avec VS 2008 SP1. Eh bien c'est désormais en partie corrigé. Une partie du code source de .NET 3.5 SP1 vient d'être rendu disponible en cette fin août par Microsoft. Cela veut dire que désormais l'on peut deboguer et tracer dans le Framework .NET 3.5 SP1 avec VS 2008 SP1. C'est annoncé sur le nouveau blog Microsoft du Source Code Center.

    Par contre, la procédure indiquée sur ce blog est valable pour VS 2008, et n'a pas été mise à jour pour VS2008 SP1 ! ;) Cela viendra sans doute bientôt.

    Dans VS 2008 SP1, il y trois options à cocher pour récupérer le code source de .NET, contre deux dans VS 2008 :


    Trois options pour obtenir le code source de .NET 3.5 SP1

    Si ce n'est pas la première fois que vous utilisez cette fonctionnalité, vous devez vider le dossier cache dans lequel les sources sont stockés pour provoquer un nouveau téléchargement des sources et des symboles à jour :


    Le dossier cache où sont stockés les sources de .NET

    La plupart du code source n'est pas encore disponible. Le code source de WPF, notamment, n'est pas encore mis à disposition. Cela viendra bientôt, comme annoncé sur le blog Microsoft du Source Code Center.

    Mais pourquoi est-ce que le code de WPF 3.5 SP1 n'est-il toujours pas disponible ? Il nécessite tant de correction que cela avant de sortir de chez Microsoft ? Il y a peut-être des commentaires dans le code à supprimer, du style :

        // with this workaround, we can send Adobe Air to hell

    Mystère... ! ;)

    Tags  | 
     31 August 2008, 16:35
    # Wednesday, August 27, 2008

    De nombreux Datagrid sont disponibles pour WPF

    Microsoft vient de sortir une version "béta" (CTP) de son contrôle Datagrid utilisable avec WPF 3.5 SP1. Ce contrôle est disponible avec son code source sur www.codeplex.com/wpf, et Jaime Rodriguez en a posté un exemple d'utilisation.

    Pourtant, ce contrôle Datagrid n'est pas destiné à faire concurrence aux Datagrid WPF édités par des éditeurs de composants. Il devrait rester assez simple : ce n'est pas de l'intérêt de Microsoft de tuer les éditeurs de composants ! Par contre le code source du Datagrid Microsoft est disponible gratuitement, alors qu'il est relativement cher ou carrément non disponible chez les éditeurs tiers.

    Il existe plusieurs contrôles Datagrid chez différents éditeurs :

    Michael Sync a réalisé un banc d'essai des Data Grid de ces éditeurs.

    J'ai été surpris de constater qu'Infragistics n'était pas vraiment à la hauteur dans ce domaine précis, alors que ses composants sont renommés. Manque de maturité du produit sans doute.

    Xceed Data grid control
    Une vue du Data Grid de Xceed

    Xceed a été le premier a sortir un Data Grid pour WPF. Cette expérience lui vaut d'être sans doute le Data grid le plus utilisé par la communauté des développeurs WPF. La version 3.0 de ce contrôle vient tout juste de sortir, avec des visualisations en 3D. Et d'après Michael Sync et les commentaires de l'article, Xceed est sans doute le meilleur Data Grid actuellement, avec celui de Telerik. Cerise sur le gâteau, Xceed propose une version Express gratuite.

    Trop lents !

    Mais gros, gros problème : la performance. Ces contrôles Datagrid pour WPF sont très jolis, avec des skins, des effets 3D, mais... qu'est-ce qu'ils sont lents ! A un point qu'ils peuvent être considérés comme inutilisables... Sur les forums des éditeurs, des clients demandent conseil à propos de la lenteur d'affichage, et il leur est répondu que l'amélioration des performances est un sujet prioritaire.

    Le Datagrid de Microsoft est encore plus lent que celui de Xceed, selon mes tests personnels très subjectifs. Le scroll est catastrophique, et l'impression de lenteur générale est assez pénible (sur un Core 2 Duo 2,4 Ghz avec 2 Go de RAM). Ces pauvres performances expliquent sans doute pourquoi le Datagrid n'a pas fait partie de la version 3.5 SP1 de .NET.

    Que faire ?

    Qu'en conclure ? Ne pas utiliser de Datagrid sous WPF, tout simplement ! ;)

    Peut-être que le concept de Datagrid est très lié et très adapté à .NET 2 et Windows Form. Datagrid = Winform + .NET 2.0 ? Il existe de très jolis DataGrids maintenant pour Windows Form.

    Et alors comment présenter des données sous WPF ? Le Datagrid n'est sans doute pas adapté. Sous WPF, il faut chercher d'autres manières de présenter les données. De nouvelles "expériences utilisateur" sont à créer. Avis aux amateurs. Billy Hollins présente une telle application WPF en video. Ci dessous, deux écrans représentant un design maître-détail :


    La liste de clients : une liste non éditable


    Le détail d'un client

    Cette approche est très représentative de la manière de concevoir une application WPF : il faut bien connaître les fonctionnalités et les possibilités de la plate-forme, puis se "laisser porter" par ces possibilités pour concevoir une interface utilisateur adaptée. Tout un programme !

     

    Tags
     27 August 2008, 00:22
    # Tuesday, August 26, 2008

    Si vous avez acheté un iPod ou un iPhone, vous l'avez sans doute constaté : des logiciels dont vous n'avez pas besoin se sont sournoisement installés sur votre PC.

    Heureux possesseur d'un baladeur Apple, vous devez installer le logiciel iTunes sur votre PC. C'est écrit sur la boîte, on est prévenu.

    Par contre, ce qui n'est pas écrit, c'est que pour télécharger des applications gratuites ou des mises à jours pour votre iPod/iPhone, vous devez fournir un numéro de carte bancaire à Apple.

    Et toute une floppée de logiciels sont installés par Apple sur votre PC sans votre permission.


    Les applications installées sans permission avec iTunes

    En voici la liste (non exhaustive) :

    • le navigateur Web Safari (j'ai déjà IE et Firefox, merci)
    • QuickTime (je me demande quelle est son utilité, j'ai déjà Media Player)
    • Bonjour (Bonjour, à quoi servez vous ?)
    • Un logiciel de mise à jour qui, si jamais vous avez réussi à ne pas installer Safari la première fois en décochant les bonnes options, vous proposera encore et encore de l'installer jusqu'à ce que vous disiez oui par inadvertance. Il vous aura à l'usure !
    • Le client pour le service payant de location d'espace Web "Mobile Me". Ce dernier est installé dans le panneau de configuration.


    Mobile Me s'installe silencieusement dans le panneau de contrôle de Windows

    Ah, ce service Mobile Me ! C'est un abonnement (100$/an) pour disposer d'un espace de stockage en ligne. Comme vous avez déjà fourni votre numéro de carte bancaire à Apple, il ne suffit que de quelques clics pour y souscrire. Mobile Me est un concurrent payant de Windows Live Mesh, ce dernier étant gratuit. Mais Mobile Me ne fonctionne pas très bien...

    Le moins que l'on puisse dire c'est que Apple est vraiment sournois. Donc me voici maintenant à empêcher Apple de lancer des services et des programmes résidents qui ne me servent pas...

     

    Tags
     26 August 2008, 18:19
    # Monday, August 18, 2008

    Microsoft a profité de ce que j'avais le dos tourné (voir photo ci-dessous), pour sortir une mise à jour SP1 pour Visual Studio 2008 et aussi pour .NET 3.5. A peine rentré des Alpes Suisse, je me jette évidemment sur MSDN pour télécharger la bête.

    Le lac Thunsee, dans les Alpes Suisses, près de Bern.</
    Le lac Thunsee, dans les Alpes Suisses, près de Bern.

    Le SP1 de Visual Studio 2008 est dispo pour les versions gratuites (express) et professionnelles de Visual Studio. En anglais et en français. Pour télécharger le SP1, c'est ici pour les versions pro ou ici pour les versions express. Après avoir accepté le contrat-de-licence-qu'on-ne-lit-jamais, le programme d'installation se débrouille tout seul. Environ une heure après (quand même), me voici avec la version RTM du SP1 de .NET 3.5 et de Visual Studio 2008 :

    A propos de Visual Studio 2008 SP1

    Il y a déjà eu pas mal d'articles sur les nouvelles fonctionnalités apportées par ce SP1 en français sur le blog de Mitsu ou en anglais : la liste entière des modifications est dans la base de connaissance de Microsoft : http://support.microsoft.com/kb/945140. Plein de trucs sur ASP.NET, WPF, Linq, etc. Aussi, les applications WPF se lancent plus rapidement, c'est clair.

    Le nombre de fonctionnalités ajoutées est impressionnant. Surtout pour .NET 3.5 SP1, il s'agit plus d'une nouvelle version que d'un Service Pack ! .NET 3.5 SP1 contient la version 3 de WPF, après WPF 1 sorti avec Vista et .NET 3.0, WPF 2 sorti avec Visual Studio 2008 et .NET 3.5.

    Le SP1 pour Visual C++

    Le SP1 de Visual Studio 2008 contient les nouveautés déjà présentées dans VC++ 2008 Feature Pack (la nouvelle version des MFC, et C++ TR1). Mais comme le VC++ 2008 Feature Pack est sorti il y a quelques mois déjà, le SP1 de Visual Studio y apporte de nombreux correctifs dans le compilateur C++ (bugs corrigés), dans les extensions TR1, ainsi que dans les MFC (voir http://blogs.msdn.com/vcblog)

    Si vous avez déjà installé VC++ 2008 Feature Pack, il est donc conseillé d'installer en plus Visual Studio SP1, car ce dernier contient une mise à jour du Feature Pack.

    Autrement dit, le Feature Pack est à mettre à la poubelle, il est remplacé par le SP1 de Visual Studio.

    Un Datagrid dans WPF 3.5 SP1 !

    Il manquait un contrôle datagrid dans WPF. Plusieurs éditeurs indépendants ont fourni des contrôles Datagrid, payants ou gratuits (Xceed ou Infragistics). Ce grand manque est désormais comblé... d'une manière originale. Microsoft propose un Toolkit WPF en téléchargement sur le site www.codeplex.com/wpf. Ce toolkit contient entre autres, un datagrid, et nécessite WPF 3.5 SP1 pour fonctionner. Le code source est même disponible !

    Comme Microsoft aime bien les fournisseurs de composants indépendants, il ne va pas trop leur faire concurrence. Le Data Grid de WPF ne sera jamais aussi puissant que le Data grid payant d'Infragistics par exemple. Même si la version actuelle est encore en CTP, il ne faut pas s'attendre à voir ce contrôle devenir le meilleur des datagrid du monde ! Mais il peut rendre des services...

    Le blog de Jaime Rodriguez contient une série d'articles sur l'utilisation de ce nouveau contrôle Data Grid pour WPF :


    Un exemple d'utilisation par Jaime Rodriguez du nouveau contrôle Data Grid de WPF

    Ce Toolkit WPF contient également un outil pour pouvoir construire plus facilement des Pixel Shaders. Il y en a qui vont s'amuser comme des petits fous ! Toutes les infos sur ce nouvel outil sur le blog de Greg Schechter, le "spécialiste" des Pixels Shaders en WPF.

    Le code source du framework .NET 3.5 SP1 pas encore disponible

    Depuis quelques mois, il était possible avec Visual Studio 2008 d'utiliser le code source du framework .NET 3.5. en mode Debug. Visual Studio 2008 sait télécharger le code source d'une partie de .NET pour le mettre à disposition de tout programmeur .NET, comme expliqué par exemple par ClaueR.

    Les nouvelles options de téléchargement du code du framework .NET
    Les nouvelles options de téléchargement du code du framework .NET

    Avec Visual Studio 2008 SP1, les options de téléchargement du code source du framework .NET sont mieux pensées, mais le problème est que le code source de .NET Framework 3.5 SP1 n'est pas encore disponible ! Des fichiers PDB sont présents, mais ils ne contiennent pas (encore ?) les informations sur le code source.

    Alors, si vous avez absolument besoin d'utiliser le code source du framework .NET 3.5 en mode debug, n'installez pas encore le SP1 ! Attendons que Microsoft mette en téléchargement le code source de la dernière version de .NET.

    Nouveautés du mode debug (managed)

    En mode pas à pas, le menu contextuel (clic droit de la souris) contient des entrées supplémentaires. Le très pratique "Step into Specific" est disponible sur un appel de fonction, et permet de spécifier comment tracer à l'intérieur de la dite fonction.


    Nouveau menu contextuel en mode debug

    Il y a beaucoup d'autres nouveautés dans ce SP1, à télécharger d'urgence donc. Sauf si l'on a besoin d'utiliser le code source du framework .NET pour l'instant.

    Tags  |  |  | 
     18 August 2008, 17:47
    # Tuesday, July 22, 2008

    Maintenant que XP n'est (quasiment) plus disponible, Microsoft lance une grande campagne de pub pour Vista. Marrant :

    Le temps est venu de connaître la vérité : il faut maintenant utiliser Vista plutôt que XP[^].

    Pourtant, un livre à succès[^] affirme qu'avec Internet, le monde est plat, la preuve :

    Il est plat ou pas le monde maintenant ? Alors, qui croire ? Microsoft, ou bien Thomas Friedman ??

    En fait, la vérité est ailleurs : des petits malins[^] qui trouvent Vista trop lent, ont déjà parodié cette pub, (référence à X-Files[^], le film) :

    Tags  | 
     22 July 2008, 18:21
    # Wednesday, June 25, 2008


    Un peu de musique pendant qu'on se recueille pour la mort de XP

    Dans une lettre adressée aux utilisateurs de Windows[^] (1 milliard de personnes), Bill Veghte, Vice President de Microsoft, a annoncé le 24 juin la mort officielle de Windows XP. Un moment de recueillement pour un système qui a vécu 7 ans (l'espérance de vie d'un lion[^] est entre 7 et 14 ans).

    Enfin, mort, cela veut dire qu'il ne sera plus vendu à partir de ce soir. Ou demain matin à 05h59, pour Dell[^]. En tous cas plus du tout à partir du 30 juin. Sauf cas exceptionnel.

    Mais il sera encore supporté par Microsoft pendant près de 6 ans[^] (encore 9 mois de support "normal", puis ensuite, seulement les mises à jour de sécurité pendant 5 ans). Comme ça, si vous venez de l'acheter, vous aurez encore des mises à jour avant que votre PC ne rende l'âme. Ca veut dire aussi que si vous développez des logiciels, vous risquez d'avoir ENCORE des clients sous XP pendant 5 ans.

    5 ans encore ! Horreur, malheur ! Imaginez la tête d'un type au support technique, quand un client appellera, début 2014, pour annoncer : "euh, oui, j'ai un problème là, avec votre logiciel, je suis sous XP, que puis-je faire ?". Ah ah ah !


    La tête d'un type au support technique, début 2014,
    quand un client appellera pour signaler un problème sous Windows XP.

    D'ici là, Windows 7 sera sorti. Officiellement, et toujours d'après cette même lettre[^], Windows 7 sera disponible trois ans après Vista. Donc cela donne : sortie officielle en Janvier 2010, disponibilité pour les professionnels fin 2009, et versions béta largement disponibles dans moins d'un an.

     

    Tags
     25 June 2008, 15:21

    Le nouveau livre sur les MFC de PackT PublishingNooooonnnn ? Un NOUVEAU livre sur les MFC ?? Aucun livre n'était sorti sur les MFC depuis... au moins... trois siècles !

    Evidemment, il est en anglais... Après la fermeture de O'Reilly-France, nous n'aurons plus beaucoup de livre informatique en français...

    Ce livre de 370 pages devrait être disponible d'ici quelques jours, soit en version PDF directement sur le site de l'éditeur[^], soit en version papier. Bientôt disponible sur Amazon également.

    C'est un livre pour apprendre comment utiliser les MFC, pour ceux qui connaissent un peu le C++, ou qui ont déjà programmé des applications Windows en C#.

    Les principaux concepts des MFC sont expliqués et mis en pratique dans des exemples concrets d'applications simples.

    Bref, il a l'air bien pour se mettre (ou se remettre!) aux MFC.

    Il coûte 31,49 euros, et les frais de port sont gratuits vers la France depuis le site de l'éditeur[^].

    Tags  | 
     25 June 2008, 12:51
    # Wednesday, June 11, 2008

    Impressions

    Après plus de deux semaines d'utilisation des SP1 de Visual Studio 2008 et de .NET 3.5, je n'ai rencontré aucun problème. Pourtant j'ai fait une utilisation intensive de C#/WPF et aussi de C++ (natif).

    Le truc qui ne fonctionne plus, c'est le debogage dans le code source de .NET. Forcément : le code source de .NET 3.5 SP1 n'est pas encore disponible. Il faudra sans doute attendre au moins la sortie de la version RTM de .NET 3.5 SP1.

    Je n'ai pas pu utiliser Silverlight depuis deux semaines, car les extensions Silverlight 2 beta 1 pour Visual Studio étaient incompatibles avec VS2008 SP1. Mais ceci était indiqué et documenté. La beta 2 de Silverlight 2 qui est sortie le 6 juin fonctionne très bien avec Visual Studio 2008 SP1. Plus d'incompatibilité entre Silverlight et Visual Studio ! Je vais pouvoir continuer à m'amuser avec Silverlight avec mon fils.

    .NET 3.5 SP1 était censé accélérer le chargement des applications WPF. Je n'ai pas spécialement remarqué de différence, disons que ce n'est pas flagrant. Mais ceci n'est qu'une remarque subjective. Ou alors je ne suis pas encore satisfait des performances de WPF. Allez, M. Microsoft, encore un effort !

    J'aurais voulu tester les shaders en WPF/SP1, mais pas eu le temps. Faire des filtres graphiques qui utilisent la carte 3D, et utiliser ces filtres en XAML est une des raisons pour lesquelles WPF est prometteur, malgré ses défauts (de jeunesse). Une très bonne série d'articles ici sur la réalisation d'effets graphiques en utilisant l'accélération matérielle.

    Desinstallation

    La désinstallation de VS 2008 SP1 et .NET 3.5 SP1 est laborieuse, mais on y arrive ! Pour revenir à VS 2008 standard, il faut successivement désinstaller tout ça (la liste est dans le fichier readme.htm de Visual Studio 2008 SP1) :

    Uninstall the following list of updates, in the order shown:

    1. Microsoft Visual Studio Team System 2008 Team Suite - Service Pack 1 (KB945140)
    2. Microsoft Visual Studio Team System 2008 Team Suite - Service Pack 1 (KB948560)
    3. Microsoft Visual Studio Team System 2008 Team Suite - Service Pack 1 (KB947888)
    4. Microsoft Visual Studio Team System 2008 Team Suite - Service Pack 1 (KB948484)
    5. Microsoft Visual Studio 2008 Remote Debugger - Service Pack 1 (KB945140)
    6. KB945140 under Visual Studio .NET Prerequisites
    7. Update for WebDesigner 2007 (KB945140)
    8. Windows SDK for Visual Studio 2008 SP1 KB946729
    9. Windows SDK for Visual Studio 2008 KB946733
    10. Microsoft SQL Server Compact 3.5 SP1 Design Tools English
    11. Microsoft SQL Server Compact 3.5 SP1 English
    12. Microsoft SQL Server Database Publishing Wizard
    13. Visual Studio Tools for the Office system 3.0 Runtime Service Pack 1 Language Pack (KB949258)
    14. Visual Studio Tools for the Office system 3.0 Runtime Service Pack 1 (KB949258)
    15. Visual C++ 2008 IA64 Runtime - (v9.0.304xx)
    16. Visual C++ 2008 x64 Runtime - (v9.0.304xx)
    17. Visual C++ 2008 x86 Runtime - (v9.0.304xx)

    Après avoir désinstallé tous ces éléments, il ne reste presque plus rien de Visual Studio ;). Il faut réinstaller Visual Studio en utilisant l'option "réparer l'installation". Mais ça marche.

    Pour désinstaller .NET 3.5 SP1 beta, c'est plus simple. Il suffit de désinstaller "Microsoft .NET Framework 3.5 SP1 beta". Facile. Le problème c'est qu'après il n'y a plus de framework .NET 3.5. Il faut en réinstaller une version normale.

     

     11 June 2008, 01:52
    # Wednesday, May 28, 2008

    1. La première étape de l'apprentissage de WPF, selon Josh Smith (un gourou de WPF), est la suivante : retirez votre cerveau de votre crâne, faites le tourner de 180°, puis remettez-le en place (voir Figure 1).

     

    Avant d'apprendre WPF, retournez votre cerveau
    Figure 1 : Prérequis avant d'apprendre WPF

    Il est vrai que pour nous qui connaissons la programmation d'applications clientes "classiques" (type Win32, MFC, ou même Winforms), l'apprentissage de WPF provoque divers types d'émotions qui vont de l'étonnement à l'incompréhension, en passant par l'admiration ou la colère. La programmation WPF est... hmmm... comment dire... différente.

     


    2. La deuxième étape est d'acheter un livre (celui que je préfère est celui d'Adam Nathan, aucun livre correct en français encore), de consulter la documentation de WPF sur MSDN, et de regarder des articles, tutoriels, vidéos sur CodeProject, sur des blogs, ou sur www.windowsclient.net. C'est un long processus : WPF est un environnement de programmation tout neuf, et tout est à découvrir ! Il y a tellement de nouveaux concepts à apprendre.

    Comptez plusieurs semaines pour cette deuxième étape (pour la première étape, le délai peut être infini).

    A l'issue de cette deuxième étape, vous savez comment faire des petits programmes qui mettent en oeuvre deux ou trois fonctionnalités de WPF. Vous savez créer une fenêtre avec un bouton 3D contenant une vidéo. Vous savez comment récupérer des images sur un site Web, et en afficher les miniatures. Vous pouvez même vous mettre rapidement à Silverlight, et porter votre petit bout de code sur le Web. Idéal pour épater vos collègues. Ajoutez en plus : "bah, j'ai fait ça en une soirée".

    Mais mais mais... pas question encore de créer une application. A l'issue de cette deuxième étape, les fonctionnalités de WPF, c'est comme les débris de verre cassés chez un vitrier. Un par un il sont clairs, mais tous ensemble, ils sont opaques.

     


    3. La troisième étape - délicate - est de tester chaque fonctionnalité de WPF dont on peut avoir besoin, dans une étude de faisabilité. Pour vérifier si :

    • elle fonctionne correctement, comme indiqué dans la documentation
    • elle est rapide (ou pas trop lente)

    Il existe malheureusement encore des domaines mystérieux et inconnus de WPF. Ou d'autres lieux où il vaut mieux ne pas s'aventurer si l'on veut conserver des performances correctes. Tout ceci n'est écrit nulle part, et si vous ne le vérifiez pas, vous ne le saurez pas.

    Oui, WPF est une technologie très jeune et très prometteuse, mais elle a les défauts (bugs) de sa jeunesse.

    Un exemple parmi d'autres, les bitmapeffects sont parfois très lents et, par conséquent, souvent inutilisables. Mais dans le SP1 de .NET 3.5 (qui vient de sortir en béta), ces bitmapeffects ont été totalement réécrits pour profiter de l'accélération matérielle de la carte graphique. Ils sont devenus très rapides ! Surprise surprise...

     


    4. La dernière étape est d'apprendre comment créer des application WPF. Imaginez que votre boss/client vous dise : "bon, ce nouveau projet, là, finalement on va le faire en WPF plutôt qu'en C++/MFC (ou Winforms, ou autre)".

    Les MFC proposent nativement une architecture d'application document-vue. Elle a le mérite d'exister et de structurer le développement d'application. Avec WPF, s'élabore une structure similaire, l'architecture modèle-vue-machin. Machin ?!

    (

    Le premier livre sur les design patternsPetite parenthèse sur les design patterns, au cas où. Les design patterns (ou shemas ou patrons de conception en français... ah quelle drôle de langue que le français) ont été décris en 1995 dans un livre culte : "Design Patterns - elements of reusable software". Les design patterns sont d'excellents moyens de formaliser des problèmes classiques de conception de logiciels, et d'apporter une solution. Pourquoi réinventer la roue à chaque fois, alors que d'autres architectes logiciels, d'autres programmeurs, se sont déjà cassés les dents neurones sur des problèmes de conception de logiciel ?

    Tout ça pour dire que, en 1995, à l'heure de gloire des MFC, on se passait de ces shemas. Mais maintenant il est impensable qu'un programmeurs, codeur, ou architecte logiciel ne se jette pas la tête la première dans ces patterns, avant de commencer quelque logiciel que ce soit.

    Un excellent livre sur les design patterns, malheureusement épuisé en français

    )

    En 2005-2006, avant même la sortie de WPF, deux gars de chez Microsoft, John Gossman et Dan Crevier, se sont posé la question de savoir comment architecturer une application WPF. Ils ont inventé le pattern Model-View-ViewModel, qui est décrit sur le blog de John Gossman ici puis , ainsi que sur le blog de Dan Crevier. Plus récemment, Josh Smith a écrit une très bonne synthèse sur codeproject. Avec un brin de malice et de réalisme, le Dr WPF appelle ce pattern Model-View-Poo.

    En gros, le pattern Model-View-ViewModel (Modèle-Vue-Machin) profite de la possibilité offerte par WPF de séparer facilement le code et les données d'une part, et l'interface utilisateur et l'affichage des données d'autre part. Ce pattern découpe une application en trois parties :

    • le modèle (Model) : les objets métiers, le code, les données, la logique et les algorithmes du programme. Le modèle est totalement indépendant de l'interface utilisateur, et de sa présentation à l'utilisateur.
    • la vue (View) : la présentation à l'utilisateur des données et des résultats des traitements. C'est l'interface utilisateur, et elle contient des fenêtres, des contrôles, ... Elle est complètement séparée du modèle.
    • le machin (ViewModel, ou Poo) : permet aux deux parties ci-dessus de communiquer. Un pont entre les deux mondes que sont le modèle et la vue. Le machin demande par exemple la mise à jour de l'affichage. Ou bien commande le démarrage d'un nouveau calcul, ou la mise à jour de données.

    Bien que le machin (poo) qui relie le modèle et la vue ne soit pas toujours parfaitement décrit ni organisé, le but du shema Modèle-Vue-Truc est déviter que vos applications WPF ne ressemblent à ceci :

    Code spaghetti

    Pour aller au delà du simple shema modèle-vue-machin, Microsoft met au point une méthodologie de développement d'application WPF, appelée Prism. Une présentation du concept est effectuée par un membre de l'équipe de Prism. Des conseils, stratégies, design-patterns, exemples et guides font partie de ce kit de survie à l'usage des développeurs d'applications WPF. Ou plutôt des architectes WPF. Ces outils sont destinés à faciliter le développement d'applications WPF conséquentes. Prism n'est pas terminé, mais des préversions sont déjà disponibles sur codeplex. Il faut que je regarde ça de plus près.

    Prism, méthodologie de développement WPF
    Prism : méthodologie de développement WPF


    On l'aura compris, la connaissance technique de WPF, de ses contrôles, styles, objets, etc, n'est que la première des étapes de l'apprentissage de WPF. Cette étape est bien décrite sur internet avec des tutoriels, des articles, des webcasts, etc. Il existe aussi de nombreux livres techniques (essentiellement en anglais).

    Par contre, cela ne suffit pas pour créer et architecturer de vraies applications. Les shemas, les design patterns, les "guides de bonnes pratiques" sur la manière de combiner les éléments de WPF et construire des logiciels commencent à peine à pointer le bout de leur nez. Il reste encore beaucoup à faire dans ce domaine. La jeunesse de WPF (un an !) explique sans doute le manque de maturité dans ce domaine. A titre de comparaison, les MFC proposaient il y a 15 ans (!) une implémentation automatique du shema Document-Vue, avec un assistant qui générait le squelette de l'application selon ce design pattern. Ce shéma document-vue est un ancêtre du Modèle-Vue-Machin de WPF. Mais ce dernier est encore bien flou...

    Bref, développer une application WPF, c'est un peu comme partir à la conquête du Far West il y a 150 ans. C'est une aventure.

     

    Mise à jour : John Gossman (qui a géré le développement de Expression Blend en WPF) vient d'écrire un article intéressant sur le sujet : PresentationModel and WPF, dans lequel il écrit : "WPF is still so new that we still don't know all the best practices and techniques..."

    Tags  | 
     28 May 2008, 23:42
    # Saturday, May 17, 2008

    L'article de Scott Guthrie présente une longue liste de nouveautés apportées par ces deux SP1. Mais il ne dit pas tout, la preuve :

    1. D'abord l'icône de Visual Studio a changé : il y a un petit 9 dessus maintenant !

    2. Deuxième constatation : tous les paramètres de l'environnement sont réinitialisés ! Configuration, dossiers "Include" ou "Lib" du compilateur C++, raccourcis clavier, ... il faut tout reparamétrer ! Je ne sais pas si j'ai fait une erreur ou si c'est un bug de la version beta...

    3. Le designer WPF (ex Cider) a bien changé : il dispose maintenant d'un éditeur d'événement. Il suffit de sélectionner un objet WPF, en mode design ou en XAML, et la liste des événements disponibles pour cet objet s'affiche. On peut trier les événements par ordre alphabétique, ou bien par thème. Cela manquait !

    Une autre amélioration très pratique est la possibilité d'effectuer un glisser-déplacer depuis la barre d'outils des contrôles WPF, vers une fenêtre WPF en mode design, aussi bien que vers le code XAML.

    A suivre...

    Tags  | 
     17 May 2008, 00:31
    # Friday, May 16, 2008

    Trop tentant d'installer ces dernières versions de VS 2008 et de .NET 3.5, je n'ai pas pu résister. Ce qui est dit de ces mises à jour de VS2008 et .NET 3.5 sur les blogs de Scott Guthrie et Tim Sneath est alléchant.

    Attention ! N'installez pas ces Service Packs si vous développez pour Silverlight 2. Le SP1 de .NET Framework 3.5 est incompatible avec les outils de programmation de Silverlight 2 beta. Il faut attendre quelques semaines pour qu'une nouvelle version de l'extension "VS 2008 Tools for Silverlight 2" compatible avec .NET 3.5 SP1 soit disponible.

    Ce sont des versions béta. Et un certain nombre de précautions doivent être prises avant d'intaller la bête.

    1. Sous Vista, il faut installer Vista SP1 au préalable.

    2. Si vous avez installé les extensions "VS 2008 Tools for Silverlight 2 Beta1" pour faire desprojets Silverlight avec VS 2008, il faut le désinstaller. .NET 3.5 SP1 ou Silverlight 2, il faut choisir !!

    Vous pouvez aussi désinstaller "Silverlight 2.0 SDK Beta1", il ne fonctionnera plus avec VS2008 SP1.

    Par contre, gardez évidemment le runtime de Silverlight.

    3. Il faut désinstaller une ou deux mises à jour de Visual Studio 2008. Pour cela, cliquer sur "Afficher les mises à jour installées", puis désinstallez les mise à jour de Visual Studio KB949325, et KB944899.

    Si vous ne désinstallez pas ces mises à jour, le programme d'installation des Service Packs ne fonctionnera pas.

    4. Les versions de Expression Blend antérieures au 9 mai 2008 ne fonctionneront plus avec .NET 3.5 SP1. Poubelle ! A désinstaller ! Même la dernière version 2.5. Heureusement, il existe déjà une mise à jour de Blend 2.5 : elle porte le même nom, "Expression Blend 2.5 March 2008 Preview", mais son numéro de version est 2.1.1113.

    5. Installez Visual Studio 2008 Service Pack 1 Beta

    6. Installez .NET Framework 3.5 Service Pack 1 Beta

    7. Installez Expression Blend 2.5 March 2008 Preview Refresh v2.1.1113

    8. Et voilà !

     

     16 May 2008, 16:40
    # Tuesday, April 08, 2008

    official beijing olympics logo

     

    Tags
     8 April 2008, 23:28
    # Monday, April 07, 2008

    Sur un dossier skydrive (5 Go de stockage gratuit en ligne sur skydrive.live.com !), j'ai mis le runtime des MFC90 avec feature pack RTM, et des exemples compilés. Cliquez sur le dossier Skydrive ci-dessous pour télécharger le runtime MFC90 (un ZIP de 2,5 Mo contenant MFC90U.DLL, MSVCM90.DLL, etc.), puis les exemples (des ZIP de 150 Ko à 1 Mo contenant chacun un fichier EXE) .

    J'ai aussi mis un exemple qui n'a pas besoin du runtime des MFC pour s'exécuter, puisque ce runtime est inclus statiquement dans le fichier EXE. Le fichier EXE est plus gros, forcément. Le ZIP fait 1,7 Mo, et contient un seul fichier EXE indépendant :

    Pourquoi avoir mis quelques exemples en téléchargement ? Juste pour ceux qui n'auraient pas forcément Visual Studio, ou pas le temps d'installer le Feature Pack, mais qui auraient quand même envie de voir ce qu'on peut faire avec du bon vieux code C++ bien de chez nous crévindiou, et la toute dernière version des MFC.

    Et de se dire : "wouah, c'est quand même vachement plus rapide qu'une appli .NET" :D

    (au fait, WPF c'est Windows Pour les Fénéants ;), même si tout développeur est fénéant, par définition)

    J'espère que le runtime MFC90-Feature pack que j'ai mis sur skydrive est complet, je n'ai pas fait passer tout ça par le service QA, désolé ;)

    Voici une capture d'écran d'une des applications MFC90-Feature Pack mise sur le dossier Skydrive :

    Entre parenthèse, pour ceux qui auraient déjà installé le feature-pack, les exemples livrés ont une configuration de compilation qui s'appelle "Debug CLR", et qui produit un exécutable qui utilise à la fois MFC90.DLL et MSCOREE.DLL. Et donc génère du code géré ?? Pas tout compris là... Si quelqu'un peut éclairer ma lanterne avant que je ne finisse par lire la doc...

    Tags  | 
     7 April 2008, 23:34

    C'est THE événement de l'année - que dis-je, du siècle - dans le monde du développement d'applications en C++ sous Windows.

    Une mise à jour importante des MFC et des librairies C++ ! La doc de cette mise à jour est déjà sur MSDN (en anglais).

    L'info est parue sur le blog de l'équipe VC++, et le téléchargement du C++ Feature Pack est ici. Ce téléchargement est gratuit (322 Mo), et pour Visual C++ standard, Pro ou Team System. Une version pour Visual C++ express sera bientôt disponible.

    La fonctionnalité la plus spectaculaire offerte par ce Visual C++ Feature Pack est bien sûr le look and feel office 2007, y compris le ruban. Il se murmure sur les blogs que ce ruban d'Office serait appelé à être l'interface par défaut des applications sous Windows 7. C'est une rumeur... qui va dans le même sens que l'inclusion de ce ruban Office dans les MFC. Code natif ou code géré, même combat (pour une fois !)

    La licence d'utilisation du ruban Office 2007

    Notez que l'interface d'Office 2007 (le ruban, le design et le graphisme) sont protégés par Microsoft, et qu'il n'est possible de distribuer des applications qui utilisent cette interface qu'en obtenant une licence d'utilisation (gratuite) de l'interface Office 2007 ici : http://msdn.microsoft.com/officeui. Cette licence d'utilisation vous interdit d'utiliser l'interface d'Office 2007 pour faire un concurrent d'Office 2007 ;) et vous oblige à utiliser cette interface correctement. Dans ce cas, cette licence est gratuite et facile à obtenir.

    D'ailleurs, cette licence "Office 2007 Fluent UI" est obligatoire pour toute application qui utilise l'interface d'Office 2007, que cette application soit écrite avec les MFC, ou bien avec une autre librairie qui offre le look and feel Office 2007.

    La taille du runtime MFC a triplé

    Voici les nouvelles versions des DLLs du runtime MFC, après installation du feature pack : MFC90.DLL, MFC90U.DLL. Elles sont dans C:\Windows\winsxs\x86_microsoft.vc90.mfc.....

    Elles ont bien grossi après l'installation du feature pack. La version MFC 90 sans feature pack est trois fois plus petite :

    Il faut aussi ajouter les DLLs du runtime C++, soit msvcr90.dll, msvcp90.dll et msvcm90.dll, pour 1,38 Mo. Sachez donc qu'avec le Feature Pack, une application MFC occupe au moins 5 Mo ! Evidemment de nos jours ce n'est pas forcément grand chose, mais moi qui ai connu les PC à 128 Ko de mémoire, imaginez un peu...

    On note qu'on se retrouve avec deux versions très différentes des MFC qui s'appellent toutes les deux MFC90 :

    - MFC90 livrée avec Visual Studio 2008, dont la taille est 1 Mo

    - MFC90 du feature pack, dont la taille est 5 Mo

    Hmmm, ça risque de poser des problèmes pour les installations ça...

    Des exemples

    Bon, on en a pour notre espace disque quand même. Tous les bitmaps du look Office 2007 qui mangent ces quelques Mo sur le disque sont bien agréables à l'oeil, n'est-ce pas ? Voici deux samples livrés avec le Feature pack.

    Histoire de taper un peu sur .NET et surtout sur WPF, quel plaisir de voir des applications qui se lancent en une fraction de seconde, et qui sont très rapides à l'exécution !

     

    Ces exemples sont téléchargeables sur mon espace skydrive.

    Tags  | 
     7 April 2008, 15:37
    # Tuesday, March 11, 2008

    Image © parazit - Fotolia.com

    Je l'avais promis... Cette demoiselle sexy va enlever le haut... pour ceux qui ont téléchargé le plug-in Silverlight 2.

    Ahah ! Je vais faire grimper les stats d'installation de Silverlight rapido !

    Utilisez la molette de la souris pour zoomer sur sa..., et le cliquer-déplacer pour déplacer l'image pour mieux voir ses...

    (Cliquez ici pour obtenir le plugin Silverlight 2 pour MacOS ou pour Windows)

    Pour savoir comment fonctionne Deep Zoom et le contrôle MultiScaleImage de Silverlight, utilisé ici pour cette "animation", vous pouvez consulter l'article DeepZoom in C# - Not just possible, but easy de Laurence Moroney.

    Tags  | 
     11 March 2008, 14:16


    Image (c) New York Times

    The Cloud

    J'aime bien cette image :) On dirait Microsoft qui veut racheter Yahoo pour faire de l'ombre à Google. Ou bien prendre le contrôle du ciel. Ou plutôt du "cloud".

    Le "cloud" (nuage), c'est un terme à la mode dans le monde Internet depuis quelques semaines. Un terme qu'il faut connaître, sinon on passe pour... euuhhh...

    Le "cloud", c'est (je crois... c'est du marketing aussi hein...) la possibilité d'avoir à disposition toutes nos informations, toutes nos applications, partout, en utilisant des terminaux connectés à Internet. Terminaux fixes ou mobiles : PC, portables, téléphones, balladeur... On utilisera des applications comme des services internet aussi bien que des applications classiques qui s'installent sur un PC. Pour pouvoir utiliser ses informations et ses documents partout. Sympa non ?

     

    The Mix

    Le Mix 08 vient de commencer, et il s'y dit que d'ici 5 ans, tout sera connecté à Internet. Y compris les programmeurs qui devront créer ces applications mobiles, connectées. Avec Silverlight, .NET 3.5 et WPF (et ASP.NET). Ca tombe bien Microsoft sort aujourd'hui en béta :

    Il y a un truc que je n'ai pas compris dans tout ça, c'est pourquoi XNA (surcouche en C# de DirectX pour les jeux) faisait partie du discours...

    Tim Sneath a fait un excellent résumé de la scéance plénière du Mix 08. Les webcast et autres infos sont sur le site www.visitmix.com.

    Scott Guthrie présente le cloud Microsoft au MIX 08
    Scott Guthrie présente le "Cloud" de Microsoft, au MIX 08

    En face, Adobe sort cette semaine sa plate-forme RIA Air (avec Flex et Flash), concurrente de Silverlight-.NET-ASP. Air, c'est, comme son nom le suggère, le "cloud" d'Adobe. Comme quoi, Microsoft ne cherche pas à faire de l'ombre qu'à Google.

     

    Comment se mettre à Silverlight 2 ?

    Si vous ne vous êtes pas encore mis à XAML et Silverlight, c'est vraiment le moment d'y jeter un oeil... Il y a réellement une effervescence autour de tout cela.

    Pour mettre les mains dans le cambouis et découvrir Silverlight 2, il faut une déjà une version de Visual Studio 2008 en anglais j'imagine (une version express ne convient pas). Puis installer Silverlight Tools beta for Visual Studio 2008. 50 Mo quand même : cela contient le runtime Silverlight 2 béta, son SDK, des templates en C# et VB.

    Attention ! Avant d'installer Silverlight Tools, il faut désinstaller à la main toute version précédente du runtime Silverlight ainsi que du SDK de Silverlight qui pourrait être déjà installée sur le PC, et effectuer 2 ou 3 tâches un peu bizarres. Sinon, un message d'erreur fatal apparaît. Le programme d'installation de Silverlight Tools for Visual Studio a toutes les chances de ne pas s'exécuter correctement du 1er coup (pour moi, la 3eme tentative a été la bonne). Heureusement, un blog sur ASP.NET présente un mode d'emploi détaillé du programme d'installation. En tous cas, Microsoft peut mieux faire sur ce coup là, c'est clair...


    Le programme d'installation de Visual Studio Tools pour Silverlight ne marchera pas du premier coup...

    Pour info, le runtime Silverlight 2 est un téléchargement de moins de 5 Mo, et occupe environ 10 Mo sur le disque.

    Pour créer du contenu Silverlight 2, il faut aussi Expression Blend 2.5 March Preview. Trois versions de Blend sont disponibles simultanément ! Blend et Visual Studio sont étroitement liés. La version de Blend à utiliser dépend de la version de Visual Studio que l'on utilise :

    • Blend 1.0 fonctionne avec Visual Studio 2005, pour des interfaces WPF.
    • Blend 2.0 December Preview fonctionne avec Visual Studio 2008 et permet de créer des interfaces en XAML pour WPF 3.5.
    • Blend 2.5 March Preview fonctionne avec Visual Studio 2008, WPF 3.5 et Silverlight 2 béta 1. C'est cette version qu'il faut pour utiliser Silverlight 2.

    Il est possible d'installer côte à côte plusieurs versions de Blend.

    Il est nécessaire d'avoir installé Silverlight Tools 2 béta for Visual Studio 2008 avant d'installer Blend 2.5. Blend 2.5 s'installe facilement, pas comme Silverlight Tools !

    Ensuite... rendez-vous sur www.silverlight.net, et cliquez sur le bouton "Learn" pour y trouver tutoriels, hands-on labs et vidéos pour Silverlight 2 (tout en anglais...)

    Toutes les vidéos (en anglais) du MIX 08 sont sur sessions.visitmix.com. La deuxième session plénière (Keynote II) avec Steve Ballmer est à mourir de rire (la transcription ici).

    Mais il existe déjà pas mal de contenu en français pour apprendre Silverlight (vidéos, webcast, tutoriels, articles) dans la section Développement Web du MSDN français (le problème avec les infos Silverlight, c'est qu'elles deviennent obsolètes quelques semaines après avoir été écrites)

     

    The killer feature

    Je ne m'attendais pas à voir la fonctionnalité Deep Zoom (ex Seadragon) dans Silverlight 2. C'est très impressionnant : on zoome et navigue dans des collections de photos d'une manière incroyable. Le site Hard Rock en propose une démo : http://memorabilia.hardrock.com (on zoome avec la molette de la souris).

    Sur memorabilia.hardrock.com Silverlight propose une manière inhabituelle de naviguer dans une collection de photos
    Sur memorabilia.hardrock.com Silverlight propose une manière inhabituelle de naviguer dans une collection de photos

    J'espère que Deep Zoom sera également disponible dans la version améliorée de WPF prévue pour cet été... S'il te plaît Mr Guthrie, tu peux mettre DeepZoom dans WPF ?

    Voici en exclusivité galactique une animation Silverlight 2 (avec DeepZoom) des photos de mon week-end dans le Jura Suisse. Ah oui, pour voir les animations des photos, il faut installer le plug-in Silverlight 2 pour MacOS ou Windows. Utilisez la molette de la souris pour zoomer...

     

     11 March 2008, 14:02
    # Monday, March 03, 2008

    2018 Israel Palestine Footbal World Cup

    En 2018, la coupe du monde de foot sera organisée conjointement par Israel et la Palestine. Une demi finale à Gaza, la finale à Jerusalem.

    On peut rêver ici : goal2018.org

     

    2018 Israel Palestine Footbal World Cup

    Tags
     3 March 2008, 23:33
    # Sunday, February 24, 2008

    Google m'envoie plein de demandes d'internautes qui recherchent comment charger une image PNG ou JPEG depuis les ressources d'un programme C++.

    Mettre un bitmap BMP dans les ressources, et le charger en C++/MFC, c'est facile. Y mettre un PNG ou JPEG, c'est un tout petit peu délicat.

    D'abord, ajouter l'image dans le fichier ressources :

    IDB_IMAGEPNG PNG "res\\image.png"

    Puis la charger dans le code :

    // Load image data from PNG section of the resource file
    HINSTANCE hResourceModule = AfxGetResourceHandle();
    HRSRC hRes = FindResource(hResourceModule, 
             MAKEINTRESOURCE(IDB_IMAGEPNG), _T("PNG"));
    DWORD dwSizeResource = SizeofResource(hResourceModule, hRes);
    HGLOBAL hMem = LoadResource(hResourceModule, hRes);

    // Copy the PNG image data into a new buffer
    BYTE *pRes = (BYTE *)LockResource(hMem);
    HGLOBAL hImg = GlobalAlloc(GHND, dwSizeResource);
    BYTE *pImg = (BYTE *)GlobalLock(hImg);
    memcpy_s(pImg, dwSizeResource, pRes, dwSizeResource);
    GlobalUnlock(hImg);

    // Create a GDIPlus Bitmap from a HGLOBAL
    IStream *pStream = NULL;
    HRESULT hr = CreateStreamOnHGlobal(hMem, FALSE, &pStream);
    Bitmap *pBitmap = new
    Bitmap(pStream);
    pStream->Release ();
    GlobalFree(hImg);

    Ce code fonctionne avec les images JPEG et GIF aussi bien que les PNG.
    Tags  | 
     24 February 2008, 18:47

    Le grand Scott Guthrie (dont la lecture du blog est de plus en plus incontournable) nous fait baver en donnant des détails sur Silverlight 2, et même un tutoriel (d'autres infos ici aussi, et en français sur le blog de ClaueR)... alors que tout cela n'est même pas encore disponible en béta : il faudra attendre la conférence MIX 08, dans deux semaines, pour tester Silverlight 2 (en béta).

    Moi aussi je vais faire du teasing à la Scott Guthrie. Dans deux semaines, la jolie demoiselle ci-dessous va enlever le haut, sur ce blog, ici même ! Et moi aussi j'enlèverai le haut (du blog) : je remplacerai la petite animation Flash par une animation Silverlight 2.


    Image © parazit - Fotolia.com

    Tags  | 
     24 February 2008, 15:29
    # Tuesday, February 19, 2008

    Il y a un peu plus d'un mois je râlais contre WPF, parce qu'il est trop lourd, trop gros, trop lent. Parce qu'il fallait trois jours pour lancer une application WPF (OK j'exagère un peu). J'allais jusqu'à dire que si bien peu d'applications WPF sont disponibles, c'est principalement à cause de ses mauvaises performances. Même si ce n'est pas la seule raison : WPF et XAML représentent une nouvelle façon de programmer qu'il faut un moment à assimiler.

    J'étais prêt à jeter à la poubelle mon bouquin Windows Presentation Foundation Unleashed, persuadé que WPF signifie secrètement Windows Pour les Fénéants.

    Alleluia !

    Scott Guthrie (qui vient d'être promu Corporate Vice President de Microsoft, en charge de .NET, CLR, WPF, Silverlight, ASP.NET, IIS ...) annonce aujourd'hui une amélioration des performances de .NET, et particulièrement de WPF, et une nouvelle version importante de WPF pour cet été. Peut-être une synergie avec Silverlight 2.0 ?

    WPF était une nouveauté de .NET 3.0, et quelques améliorations ont été apportées à WPF avec la sortie de .NET 3.5. Cet été, une nouvelle version de WPF sera disponible.

    Cette nouvelle version proposera une installation du framework .NET optimisée, un chargement des applications .NET plus rapide, un affichage du texte et des vidéos plus rapide en WPF, etc. Tout cela sans avoir à modifier les applications existantes. Outre des performances améliorées, WPF 3.5 comportera de nouveaux contrôles qui manquent cruellement : un calendrier (enfin !), un Ribbon (comme Office 2007), et un DataGrid. Visual Studio 2008 disposera aussi d'une meilleure intégration de WPF.


    Le Datagrid de xceed.com. Bientôt dans WPF ?

    Microsoft est - enfin ! - concerné par la performance des applications réalisées avec Visual Studio : de nouvelles MFC, une version optimisée de WPF... Mieux vaut tard que jamais ! ;)

    J'en conclus que le moment est venu de se mettre sérieusement à XAML. Oui, oui, même pour toi, programmeur C++/MFC. L'interface utilisateur de ton programme risque d'être en WPF l'an prochain. Même si tu devras encore gérer des DLL en C++ pour quelques années encore.

    Nous en saurons plus dans deux semaines : Rob Relyea, qui a réalisé une excellente présentation de WPF pour les développeurs à la conférence MIX l'an dernier, décrira le futur de WPF dans une session du MIX 08.

    Tags  | 
     19 February 2008, 22:34
    # Monday, February 18, 2008

    Pendant des siècles on s'est demandé ce que signifient nos rêves. Freud et d'autres ont essayé d'en saisir la signification. En fait, les rêves, ce sont juste nos cerveaux qui se défragmentent pendant la nuit.

    Dreams are really just our brains defragmenting overnight

    (de steve clayton)

    Tags
     18 February 2008, 16:11
    # Friday, February 15, 2008

    Comme quoi j'étais mauvaise langue il y a quelques jours : la copie a pris moins de 30 jours ;)

    En fait, Microsoft a avancé la disponibilité sur MSDN et Technet pour permettre aux éditeurs de logiciel et intégrateurs de tester le SP1 avant sa sortie au grand public, dans un mois. Abonnés MSDN et Technet ont râlé, Microsoft a donné satisfaction.

    On dit que ce SP1 rend Vista plus rapide... de manière impressionnante parfois. Notamment la copie de fichiers ;) selon ZDNet.

    Pour les abonnés MSDN, c'est ici : http://msdn2.microsoft.com/en-us/subscriptions/default.aspx, dans la rubrique "Top download", en français, anglais, pour x64 et x86. Aussi dispo pour les abonnés Technet Plus.

    Je me demande si les performance des applications WPF vont être améliorées. Parce que faire des applications avec WPF est vraiment tentant quand même... Je rêve là, non ?

    Si l'installation de "la bête" prend plus d'une heure, elle est très simple : il suffit d'exécuter la bonne version du SP1 (x86 ou x64). Pour l'image ISO, même pas besoin de la graver sur un DVD, un simple lecteur virtuel suffit. Ensuite tout est automatique, heureusement. L'installateur détecte tout seul la langue du système. Pas de problème sur les quelques PC sur lesquels il a été installé.

     

    Après installation, la version de Windows est toujours 6.0, le numéro de build est 6001.

    On peut tester par programme si le SP1 de Vista est installé (en C++ natif) :

    OSVERSIONINFOEX osvi;
    memset(&osvi, 0,
    sizeof(osvi));
    osvi.dwOSVersionInfoSize =
    sizeof
    (osvi);

    if
    (GetVersionEx((OSVERSIONINFO*)&osvi))
    {
          
    if
    (osvi.dwMajorVersion == 6 && osvi.dwMinorVersion == 0)  // Windows 6.0
          {
                // Vista 6.0

                if (osvi.wServicePackMajor == 1) // Service pack version 1
                {
                   
    // Vista SP1
                }

          
    }
    }

    Voici ce que contient toute la structure OSVERSIONINFOEX sous Vista SP1 :

    Le nom "Service Pack 1" est en clair dans szCSDVersion, et le numéro de version du Service Pack est 1.0.

    Pour rappel, voici les numéros des différentes versions de Windows :

    Operating system Version number
    Windows Server 2008 6.0
    Windows Vista 6.0
    Windows Server 2003 R2 5.2
    Windows Server 2003 5.2
    Windows XP 5.1
    Windows 2000 5.0
    Windows Me 4.90
    Windows 98 4.10
    Windows NT 4.0 4.0
    Windows 95 4.0

    On notera que Vista a le même numéro de version que Windows Server 2008...

    Bon allez hop, au boulot ! Testons si nos logiciels fonctionnent toujours avec ce SP1. Parce qu'il sera disponible au grand public dans un mois exactement. Les services QA/tests ne vont pas pouvoir partir au ski...

    Tags  | 
     15 February 2008, 15:31
    # Tuesday, February 05, 2008

    Sur le blog de Windows Vista, Mike Nash (Microsoft Vice President, Windows Product Management) a annoncé que le SP1 de Vista était sorti en RTM... mais qu'il ne serait disponible sur Windows Update qu'en mars et avril 2008. Quand un produit sort en RTM (Release To Manufacturer), ça veut dire qu'il est fini, qu'il part à la fabrication, au pressage des DVDs, qu'il est mis en ligne en téléchargement, qu'il sort en RTW (Release to Web !). Alors, bizarre ce délai, non ?

    Bon, bon... attendons un peu : Mike Nash nous promet que le SP1 améliore la rapidité de copie des fichiers sur le réseau jusqu'à 50%. Ce SP1 pourra être installé sur la plupart des PC Vista, sauf ceux qui ont des drivers incompatibles. Sur ces machines, le SP1 ne s'installera pas.

    La voilà la vraie raison ! Selon www.istartedsomething.com, le PC Vista qui copie les fichiers du SP1 sur les serveurs de Windows Update a des drivers réseau pas très catholiques. Du coup, le SP1 n'a pas pu être installé sur ce PC, qui conserve son problème de lenteur lors de la copie de fichiers sur le réseau.

    Criant de vérité, non ?

    Tags  | 
     5 February 2008, 10:36
    # Monday, January 28, 2008

    Bien sûr vous connaissez Codeproject.com, la référence du partage de code et d'expérience de programmation depuis des années. Microsoft vient également d'ouvrir un site communautaire de partage de code. Proposez vos articles et bouts de codes, profitez de l'expérience de vos pairs sur code.msdn.com, et faites part de vos commentaires. Bref, le site MSDN version web 2.0.

    Pour l'instant il n'y a pas énormément d'articles, mais je suis sûr que très bientôt, ce site regorgera de code C++/MFC !

    Il existe d'autres communautés Microsoft (en anglais) dédiées au développement, par type de plateforme. Si vous, programmeur (C++), voulez découvrir ou approfondir un sujet sur .NET, c'est ici :

    Il y a aussi des communautés comme Channel8, Channel9 et Channel10, où l'on trouve un peu de tout : de la dernière interview vidéo d'un gourou de chez Microsoft, à un article du genre "Mais pourquoi utilise-t'on encore C++ avec des pointeurs qui pointent n'importe où, alors que C# est un merveilleux langage ?"

    Hum... où est le C++ natif dans tout ces sites Microsoft ??

    Tags  | 
     28 January 2008, 23:00

    Des vidéos et des photos en provenance de Chine montrent soi-disant des pré-versions de Windows 7, le successeur de Windows Vista.

    Mais il y a mieux ! Voici ce à quoi ressemblera Windows 8 (qui sortira fin 2012 début 2013) :

    Etonnant non ?

    Tags  | 
     28 January 2008, 16:17
    # Sunday, January 20, 2008

    Windows Seven logo Depuis quelques jours, pas mal d'informations filtrent sur Internet à propos de la prochaine version de Windows. Le nom de code du successeur de Vista est actuellement Windows 7, après avoir été Vienna.

    Quand sort la prochaine version de Windows ?

    Selon diverses sources (TG Daily, repris par ZDNet, Infoworld...), le développement de Windows 7 est bien avancé puisqu'une version a été livrée ces derniers jours aux principaux constructeurs de PC partenaires de Microsoft.

    Initialement prévue pour 2010, la sortie de Windows 7 aurait donc été avancée au deuxième semestre 2009. C'est dans un an et demi ! Et si on prévoit une large disponibilité de Windows 7 sur des PC préinstallés pour Noël 2009, cela veut dire que Windows 7 sera disponible à la fin de l'été 2009. Par conséquent, une version béta (non encore planifiée) sera sans doute disponible dans environ un an, début 2009.

    Souvenons-nous des déboires et du retard de Microsoft lors de la sortie de Vista. Ils ne veulent pas rééditer le même scénario.

    Il y aura quoi dedans ?

    Il y a des fuites. Une taupe* a pu installer la version de Windows 7 qui vient d'être livrée aux partenaires Microsoft, et fait part de ses commentaires sur un forum du site Neowin.

    - Il semble que certains accessoires de Windows 7 soient réécrits en WPF : Paint, la calculatrice,... une révolution ! ;) C'est vrai ça, dans Vista, rien (ou presque) n'est écrit avec WPF. Cela voudrait-il dire que Microsoft a amélioré la performance de WPF ? Cela serait vraiment, vraiment bien.

    - On parle aussi d'une intégration de Windows Live avec Windows 7, ici et ici. Internet et Windows Live comme une extension naturelle de Windows, ma foi, ça semble tomber sous le sens. Faites chauffer votre passport MSN.

    - Et de performance améliorée. Yesss !! On parle de Minwin, ici ou ... MinWin est un noyau Windows allégé, en 33 Mo. Et l'on se met à rêver de performance, de système rapide et moins gourmand en ressources...

    Il y a quelques mois, le site Neowin, encore lui, avait publié une liste de souhaits qui a été présentée à l'équipe de Windows 7. Il a été confirmé que cette liste était bien réelle. Mais elle n'apporte pas grand chose en fin de compte : ce sont des souhaits qui ont été présentés à l'équipe Windows. Ce n'est pas une liste de fonctionnalités.

    Voici un extrait de la liste. Cliquez pour voir la liste complète :


    En même temps, Mike Nash (Microsoft VP, Windows) a déclaré que, s'il ne regrettait pas tous les changements apportés par Vista, il y aura moins de modifications d'architecture du système dans Windows 7.

    On peut traduire cela par : "après les folies de Vista, on se calme pour Windows 7". Ou bien par "il y a eu tellement de modifications d'architecture dans Vista (UAC, drivers, réseau, gestion UI...) que maintenant on est tranquille". Ou encore par : "avec Vista, Microsoft a changé tellement de choses que beaucoup de logiciels ne fonctionnaient plus. Ce ne sera pas le cas avec Windows 7". Ouf.

    Pourquoi si tôt ?

    Parce que Microsoft a des soucis avec Vista : après être sorti en retard, peu d'utilisateurs l'ont adopté.

    Au moins quand on est en avance, on n'est pas en retard.

    Peu d'utilisateurs de PC utilisent Vista, ils restent sous XP. Chez Dell par exemple, on peut encore commander un PC neuf avec XP. Selon Xiti, 80% des internautes utilisent encore Windows XP. 12% utilisent Vista, et les 8% qui restent sont à partager entre MacOS, les autres versions de Windows (2000, 98, ...), Linux, les mobiles et les consoles.

    Les grands comptes ont déjà payé la migration vers Vista même s'ils utilisent encore XP. Ce n'est donc pas une question de coût des licences. Eh oui, Microsoft est très fort : avec "l'assurance logicielle", les grands comptes paient les dernières versions, même s'ils ne les utilisent pas. Enfin, ce n'est pas nouveau que le marketing de Microsoft est efficace !

    Ceux qui sont encore sous Windows XP pourront peut-être passer directement à Windows 7, sans passer par la case Vista. Dans un an, quand on commencera à pas mal parler de Windows 7, les utilisateurs de Windows XP passeront vraiment pour des dinosaures. Un peu comme les utilisateurs de Windows 98 maintenant.

    Vista n'est pas un vrai succès : après être sorti en retard, peu d'utilisateurs l'ont adopté. Microsoft veut remédier à cela... avec Windows 7 !

     

    Tags
     20 January 2008, 13:55
    # Thursday, January 17, 2008

     

    Mise à jour du 7 avril 2008 : la version finale du feature pack est disponible !

     

    J'ai installé la version béta du Service Pack Feature pack de Visual Studio 2008. 300 Mo, quand même...

    Attention ! Ce Feature Pack ne s'installe que sur une version anglaise de Visual Studio Professional (ou +). Il faut aussi que le DVD d'installation de Visual Studio soit inséré dans le lecteur si vous n'avez pas fait une installation complète de Visual C++.

    Le feature pack de Visual C++ contient une version de TR1 de C++0x, et la nouvelle version des MFC. Je vais parler ici des MFC seulement.

    Les MFC à la diète !

    Première chose, je regarde la taille de la DLL redistribuable des MFC : mfc90.dll passe de 1130 Ko à 3666 Ko une fois le Feature Pack installé. Ouch, ce n'est pas rien ! D'où vient l'accroissement de la taille ? Des quatre thèmes office 2007 inclus. Il y a environ 500 fichiers PNG dans mfc90.dll. Chaque fichier PNG existe en 4 versions, une pour chacun des quatre thèmes de Office 2007 : Aqua, Black, Blue, Silver.

    C'est pratique d'avoir une seule DLL, mais ça serait peut-être bien de mettre les bitmaps des 4 thèmes Office dans 4 DLL différentes. Genre MFC91UXBLUE.DLL. Histoire d'économiser 2 Mo. Oui, oui, il y a quand même encore des gens qui regardent la taille des exécutables qu'ils produisent...

    Là où c'est encore plus gênant, c'est quand on "linke" statiquement avec les MFC. Toutes les images des 4 thèmes Office se retrouvent dans le fichier EXE, même si on ne les utilise pas. Ca, c'est pas bien du tout ! Du coup, la moindre application avec les MFC liées statiquement fait presque 3 Mo. Si on ouvre l'exécutable généré dans Visual Studio pour voir les ressources, on obtient... ça :

    J'espère que les MFC9.1 feront une petite diète avant de sortir en version finale... un petit régime avant l'été, ça serait sympa ?

    Exemples d'interfaces utilisateur

    Que peut-on faire avec ces nouvelles MFC ? Ah, ça déchire, comme disent les jeunes de maintenant. Voici quelques captures d'écran, pour le plaisir des yeux. Je vous propose en plus ces programmes en téléchargement, pour que vous puissiez apprécier la richesse de l'interface. J'avoue que l'aperçu avant impression de l'application MFC91Ribbon est pas mal, ainsi que le changement de style à la volée, et.... etc, etc.

    Voici un exemple d'application C++/MFC avec un Ribbon :

     

    Un autre exemple avec une interface genre Visual Studio, et "Diamond Docking" :

     

    Vous pouvez télécharger ces deux applications ci-dessous, si vous voulez jouer avec (pour Windows Vista seulement). J'ajouterai d'autres exemples très bientôt. Enjoy !

    MFC90samples.zip (2,46 MB)

    Tags  | 
     17 January 2008, 18:46
    # Saturday, January 12, 2008

    Pourquoi Vista est il plus lent que XP ?

    Devil Mountain Software a fait des tests pour comparer les deux versions de Windows, avec et sans Service Pack, selon Yahoo News. XP SP3 est toujours plus rapide que Vista SP1, jusqu'à deux fois plus rapide dans certains cas. Et Windows XP SP3 serait 10% plus rapide que XP SP2. Par contre, Vista SP1 ne serait pas vraiment plus rapide que Vista "normal".

    "Vivement le SP3" direz-vous, si vous utilisez encore Windows XP. Eh bien vous l'avez déjà, ce SP3 ! Enfin, vous l'avez quasiment si vous utilisez les mises à jour de Windows Update. Car un Service Pack n'est rien d'autre que la compilation de tous les correctifs déjà parus.

    Dans tous les cas Vista est plus lent que XP ! Eh bien c'est tout à fait normal. Les nouvelles versions des logiciels (y compris les systèmes d'exploitation) sont généralement plus lents que leurs prédécesseurs, car ils apportent leur lot de nouvelles fonctionnalités, gourmandes en ressources. Souvenez-vous de Visual C++ 6.0 qui compilait un programme à la vitesse de la lumière; Visual Studio 2008 est beaucoup plus lent. C'est ainsi que de nouveaux PC plus puissants sont vendus, qui font vendre de nouveaux logiciels, et réciproquement. Cela fait quelques dizaines d'années que ce serpent qui se mord la queue me permet (entre autres) de manger. Et sans doute vous aussi, avouez !

    Vista a de nombreux gadgets et nouvelles fonctionnalités, dont certaines sont gourmandes en ressources. Par exemple, Windows Vista a beaucoup plus d'animations graphiques que XP. Activez l'affichage classique de Vista - sans Aero - et vous gagnerez beaucoup en performance. Aero consomme tellement de mémoire que je me demande si certains gadgets visuels ne sont pas écrits en WPF ! La gestion du réseau de Vista est très différente, la sécurité n'a rien à voir... autant de nouveautés qui coûtent.

    Pourquoi (ne pas) migrer vers Vista ?

    En fait, si on se pose la question de savoir si Vista est plus lent que XP, c'est que les utilisateurs manquent de raisons pour migrer vers Vista. Sinon on ne se poserait même pas la question. Même si 100 millions de PC ont déjà adopté Vista selon Bill Gates au CES, les utilisateurs migrent moins vite vers Vista qu'ils ont migré vers XP.

    Ce qui fait migrer les utilisateurs moyens, et notamment en entreprise, c'est quand ils sont obligés d'avoir la dernière version de Windows pour faire tourner ce logiciel dont ils ont besoin.

    Où sont les logiciels qui fonctionnent sous Vista et pas sous XP ? Bonne question. Il ne doit pas y en avoir beaucoup... Quel éditeur serait assez fou pour se priver de la moitié + de son marché ? Quand Adobe ne supportera plus XP, plus personne n'utilisera ce système.

    WPF est-il mort ?

    Pourtant, dans les conférences Microsoft, quand ils nous parlaient de Vista avant sa sortie, on avait droit à des démos d'impressionnantes applications WPF. Et on se disait : "Vivement Vista qu'on puisse faire des applis démentes". On avait hâte que Vista sorte pour pouvoir proposer des applications avec une interface utilisateur réellement nouvelle. Or ces applications ne sont pas sorties. Pourtant, les technos WPF sont disponibles depuis presque deux ans...

    Pour l'instant, faire une application au look Vista, c'est :

    • utiliser la police de caractère Segoe UI à la place de Tahoma ou de MS Sans Serif.
    • avoir un champ "Recherche" bien en évidence.
    • utiliser des boîtes de dialogue type "Task dialog", et des assistants au style Aero.
    • reprendre les messages de l'interface utilisateur pour les mettre au goût de Vista.

    Pas de quoi fouetter un chat. En plus tout cela est accessible sous XP, et même sous Windows 98 !

    WPF est trop lent, trop lourd, et trop gourmand en mémoire. Et encore, il paraît que l'équipe Windows en a bien amélioré les performances et le temps de chargement des applications, avant la sortie de Vista. Est-il possible de construire une application grand public avec WPF, et de la vendre dans le commerce aujourd'hui ? Je demande à voir.

    Pour la plupart de leurs applications, y compris pour le Ribbon d'Office, Microsoft utilise une sorte de mini-XAML en code non managé qui s'appelle DirectUI (recherchez sur google). Jamais WPF. Mais ne rêvez pas non plus : DirectUI ne sera jamais disponible au commun des développeurs, car DirectUI est un produit à usage interne, pas suffisamment propre pour que Microsoft puisse le vendre et en assurer le support pendant 10 ans. C'est d'ailleurs pour cette raison que Microsoft a préféré acheter le code source d'un Ribbon à BCGSoft pour l'inclure dans les MFC, plutôt que de publier le leur.

    WPF est-il déjà mort ? En fait, WPF est une version 1.0. WPF 2.0 sera - espérons le - plus rapide et moins gourmand : c'est à dire écrit en code natif ! Sinon, nous autres éditeurs d'applications, l'enterrerons dans le même cimetière que le langage Java.

    WPF ou Silverlight ?

    En attendant que WPF ne sorte un pied de la tombe (ou bien qu'il y mette les deux), Silverlight pointe le bout de son nez. Avant sa sortie officielle, Silverlight s'appelait WPF/Everywhere, souvenez-vous. Silverlight 2.0 (en alpha actuellement) sera une implémentation légère, rapide et compacte d'une partie de WPF.

    Comment ? Microsoft aurait implémenté deux fois le support de WPF ? Oui : une fois de manière lente et non optimisée (en code "managed"), et une fois de manière légère et rapide (en code natif). C'est ça Silverlight : un redoutable concurrent de WPF.

    Et, pour en revenir à Windows XP, Silverlight tourne bien sûr sous XP...

    Cela en fait des modèles de programmation, je choisis lequel pour mes applications ?

    Pour faire une application sous Windows, on peut utiliser :

    • L'API Windows native (Win32), généralement à travers les MFC ou les ATL. La technologie est ancienne, éprouvée, rapide, mais les programmeurs d'aujourd'hui ne veulent plus coder en C++, ils préfèrent .NET... ! Si vous codez en C++, demandez une augmentation à votre chef, vous le valez bien.
    • Windows Forms (.NET 1.0 à 2.0) : cette technologie fonctionne très bien pour les applications de gestion, les application d'entreprise, et également pour les petits logiciels qui mettent en forme le contenu d'une base de données (genre "1000 courriers types" ou "mes recettes de cuisine").
    • Silverlight : c'est WPF allégé, écrit en code natif, et donc rapide. Mais Silverlight 1.0 est trop limité (à mon avis), et Silverlight 2.0 encore en version alpha. Silverlight arrivera-t'il trop tard ? Silverlight est apparemment destiné à des applications internet à client riche (RIA), mais il est possible de l'utiliser dans une application classique. Et gageons que les évolutions futures rendront Silverlight plus polyvalent.
    • WPF : très complet, très puissant, trop lourd, trop gourmand. Il faudrait (faudra) qu'il soit réécrit en code natif. Vivement WPF 2.0.

    En regardant la liste, c'est marrant, on voit tout de suite qu'il y en a un environnement de trop, entre WPF et Silverlight. Ces deux environnements sont deux implémentations très différentes d'un seul type d'application (XAML/C#). Microsoft a développé deux fois la même chose on dirait.

    Depuis quelques mois, on dirait que Microsoft a redécouvert qu'ils pouvaient proposer des outils pour développer des applications en code natif. Les nouvelles MFC sont un exemple. Est-ce que la trop grande lourdeur de WPF leur a montré qu'ils étaient allés trop loin dans le tout "managed" ?

    Bon, qui vivra verra. En attendant, de nombreux utilisateurs restent sous XP. Microsoft s'en fiche, ils ont payé leur licence Windows. Et les éditeurs n'osent pas encore sortir des applications spécifiques Vista.

     

    Tags  |  |  | 
     12 January 2008, 23:32
    # Tuesday, January 08, 2008

    J'ai déjà parlé de cette nouvelle version, ici ou , elle est maintenant disponible en version beta. C'est annoncé sur le blog de l'équipe de Visual C++. Le téléchargement (en anglais) est sur le site MSDN. Si vous voulez juste lire la documentation, c'est ici.

    La version béta des nouvelles MFC n'est pas encore disponible pour Visual C++ Express, mais cela viendra.

    Quoi de neuf (selon le blog de l'équipe Visual C++) :

    • Le ruban office 2007
    • Le look and feel d'Office 2007, 2003 ou XP, au choix.
    • Les panneaux attachables (docking panes... on comprend mieux en anglais !), comme dans Visual Studio
    • Barres d'outils et menu paramétrables
    • De nouveaux contrôles avancés
    • Gestion des applications MDI avancée : onglets, ...

    De plus, cette version des MFC inclut une implémentation de TR1. L'implémentation de TR1 est un pas vers l'adoption du standard C++0x. J'ai déjà parlé de C+=2 C++0x ici. L'implémentation TR1 proposée dans les MFC comprend :

    • Pointeurs intelligents (smart pointers)
    • Expression régulières.
    • Nouveaux types conteneurs : tuples, tableaux, ensembles non ordonnés, etc.
    • Générateur de nombres aléatoires avancé
    • Encapsulateurs de fonction polymorphique (polymorphic function wrapper)
    • Type traits
    • et d'autres.

    Je n'ai pas tout compris à TR1 encore, mais ça a l'air pas mal :)

    Bon allez, au boulot !

    Tags  | 
     8 January 2008, 12:52
    # Monday, January 07, 2008

    C'était hier la douzième et dernière intervention de Bill Gates au CES de Las Vegas (Consumer Electronic Show, la grand-messe de l'électronique grand public). De très bonnes transcriptions de la conférence d'ouverture (keynote) sont déjà disponibles, comme sur engadget.com. La vidéo (en Silverlight) est disponible sur http://www.microsoft.com/ces/, et des billets sont déjà sur Channel10.


    Image Engagdget

    Que dit Bill ?

    La tendance pour les 10 prochaines années : le logiciel (comprenez : le logiciel développé sur une plate-forme Microsoft) sera partout là où il y aura de la vidéo et du divertissement. Tout le monde aura un "Windows Live ID" pour pouvoir s'identifier et avoir toutes ses informations et son contenu disponibles partout. On utilisera une interface "naturelle", comme Microsoft Surface ou bien IPhone. Et de la vidéo HD avec Silverlight et la chaîne NBC pour le contenu, de la vidéo HD, de la vidéo HD. La plate forme est bien sûr Windows (sur un téléphone Windows mobile ou sur un PC) ou bien un matériel Microsoft comme Zune, XBOX, ou MediaRoom (la MicrosoftBox pour la télé sur IP, déjà adoptée par British Telecom).

    Quelques chiffres : 10 millions de nouveaux terminaux Windows mobile en 2007, 20 millions prévus en 2008. 100 millions d'utilisateurs de Vista aujourd'hui.

    Pourquoi parler du CES, de vidéo et de divertissement alors que sur ce blog on parle C++ ? Eh bien tout simplement parce que... les logiciels dont Bill parle ne sont pas encore écrits. Sans doute que certains d'entre eux le seront (partiellement ?) en C++ natif... Alors, techniquement, quelles pistes explorer ?

    • Silverlight est très bien pour gérer la vidéo. Apprenons Silverlight. Et comme Silverlight est un contrôle ActiveX, on peut l'inclure facilement dans une application écrite en C++ natif ! Silverlight 1.0 est très (trop) léger au point de vue fonctionnalités, mais Silverlight 2.0, déjà disponible en alpha, mérite un coup d'oeil. Le site de NBC pour les Jeux Olympiques 2008 de Pékin (www.NBCOlympics.com) sera tout en Silverlight : un sacré coup de pub pour ce concurrent de Flash !
    • L'API Live ID est à apprendre par coeur. Euh... en C++ natif il existe quelque chose pour attaquer les Web services ?

     

    Tags  | 
     7 January 2008, 11:32
    # Saturday, January 05, 2008

    Oui, nous sommes en 2008 et la newsletter hebdomadaire "Microsoft download notification" du 4 janvier 2008 indique qu'il faut télécharger le SP2 de Windows Vista XP. Cette lettre d'information présente l'actualité des téléchargements Microsoft. Télécharger le SP2 de Windows XP est donc d'actualité, dixit Microsoft.

    Microsoft aurait-il entendu les utilisateurs se plaindre que Windows Vista est trop lent ? Comme dans la lettre d'information de CNET du 4 janvier 2008 : "What can I do to improve the speed of my Vista machine ?" Un sondage (non représentatif) sur ce même site indique que 49% des utilisateurs ne veulent pas migrer de XP à Vista.

    Les utilisateurs de PC en auraient-ils assez des fatwares : systèmes et des logiciels trop lents, trop gourmands en ressources ?

    Est-ce que Bill Gates parlera de la difficulté à faire adopter Vista pas les utilisateurs de Windows XP, lors de son discours d'ouverture du CES, dimanche 6 janvier ? Je pense que oui. Enfin, il parlera du SP1 de Windows Vista. Il devrait aussi, dit-on, annoncer des nouveautés concernant Windows Mobile, Media Center, Home Server, XBOX 360, et Zune. Au fait, le site événementiel de Microsoft pour le CES est tout en silverlight... très joli design.

    La difficulté de voir Vista être adopté par les utilisateurs de XP est un point que nous, éditeurs ou créateurs de logiciels, devons prendre en compte. Il y a un an, on pouvait se dire : "j'ai un nouveau développement, je le démarre en .NET 3.5, Vista sera adopté dans un an par tout le monde". Un an plus tard, Vista n'a pas envahi les PC. .NET 3.5 ne fonctionne pas très bien sous XP, qui reste une cible très importante pour nos logiciels. Les utilisateur ne veulent pas de fatware. Le C++ a encore un bel avenir.

     

    Tags  | 
     5 January 2008, 15:25
    # Wednesday, December 26, 2007

    Codejock est l'éditeur de la librairie de classe MFC eXtreme Toolkit Pro. C'est le concurrent de BCG Soft, dont la technologie a été achetée par Microsoft pour être incluse dans la prochaine version de MFC.

    Codejock est en train de développer une fonctionnalité assez étonnante : le support d'une partie de XAML en C++ natif. Noooon ?? Si !

    C'est vrai après tout ! XAML est le langage de description d'interface de .NET 3.5 (WPF). Mais pourquoi être obligé d'utiliser .NET pour faire du XAML ? C'est la question que Codejock s'est posée. Du coup, nous allons bientôt avoir droit à une implémentation de XAML en C++ natif.

    Hum, ça veut dire quoi "une implémentation de XAML en C++ natif" ? Eh bien tout simplement que nous aussi, développeurs C++/MFC, pourrons bientôt utiliser XAML et Expression Blend pour coder nos interfaces. Je dois avouer que j'enviais énormément ce privilège aux développeurs C# .NET 3.5.

    Quel intérêt ? Développer des interfaces utilisateurs très sympa, sans s'encombrer de la lourdeur de WPF. Je ne sais pas si vous avez déjà lancé une application écrite en XAML pour WPF, mais c'est loooonnng à se lancer, et ça nécessite énormément de mémoire. Et WPF sous Windows XP, ce n'est pas tout à fait ça (à moins que quelqu'un ne me contredise...)

    Voici quelques exemples d'interfaces écrite en XAML :

    L'exemple ci-dessus est écrit entièrement en XAML (le code XAML est ici (12 Ko)). Ce code XAML peut au choix être utilisé avec WPF pour faire une application en code managé et WPF, ou alors être utilisé par le module XAML de Codejock pour faire une application C++ natif.

    Ci-dessus, du code XAML est utilisé pour créer des contrôles dans une application C++/MFC. On reconnaît la listbox multi-ligne, multi-format : une spécialité de XAML et WPF !

    Cette fonctionnalité de Codejock ne supportera pas tout XAML, du moins dans la première version ;). Je ne sais pas quand cela sera disponible, mais à vue de nez... sans doute en même temps que les nouvelles MFC !

    En tous cas, le rachat d'une partie de la librairie de BCG Soft par Microsoft a pour effet de dynamiser le développement C++ ! Vivement la suite !

     

    Tags  |  | 
     26 December 2007, 18:45
    # Thursday, December 13, 2007

    Les TechDays, c'est la grand-messe annuelle à Paris, où Microsoft nous présente pendant 3 jours les nouvelles technos de développement liées à Windows. Un événement d'autant plus incontournable qu'il est gratuit et ouvert à tous ceux qui s'intéressent au développement d'applications (et qu'il y a à manger :-p).

    Grande première pour la prochaine édition : il y aura une session sur Visual C++ ! Microsoft associe à nouveau "Nouvelles technologies" et "C++".

    Les nouveautés de Visual C++ 2008 animé par Eric Mittelette, Eric Vernié
    Le lundi 11 février 2008, 11:00 - 12:00.

    Une session consacrée aux nouveautés de Visual C++ 2008, à la fois pour le développeur C++ Natif, et pour le développeur C++/CLI (C++ qui cible .NET). Venez découvrir les nouvelles bibliothèques STL/CLR et marshalAs, qui font de C++/CLI, LE langage d'intéropérabilité entre le monde natif (Win32) et le monde .NET. Mais les développeurs natifs ne seront pas en reste, car une surprise les attend avec les nouvelles bibliothèques MFC.

    La session sera dense : une heure pour présenter les nouveautés C++/CLI et MFC !

    Pour tout savoir sur les Techdays 2008 et s'inscrire gratuitement, rendez-vous sur :

    Retrouvez-moi aux Microsoft TechDays 2008

    Tags  | 
     13 December 2007, 12:41
    # Wednesday, November 28, 2007

    Le site MSDN, c'est un peu comme le Musée du Louvre : même en y revenant plusieurs fois, on y trouve toujours quelque chose qu'on n'avait pas remarqué avant.

    La page "How do I ?" Videos for Native Code contient une cinquantaine de vidéos (en anglais) de 15 à 20 minutes. S'il y a quelques sujets sur l'interopérabilité code natif/code managé, la plupart des vidéos concernent exclusivement le code natif C++. Le niveau va de l'initiation, à des sujets plus avancés comme le debogage distant ou encore l'utilisation du Kernel Transaction Manager de Vista !

     

    Et pendant que je suis sur le site MSDN, un petit clin d'oeil. Comparez les trois pages ci-dessous. Il y en a une qui est à jour, les autres pas encore ;-) :

    http://msdn2.microsoft.com/en-us/vstudio/default.aspx (page du site MSDN américain)
    http://msdn2.microsoft.com/en-gb/vstudio/default.aspx (la même page, sur le site anglais UK)
    http://msdn2.microsoft.com/fr-fr/vstudio/default.aspx (la même page, en français)

     

    Tags  |  | 
     28 November 2007, 01:20

    Une vidéo de 46 minutes sur channel 9 nous fait découvrir que C++ en tant que langage non managé existe, et continuera d'exister. La plate-forme C++/MFC, bien que quasiment non mise à jour depuis 6 à 8 ans, a toujours des utilisateurs. Microsoft commence (?) à entendre que C++/MFC ne peut pas forcément être remplacé par C++ managé ou C#/VB.

    Steve Teixeira (Visual C++ manager) fait part de ses commentaires sur la sortie de la prochaine version des MFC/TR1 dans quelques mois. La plate forme C++/MFC continuera à évoluer indépendamment de la plate-forme .NET. Ouf !

    Steve Teixeira au TechEd Barcelone
    Steve Teixeira au TechEd de Barcelone

    Au fait, Channel 9 utilise un player vidéo écrit en Silverlight... alors que ce site utilise un peu de F###H, désolé...;)

    Justement, demain je me mets à Silverlight. Il y a une présentation de Silverlight à Paris. Quand j'aurai un moment je remplacerai mon animation F###H en haut de page par une animation Silverlight.

    Voir la vidéo
    Ecouter le podcast (MP3)
    Ecouter le podcast(WMA)
    Telecharger la Vidéo

    Tags  |  | 
     28 November 2007, 00:28
    # Wednesday, November 21, 2007

    Ca y est, j'ai installé VS2008 et migré le projet C++ sur lequel je travaille.

    Ce projet C++ est un projet moyen (40.000 lignes de C++). C'est une application d'imagerie médicale destinée à des chirurgiens, pour leur permettre de travailler avec leurs images au format spécifique Dicom. Ce projet utilise la bibliothèque Codejock, ainsi que les librairies OpenJpeg (jpeg2000), LibTiff, Jpeg Group.

    L'installation de VS2008 est trèèèès longue. Elle dure plusieurs heures (plus d'une demi-journée). Faut dire qu'il y en a des composants .NET à installer ! Ne faites pas comme moi, ne l'installez pas un mardi, le jour des patches de Vista (patch tuesday), pour ne pas avoir à rebooter au milieu de l'installation ;). Lancez l'installation un soir, ce sera bon pour le lendemain matin.

    Sous Vista x64, tout s'est bien passé. Pour l'instant je garde VS2005 et VS2008. Je n'avais pas installé de béta de VS2008 sur ce PC. D'après Scottgu, il faut désinstaller soigneusement une béta de VS2008 avant d'installer la version finale, et ça n'a pas l'air très simple.

    Deuxième étape pour moi : compiler la librairie Codejock (xTreme Toolkit pro) avec VS2008. Là encore, tout se passe bien avec la dernière version (11.2.1), le programme d'installation de Codejock fait ça tout seul pour VS2008. Comme quoi ils sont bien chez Codejock : leur librairie fonctionne impeccablement sous VS2008. Il avaient sans doute anticipé avec les versions béta de VS2008. C'est dans ces cas là qu'on distingue les pros.

    Lorsque j'ouvre mon projet C++/MFC sous VS2008, l'assistant de conversion de projet ne pose pas de problème. Je récupère bien mes environnements. La compilation du projet (en Unicode) se fait également sans problème, et le logiciel fonctionne.

    Bon, je suis quand même surpris, ça s'est passé tout seul. Je ne sais pas si le compilateur a été modifié. Lors de la sortie de VS2005, le compilateur avait été modifié. La migration avait été plus longue. Il avait fallu modifier le code à plusieurs endroits. Là, non.

    Résultat : en passant de VS2005 à VS2008, la taille du binaire diminue de 50 Ko (sur 3,4 Mo). Le temps de compilation diminue de 10 secondes (moyenne de 2"59 à 2"48).

    Pour un utilisateur C++, pas grand chose ne change, donc. Ce qui est quand même une bonne nouvelle : la migration est facile. Ah si, j'ai quand même l'impression que l'IDE est un peu plus rapide. Je n'ai plus observé ces blocages assez fréquents avec VS2005.

    Est-ce qu'il faut migrer votre projet C++ natif vers VS2008 ? Ma foi, si vous êtes abonné à MSDN et que vous avez VS2008, faites-le : ça a l'air de bien fonctionner. Mais si vous ne faites que du C++ natif, vous ne verrez pas beaucoup de différence entre VS2005 et VS2008. En attendant la nouvelle version des MFC et des librairies C++ dans quelques mois.

     

    Tags  | 
     21 November 2007, 17:52
    # Monday, November 19, 2007

    Toute la famille des produits Visual Studio 2008 (Express, Professional, Team Suite) est disponible ici, y compris les versions gratuites, ou bien sur le site MSDN pour les abonnés.

    A cette occasion, une vidéo très intéressante a été postée sur channel9 : une interview de S. Somasegar (Developer Division VP), Jeff Beehler (mon ex-boss et actuellement VS Team System manager), et Carol Grojean (program manager of VS2008 & .NET 3.5).

    Dans cette vidéo, Soma annonce que pour nous, adeptes du C++, il faudra attendre 2 mois pour obtenir une béta de la nouvelle version des MFC et de C++ TR1. Rendez-vous donc au mois de janvier pour que Visual Studio 2008 devienne -enfin- un outil pour les "vrais" programmeurs ;). Car, si la plupart des nouveautés de VS2008 concernent le code managé (et notamment la révolution LINQ), la plupart des développeurs chez Microsoft programment en C++. Si, si ! C'est le grand chef qui le déclare.

    Plein d'autres choses intéressantes dans cette vidéo...

    Pour la liste des nouvelles fonctionnalités, voir l'article de Scottgu, ou celui de Jeff Beehler pour VSTS.

    Et pour ceux qui voudraient avoir de la conversation dans les salons pendant les pauses des conférences Microsoft, j'ai vu sur le blog de Redo un lien vers un .NET Framework 3.5 Training Kit qui a l'air très intéressant...

    Tags  | 
     19 November 2007, 19:32
    # Wednesday, November 14, 2007

    Comparaison n'est pas raison. Mais quand même...

    Prenons trois petits programmes :

    - Une application de gestion de comptes bancaires (Votre Budget) écrite en C++/MFC avec la librairie BCGSoft, linkée statiquement avec MFC et BCG (oui, la librairie qui va être intégrée dans la prochaine version des MFC)

    - Un petit freeware écrit en VB.NET qui aide à arrêter de fumer, StopClope. On entre la date à laquelle on arrête de fumer, et puis on obtient des récompenses en fonction du nombre de jours qu'on tient sans fumer. Par exemple, j'ai arrêté il y a 101 jours, économisé 707 euros, et j'ai gagné 19 jours d'espérance de vie. Motivant non ?

    - Une application WPF, LCI Intégrale qui affiche des vidéos en streaming.

    Voici à quoi ressemble mon gestionnaire des tâches Vista quand je lance ces trois programmes en même temps :

    Mémoire occupée par les trois applications :

    - C++/MFC/BCG : 5 Mo (13 Mo)

    - Winform : 15 Mo (28 Mo)

    - WPF : 64 Mo (145 Mo)

    A vue de nez, une application WPF occuperait 4 fois plus de mémoire qu'une application Windows Forms, et 12 fois plus qu'une application MFC/BCG.

    Ces trois programmes sont des petites applications, mais les valeurs ne varient pas énormément. Pour donner un ordre de grandeur, j'ai aussi lancé Word 2007 (22 Mo), Photoshop (65 Mo), et Visual Studio (50 Mo).

    Le confort ressenti à l'utilisation de ces applications est directement proportionnel à l'espace mémoire utilisé. Photoshop et Visual Studio sont lourds à utiliser, n'est-ce pas ?

    Ah ! Quel plaisir d'utiliser des logiciels écrits en C++ ! Alors faites plaisir à vos clients, programmez en C++ !

    Tags  |  | 
     14 November 2007, 00:48
    # Tuesday, November 13, 2007

    Mac & PC contiennent du cadmium, beryllium, plomb, mercure...

    Les pubs originales sont là : www.apple.com/getamac/ads/

    C'est un PC sur lequel on a installé trop d'applications .NET :p

    Tags
     13 November 2007, 16:12
    # Sunday, November 11, 2007

    C'est officiel, une grande partie des nouveautés de la nouvelle version des MFC incluse dans Visual Studio 2008 ne sera pas (entièrement) développée par Microsoft, mais a d'ores et déjà été rachetée à la société russe BCGSoft. Il s'agit du produit BCG Controlbar Pro. Pour avoir une idée précise des nouveautés à venir, il suffit d'aller sur la page www.bcgsoft.com/FeatureTour/bcgcontrolbar-tour.htm, il y a de nombreuses captures d'écran.

    J'ai déjà personnellement utilisé BCG Controlbar Pro pour créer différents produits C++/MFC/BCG depuis 2002, et j'ai été très satisfait du résultat. L'utilisation de BCG Controlbar dans une application MFC est relativement simple à mettre en oeuvre, la migration des applications existantes ne devrait pas poser de gros problème. Depuis 2004 j'ai aussi utilisé le concurrent direct, la librairie Codejock (www.codejock.com), plus complète et aussi un peu plus complexe à utiliser.

    Avant que d'ici 6 mois environ, nous puissions disposer de la nouvelle version des MFC, il est déjà possible de télécharger une version d'évaluation de BCG ControlBar ici : www.bcgsoft.com/bcgcontrolbar-download.htm.

    Que vont devenir les deux frères ennemis BCGSoft et Codejock, maintenant que leurs technologies sont "gratuites" avec Visual C++ ? BCGSoft propose aussi d'autres produits pour .NET, et Codejock... ?

    Pour illustrer concrètement cette nouvelle étape des MFC, voici deux captures d'écran de l'exemple de code C++/MFC Drawcli qui est livré avec Visual C++ depuis longtemps... Le voici relooké ! Avant - Après. Sans commentaire !

    Tags  | 
     11 November 2007, 22:10