Accéder au contenu principal

Vaadin, un Framework pour créer des applications Web en Java




Vaadin est un Framework Java permettant de développer une application Web entièrement en Java. Il est certes basé sur GWT (Google Web Toolkit), mais l'utilise de manière relativement transparente. Vaadin est une société Finlandaise qui existe depuis 2007 (initialement sous le nom d'IT Mill Toolkit).
Ses principaux avantages sont :
- une API très proche de Swing
- une librairie Open Source
- de très nombreux Addons gratuits
Ses inconvénients :
- la lourdeur de la librairie (18 Mo minimum) depuis la version 7, essentiellement à cause des thèmes.
- la "relative" complexité dans l'utilisation des Widgetsets et des CSS
- quelques Addons sont payants, tels que les Charts, le Calendar, le TouchKit (il faut bien vivre)
- l'éditeur graphique payant, mais comme avec Swing, on peut s'en passer

Installation dans Eclipse

Pour vous faire une idée de l'interface, vous pouvez regarder les démos : http://demo.vaadin.com/sampler/#.  Cela vous donnera une assez bonne idée de ce que la librairie peut faire.
Vaadin propose un plugin Eclipse pour la création de nouveaux projets. Le plugin est disponible à l'adresse http://vaadin.com/eclipse. Celui ci permet de créer des projets, mais également des thèmes ou de nouveaux Widgets.
Pour la compilation des WidgetSets et des thèmes, un nouveau bouton est rajouté dans la barre de menu.
Le plugin permet également d'installer Vaadin Designer. Cette version nécessite une licence. La version sans licence permet juste d'évaluer l'outil rapidement mais ne permet pas de sauvegarder les modifications. Le Designer nécessite également l'utilisation d'Internet Explorer 10 au moins.

Création de la première application "Click Me"

Une fois le plugin installé, vous pouvez créer votre première application Vaadin. Un exemple est généré par défaut, permettant de tester assez rapidement le Framework.

Création du projet

Sélectionnez un projet Vaadin 7.

Entrez le nom du projet et sélectionnez le conteneur de servlet : Tomcat 7, par exemple.


Modifiez éventuellement les noms des classes si vous souhaitez utiliser ce projet comme modèle ultérieurement. Toutes les versions de Vaadin 7 sont proposées.
Si vous n'avez pas déjà de projet avec la version proposée, la nouvelle version sera automatiquement téléchargée.
 Voici un exemple de l'arborescence ainsi générée.
 Voici le code source généré par défaut

 package com.example.testvaadin76;  
   
 import javax.servlet.annotation.WebServlet;  
   
 import com.vaadin.annotations.Theme;  
 import com.vaadin.annotations.VaadinServletConfiguration;  
 import com.vaadin.server.VaadinRequest;  
 import com.vaadin.server.VaadinServlet;  
 import com.vaadin.ui.Button;  
 import com.vaadin.ui.Button.ClickEvent;  
 import com.vaadin.ui.Label;  
 import com.vaadin.ui.UI;  
 import com.vaadin.ui.VerticalLayout;  
   
 @SuppressWarnings("serial")  
 @Theme("testvaadin76")  
 public class Testvaadin76UI extends UI {  
   
      @WebServlet(value = "/*", asyncSupported = true)  
      @VaadinServletConfiguration(productionMode = false, ui = Testvaadin76UI.class)  
      public static class Servlet extends VaadinServlet {  
      }  
   
      @Override  
      protected void init(VaadinRequest request) {  
           final VerticalLayout layout = new VerticalLayout();  
           layout.setMargin(true);  
           setContent(layout);  
   
           Button button = new Button("Click Me");  
           button.addClickListener(new Button.ClickListener() {  
                public void buttonClick(ClickEvent event) {  
                     layout.addComponent(new Label("Thank you for clicking"));  
                }  
           });  
           layout.addComponent(button);  
      }  
   
 }  

Exécution

Pour exécuter cette première application, cliquez avec le bouton droit et sélectionnez "Debug on the Server", puis sélectionnez Tomcat 7.
L'application démarre et ouvre une fenêtre dans le navigateur interne d'Eclipse. Les traces s'affichent en dessous et vous pouvez mettre des points d'arrêts.

Une fois l'application testée, elle peut être exportée sous la forme d'un fichier War complet qui ainsi peut être déployé dans n'importe qu'elle conteneur de servlet.

Conclusion

Vaadin montre que l'on peut faire des applications Web entièrement en Java à la manière de Swing. Cela peut sembler simple au départ, mais peut vite se complexifier dès que l'on souhaite avoir des interfaces beaucoup plus évoluées. Fort heureusement, la communauté autour de Vaadin apporte son lot d'addons qui en simplifient largement l'utilisation : https://vaadin.com/directory#!browse. Le principal avantage pour un développeur Swing est qu'il n'est pas trop dépaysé (voir https://vaadin.com/swing) et que la phase de débogage reste à peu près similaire. Il existe des solutions un peu similaires, telles que http://www.webswing.org, mais Vaadin offre des possibilités qui vont bien plus loin que Swing pour le monde Web.
Un des inconvénients est cependant que pour la moindre modification, il faut recompiler et relancer l'application, ce qui n'est pas toujours nécessaire avec des Frameworks basés sur du XHTML. Essayez par vous mêmes pour vous faire votre propre opinion. Personnellement, je trouve que ce Framework Open Source vaut largement le détour.

Long Life Vaadin


Commentaires

Posts les plus consultés de ce blog

Utilisez votre tablette Android comme second écran pour Linux (Raspberry Pi, MK908II)

Les tablettes Android atteignent désormais des prix qui défient toute concurrence. On trouve désormais des modèles à 39 € TTC en super marché, soit à peine plus cher que le Raspberry PI, mais avec un écran. Ces modèles souvent mono-core 1Ghz ou 1,4 Ghz avec 512 ou 1Go de mémoire ne sont très probablement pas utilisables pour une utilisation régulière sur Internet et ne sont en aucun point comparables à leur équivalent de marque (Samsung, Sony, LG, HTC, Lenovo, etc). Plusieurs tutoriels indiquent comment connecter utiliser une tablette Android comme second écran ( http://www.linux-magazine.com/Online/Blogs/Productivity-Sauce/Use-an-Android-Device-as-Screen-and-Input-for-Raspberry-Pi ). Ces méthodes utilisent généralement l'USB Tethering qui n'est malheureusement disponible que sur les téléphones ou tablettes avec un accès mobile (3G ou 4G) inclus. Dans ce billet, je vais vous montrer comment se connecter à une tablette en utilisant le mode Debug adb (Android Debug Bridge...

Ardublock ou S4A pour développer graphiquement

Si vous n'aimez pas le développement en C, ou C# sur les micro-contrôleurs, vous pouvez vous essayer au développement graphique avec Ardublock. Historique Cet environnement de développement est issu d' OpenBlocks développé par le MIT qui se positionne lui même dans la suite du langage Logo de Seymour Papert . Le langage Logo est un langage issu de l'Intelligence Artificielle dans les années 1970 dont l'objectif était de faciliter l'apprentissage de la programmation à de jeunes enfants par le biais du pilotage d'une tortue munie d'un crayon. Les ordres étaient relativement simples : avance de 90 cm, tourne à droite de 90°, etc. Ceci, permettait de réaliser des dessins assez simple, de piloter un petit robot et d'apprendre la programmation. C'était cependant un langage textuel. Exemple pour tracer un carré : POUR CARRE REPETE 4 [AV 100 TD 90] FIN   Son digne successeur, le langage Scratch désormais intégré à l'image Raspbian du Raspberry Pi...

Hack du RoboSapien en Infra-Rouge

Mon fils a eu un RoboSapien V1 il y a une dizaine d'années. Il prenait la poussière sur le haut d'une armoire, jusqu'à ce que j'ai envie de le ramener à la vie. Il était temps, les piles étaient en train de commencer à couler et vu le nombre de servo moteurs qu'il contient, ses jours étaient comptés. Mais non, j'ai réussi à contenir mon irrésistible envie de tout démonter et j'ai décidé de passer par la télécommande Infrarouge pour le piloter. Le protocole est assez similaire de celui d'une télécommande infrarouge classique avec cependant quelques petites différences. Il est correctement expliqué sur les sites http://www.aibohack.com/robosap/ir_codes.htm et http://www.markcra.com/robot/ir_codes.php . Je vais traduire en français pour ceux qui auraient un peu de difficulté. Il existe des librairies Arduino, mais comme d'habitude, pas toujours de librairie en C#. Voici les choses importantes à connaitre sur le protocole : Le protocole envoie...