SwingStates programmation d interactions graphiques en Java

Documents pareils
Objets et Programmation. origine des langages orientés-objet

Desktop Intégration. Rémi Forax

Premiers Pas en Programmation Objet : les Classes et les Objets

Auto-évaluation Programmation en Java

Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;

TP1. Outils Java Eléments de correction

Java Licence Professionnelle CISII,

Développement mobile MIDP 2.0 Mobile 3D Graphics API (M3G) JSR 184. Frédéric BERTIN

Polymorphisme, la classe Object, les package et la visibilité en Java... 1

Initiation à JAVA et à la programmation objet.

as Architecture des Systèmes d Information

Java Licence Professionnelle Cours 7 : Classes et méthodes abstraites

Corrigé des exercices sur les références

Encapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets.

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère

Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre Enrica.Duchi@liafa.jussieu.fr

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

Programmer en JAVA. par Tama

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars

Structure d un programme et Compilation Notions de classe et d objet Syntaxe

TD3: tableaux avancées, première classe et chaînes

Corrigés des premiers exercices sur les classes

Anne Tasso. Java. Le livre de. premier langage. 10 e édition. Avec 109 exercices corrigés. Groupe Eyrolles, , ISBN :

Langage et Concepts de ProgrammationOrientée-Objet 1 / 40

TP1 : Initiation à Java et Eclipse

Ingénérie logicielle dirigée par les modèles

Interfaces graphiques avec l API Swing

Licence Bio Informatique Année Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...

Héritage presque multiple en Java (1/2)

TD/TP PAC - Programmation n 3

Java Licence Professionnelle CISII, Cours 2 : Classes et Objets

Cours 2 : programmation des interfaces graphiques

Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004

Projet de programmation (IK3) : TP n 1 Correction

Programmation par les Objets en Java

Bases Java - Eclipse / Netbeans

Développement Logiciel

Programmation avec des objets : Cours 7. Menu du jour

Design patterns. Design patterns - définition. Design patterns - avantages

Environnements de développement (intégrés)

Cours. Cours 8 : Révisions. Importance. Interface homme-machine

Remote Method Invocation Les classes implémentant Serializable

TD/TP PAC - Programmation n 3

Un ordonnanceur stupide

Java 7 Les fondamentaux du langage Java

Remote Method Invocation (RMI)

Apprendre la Programmation Orientée Objet avec le langage Java (avec exercices pratiques et corrigés)

Introduction au langage Java

Langage Java. Classe de première SI

Cours 1: Java et les objets

8. Gestionnaire de budgets

Programme Compte bancaire (code)

Gestion distribuée (par sockets) de banque en Java

Chapitre 10. Les interfaces Comparable et Comparator 1

JAVA TD0. Prise en main du langage Environnement de base JAVA 1

Création d un service web avec NetBeans 5.5 et SJAS 9

Tp 1 correction. Structures de données (IF2)

Package Java.util Classe générique

Polycopié Cours Programmation Orientée Objet sous Java Programme : Filière SMI S5

Utilisation d objets : String et ArrayList

Info0604 Programmation multi-threadée. Cours 5. Programmation multi-threadée en Java

Générer du code à partir d une description de haut niveau

Pour les futurs développeurs Sommaire

LMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr

ACTIVITÉ DE PROGRAMMATION

Synchro et Threads Java TM

Threads. Threads. USTL routier 1

JADE : Java Agent DEvelopment framework. Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.

RMI le langage Java XII-1 JMF

Cours 1 : Introduction. Langages objets. but du module. contrôle des connaissances. Pourquoi Java? présentation du module. Présentation de Java

Chapitre VI- La validation de la composition.

Formation VBA 3 Interagir

Programmation en Java IUT GEII (MC-II1) 1

Cette application développée en C# va récupérer un certain nombre d informations en ligne fournies par la ville de Paris :

Silhouette Studio Leçon N 2

Solutions du chapitre 4

Flux de données Lecture/Ecriture Fichiers

INF 321 : mémento de la syntaxe de Java

Java c est quoi? Java pourquoi?

Java Aspect Components (JAC)

Programmation Réseau. Sécurité Java. UFR Informatique jeudi 4 avril 13

Classe Interne, Anonyme & Enumération

Applet pour visualiser les variables «automate» notifiées

Programmation Objet Java Correction

Introduction : les processus. Introduction : les threads. Plan

OpenPaaS Le réseau social d'entreprise

Comment sélectionner des sommets, des arêtes et des faces avec Blender?

Plan du cours. Historique du langage Nouveautés de Java 7

SSL. Secure Socket Layer. R. Kobylanski janvier version 1.1 FC INPG. Protocole SSL Application avec stunnel

1 Démarrer L écran Isis La boite à outils Mode principal Mode gadget Mode graphique...

PROGRAMMATION PAR OBJETS

Construire des plug-ins pour SAS Management Console SAS 9.1

Une introduction à Java

TP1 : Initiation à Java et Eclipse

Introduction au langage C

Quelques patterns pour la persistance des objets avec DAO DAO. Principe de base. Utilité des DTOs. Le modèle de conception DTO (Data Transfer Object)

Langage et Concepts de Programmation Objet. 1 Attributs et Méthodes d instance ou de classe. Travaux Dirigés no2

TD Objets distribués n 3 : Windows XP et Visual Studio.NET. Introduction à.net Remoting

Tutoriel BlueJ. Michael Kölling Mærsk Institute University of Southern Denmark. Version 1.4 fr-2 par le groupe Sigma 1 pour BlueJ Version 1.2.

Transcription:

SwingStates programmation d interactions graphiques en Java Michel Beaudouin-Lafon - mbl@lri.fr Caroline Appert - appert@lri.fr http://swingstates.sourceforge.net

Programmer l interaction en Java Listeners implémentation en Java d une fonction de rappel un objet listener est associé à un widget une méthode de ce listener est appelée lorsque le widget change d état Avantages concept simple notation facilitée avec les classes internes anonymes Inconvénients une interaction complexe est répartie dans plusieurs listeners la logique de l interaction est difficile à suivre maintenance difficile Alternative : les machines à états

Machines à états Automates à états fini Etat (cercle) = état de l interaction Transition (flêche) = événements d entrée (Up, Down, Move,...) Machine à états actions associées aux transitions (après le / ) conditions associées aux transitions (après le & ) Exemple : "Rubber-band" Down / Record (P1) Move / Draw (P1,current) Up / Done(P1,current)

Machines à états Combiner sélection et tracé Hystéresis : le tracé ne démarre qu après un déplacement suffisant Down / Record (P1) Move & dist (P1, current) >= eps Up / Click (P1) Up / Moved (P1, current) Move / Drag (P1, current)

Machines à états Combiner sélection et tracé Hystéresis : le tracé ne démarre qu après un déplacement suffisant Down / Record (P1) Drag & dist (P1, current) >= eps Up / Click (P1) Up / Done (P1, current) Drag / Draw (P1, current)

SwingStates : principes de base Dessin structuré : widget Canvas liste d affichage de formes graphiques formes graphiques définies par une géométrie des attributs graphiques des tags gestion de l affichage et du picking Machines à états spécification directement en Java des états et des transitions association à un Canvas association à un widget Swing quelconque

Widget Canvas : dessin structuré Hello Liste d affichage : Affichage dans l ordre de la liste : le premier objet est sous les autres Picking dans l ordre inverse pour respecter l ordre de superpostion Géométrie : CPolyline : forme quelconque CRectangle, CEllipse : formes simples CText : chaîne de caractères Hello CImage : image CWidget : widget Swing

Dessin structuré : géométrie - transformations affines translation, rotation, changement d échelle - un objet peut avoir un parent : ses coordonnées sont relatives à ce parent ici les poignées ou pour parent le rectangle et sont transformées avec celui-ci - un objet peut avoir une forme de clipping : il n est visible qu à l intérieur de cette forme

Dessin structuré : relations entre objets Affichage dans l ordre de la liste, «Picking» dans l ordre inverse Chaque objet peut être affichable ou non, «pickable» ou non Hello Hello Relation hiérarchique (parent) indépendante de l ordre d affichage : le parent peut être avant ou après le fils dans la liste (idem pour le clipping) Cut Copy Paste Paste Copy Cut Paste Copy Cut

Dessin structuré : attributs graphiques Formes géométriques : - affichage du fond et/ou du bord - peinture de fond (Paint de Java2D) - forme et peinture du bord (Stroke et Paint de Java2D) - transparence Texte : - police de caractères (Font de Java2D) - couleur (Paint de Java2D) - transparence Image : - fichier contenant l image - transparence Hello Hello Hello Hello

Dessin structuré : syntaxe enchaînée Les méthodes de SwingStates renvoient le plus souvent l objet this Ceci permet d enchaîner les appels : shape = new CRectangle(...); shape.setfillcolor(color.red).setstroke(new BasicStroke(1)).translateBy(10,100).rotateTo(45).setParent(...)... ; canvas = new Canvas(...); shape1 = new CRectangle(...);... shape2 = new CEllipse(...);... canvas.addshape(shape1).addshape(shape2)....; canvas = new Canvas(...); canvas.newrectangle(...).setfillcolor(color.red)...; Attention : ici newrectangle retourne le Shape, pas le canvas. Ceci permet de spécifier les attributs du rectangle à la suite.

Dessin structuré : tags Tag = étiquette - chaque objet peut avoir 0, 1 ou plusieurs tags - un même tag peut être mis sur 0, 1 ou plusieurs objets g1 g1 movable g1 Hello movable On peut appliquer aux tags la plupart des opérations que l on peut appliquer à un objet, par exemple déplacer ou changer la couleur : tag.rotateby(45).setfillcolor(color.blue)... Deux rôles : - manipuler des groupes d objets - définir les interactions applicables aux objets

Dessin structuré : deux types de tags Tags extensionnels - CExtensionalTag posés explicitement sur chaque objet (addtag, removetag) méthodes added et removed du tag appelées lorsque le tag est ajouté ou retiré d un objet le plus fréquemment utilisé : CNamedTag Tags intensionnels - CIntentionalTag définis par un prédicat (méthode criterion ) à définir dans une sous-classe l ensemble des objets qui ont le tag est calculé à chaque utilisation du tag en testant le prédicat sur chaque objet du canvas potentiellement coûteux une classe utile : CHierarchyTag tag intensionnel qui contient tous les descendants (par le lien parent) d un objet

Dessin structuré : animation Certains attributs géométriques et graphiques peuvent être animés couleur de bord et de fond degré de transparence position, taille, rotation // créer une forme rect = canvas.newrectangle(100, 150, 1, 1); // définir l animation animation = new AnimationScaleTo(400, 600); // l associer à la forme rect.animate(animation); // l animation commence immédiatement D autre animations peuvent être définies en étendant la classe de base Animation

Machines à états Forme graphique pour la création et le déplacement d une forme graphique Click() CreateEllipse() PressOn(ellipse) Select(ellipse) start drag Release() Deselect(ellipse) Drag() Move(ellipse) Forme textuelle idéalisée : chaque état contient ses transitions sortantes Etat start {!! Transition PressOn(ellipse) => drag {Select(ellipse)!! Transition Click => start {CreateEllipse()!! Etat drag {!! Transition Drag => drag {Move(ellipse)!! Transition Release => start {Deselect(ellipse)!

Machines à états : syntaxe Java Utilisation des classes anonymes pour ressembler à la forme textuelle StateMachine sm = new CStateMachine () {! // déclarations locales!...! public State start = new State ()!!!!!!!!!!!!

Machines à états : syntaxe Java Le premier état est l état initial StateMachine sm = new CStateMachine () {! // déclarations locales!...! public State start = new State () {!!!!!! public State drag = new State () {!!

Machines à états : syntaxe Java Utilisation des classes anonymes également pour les états et les transitions StateMachine sm = new CStateMachine () {! // déclarations locales!...! public State start = new State () {!! Transition t1 = new Press (BUTTON1, => drag ) {!!! public void action () { // do something!!!!!! public State drag = new State () {!!!

Machines à états : syntaxe Java Les transitions sont testées dans l ordre de leur déclaration StateMachine sm = new StateMachine ( sm ) {! // déclarations locales!...! public State start = new State () {!! Transition t1 = new Press (BUTTON1, => drag ) {!!! public void action () { // do something!!!! Transition t2 =...!! public State drag = new State () {!!...!

Machines à états : syntaxe des transitions Transition t1 = new <Transition>(<paramètres>,<état d arrivée>) {! public boolean guard () {...! // garde (optionnelle)! public void action () {...! // action (optionnelle) <Transition> : Type de l événement (Press, Release, Drag, Move, TimeOut, Key etc.) et éventuellement son contexte (OnShape, OnTag, etc.) <paramètres> : Informations supplémentaires : bouton utilisé, touche du clavier, etc. <état d arrivée> : spécifié sous forme d une chaîne de caractères : s1 correspond à l état déclaré State s1 =... les caractères -, =, > et espace sont ignorés : on peut écrire -> s1 ou ==> s1 ou >> s1, etc.

Machines à états : syntaxe des états public State s1 = new State() {! // déclarations locales si besoin!...! // appelé lorsque l état devient actif (optionnel)! public void enter () {...! // appelé lorsque l état devient inactif (optionnel)! public void leave () {...!! // déclarations des transitions! Transition t1 = new...!... les états doivent être déclarés public pour être visible des transitions les transitions peuvent accéder aux variables et méthodes de l état englobant et de la machine à états englobante les états peuvent accéder aux variables et méthodes de la machine à états englobante.

Forme générale d une application class MyWidget extends Canvas {! // déclarations locales!...! // machines à états! CStateMachine m1 = new CStateMachine () {...! CStateMachine m2 = new CStateMachine () {...! // constructeur! MyWidget () {!! // créer le contenu du canvas!!!!!! newrectangle(...);!!...!! // activer une machine à états (on peut en activer plusieurs)!! attachsm(m1, true);!!...

Forme générale d une application class MyWidget extends Canvas {!!...! // programme principal! public static void main(string[] args) {!! JFrame frame = new JFrame();!! MyWidget widget = new MyWidget();!! frame.getcontentpane().add(widget);!! frame.pack();!! frame.setvisible(true);!

Visualisation d une machine L appel new StateMachineVisualization(sm) crée un composant Swing contenant une visualisation graphique animée de la machine à états L état courant et la dernière transition déclenchée sont colorés Chaque machine peut également avoir des listeners qui sont déclenchés pendant le fonctionnement de la machine

Reconnaissance de gestes SwingStates implémente deux algorithmes de reconnaissance de geste : Rubine et $1 (Wobbrock) L application Training permet de créer des fichiers vocabulaire(s) de gestes java -jar SwingStates.jar fr.lri.swingstates.gestures.training Construire un classifieur classifier = RubineClassifier.newClassifier("classifier/cutcopypaste.cl"); classifier = Dollar1Classifier.newClassifier("classifier/cutcopypaste.cl"); Classifier un geste! String gc = classifier.classify(gesture); L écho de la trace doit être fait par l application. Typiquement, une machine gère le dessin de l encre et envoie des événements correspondants aux gestes reconnus à une autre machine. Voir l exemple dans le tutorial en ligne

Reconnaissance de gestes smgesture = new CStateMachine(c) {!public State start = new State() {!!!Transition copy = new EventOnShape("copy"){...;!!!Transition cut = new EventOnShape("cut"){...;!!!Transition paste = new EventOnPosition("paste"){...;!; ; smink = new CStateMachine(c) {!public State start = new State() {!!!Gesture gesture = new Gesture();!!!Transition begin = new Press(BUTTON1, ">> drag"){...gesture.reset();...;!!public State drag = new State() {!!!Transition draw = new Drag(BUTTON1){... gesture.addpoint(...);... ;!!!Transition end = new Release(BUTTON1, ">> start"){...!!!! GestureClass gc = classifier.classify(gesture);!!!! if(gc!= null) canvas.processevent(gc.getname(), getpoint());!!!...;!;!

Contrôler l explosion du nombre d états Communication entre machines machines de bas niveau pour les événements d entrée envoient des événements à des machines de plus haut niveau Machines en parallèle pour gérer des interactions indépendantes exemple : tooltips et sélection Exploiter l héritage pour factoriser des états communs

Contrôler l explosion du nombre d états Communication entre machines Une machine peut émettre des evts (fireevent) Une machine peut être écoutée (addstatemachinelistener) Machines en parallèle Exploiter l héritage pour factoriser des états communs

Les tags extensionnels Apposés explicitement sur les objets graphiques Actions associées à l ajout / retrait d un tag Exemple : selection CExtensionalTag selectiontag = new CExtensionalTag() {! public void added(cshape s) {!! s.setfillpaint(color.green);!! public void removed(cshape s) {!! s.setfillpaint(color.light_gray);! ;... // Dans une machine à états Transition select = new ClickOnShape(BUTTON1) {! public void action() {!! if(getshape().hastag(selectiontag)) moved.removetag(selectiontag);!! else moved.addtag(selectiontag);!

Les tags intentionnels ne sont pas apposés explicitement sur les objets graphiques définis par un prédicat Exemple : selection CIntentionalTag uptag = new CIntentionalTag {! public boolean criterion(cshape s) {!! return s.getmaxy() < 500;! uptag.translateby(0, 50); uptag.setfillpaint(color.light_gray); L ensemble des objets "taggés" est calculé à chaque utilisation

Un événement, trois contextes Dans SwingStates, il y a 3 types de contexte pour un même événement : : l evt est survenu n importe où (ex : Click) OnShape : l evt est survenu sur une forme (ex : ClickOnShape) OnTag : l evt est survenu sur une forme "taggée" (ex : ClickOnTag)!!!! Transition t = new ClickOnShape(BUTTON1) {... Transition t = new Click(BUTTON1) { public boolean guard() {... return canvas.pick(getpoint())!= null; Transition t = new ClickOnTag(selectionTag, BUTTON1) {... Transition t = new ClickOnShape(BUTTON1) { public boolean guard() {... return getshape().hastag(selectiontag);

Ordre des transitions Lors d un événement, l algorithme de SwingStates essaie de déclencher les transitions selon l ordre : De la plus spécifique à la moins spécifique : OnTag > OnShape > A spécificité égale, l ordre respecté est l ordre de déclaration La première transition "déclenchable" est déclenchée. g1 movable click Transition t = new ClickOnShape(BUTTON1) {... Transition t = new Click(BUTTON1) {... Transition t = new ClickOnTag("g1", BUTTON1) {... Transition t = new ClickOnShape(BUTTON1) {... Transition t = new Click(BUTTON1) {... Transition t = new ClickOnTag("movable", BUTTON1) {... Transition t = new ClickOnTag("g1", BUTTON1) {...

Machines à états pour widgets Swing La classe JStateMachine permet de redéfinir l interaction avec un widget Swing quelconque Les transitions ont le suffixe OnComponent La machine peut être attachée à un widget particulier, à tous les widgets de la même classe, ou à tous les widgets qui ont un tag (classes JTag, JNamedTag) smwidgets = new JStateMachine() {... public State out = new State() { Transition enter = new EnterOnComponent(">> in") { public void action() { initcolor = getcomponent().getbackground(); getcomponent().setbackground(color.yellow); ; ;... ;... smwidgets.attachto(getcontentpane());

Aperçu des classes StateMachine CStateMachine JStateMachine State Transition Canvas CShape CRectangle CEllipse CPolyline CText CImage Animation CTag CExtensionalTag CNamedTag CIntentionalTag JTag JExtensionalTag JNamedTag Gesture GestureClass AbstractClassifier RubineClassifier Dollar1Classifier Sous-classes de Transition Click ClickOnShape ClickOnTag Press PressOnShape PressOnTag Release ReleaseOnShape ReleaseOnTag Drag DragOnShape DragOnTag Move MoveOnShape MoveOnTag Enter EnterOnShape EnterOnTag Leave LeaveOnShape LeaveOnTag KeyPress KeyRelease KeyType TimeOut