IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Composants Java Discussion :

Logging et écriture en parallèle dans JTextArea


Sujet :

Composants Java

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Août 2009
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2009
    Messages : 23
    Par défaut Logging et écriture en parallèle dans JTextArea
    Bonjour a tous !
    Je vous écrit car je suis face à un (léger) mur dans le développement d'un projet.
    Actuellement, l'application que je développe est une application Console. Elle réalise un suivi des messages affichés en console par le bais d'un Logger (java.util.logging.Logger).
    Je passe à la seconde phase du projet, qui est de créer une IHM, dans laquelle j'ai une sorte de mini-terminal (une JTextArea donc). Le but est que les messages écrits dans le Logger, soient également affichés dans ce JTextArea.
    Le problème est que je ne vois pas comment faire, pour que dès qu'une écriture se fait dans le Log, elle se fasse également dans le JTextArea concerné.

    Merci à tous !

  2. #2
    Rédacteur/Modérateur

    Avatar de bouye
    Homme Profil pro
    Information Technologies Specialist (Scientific Computing)
    Inscrit en
    Août 2005
    Messages
    6 904
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Nouvelle-Calédonie

    Informations professionnelles :
    Activité : Information Technologies Specialist (Scientific Computing)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2005
    Messages : 6 904
    Billets dans le blog
    54
    Par défaut
    Tu connais le pattern observateur ? => Logger.addHandler(Handler handler)

    Citation Envoyé par http://download.oracle.com/javase/6/docs/api/java/util/logging/Handler.html
    A Handler object takes log messages from a Logger and exports them. It might for example, write them to a console or write them to a file, or send them to a network logging service, or forward them to an OS log, or whatever.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    public class MyTextAreaHandler extends Handler {
     
      private JTextAre textArea;
     
      public MyTextAreaHandler(JTextArea output) {
       this.textArea = output;
      }
     
      /**
      * {@inheritDoc}
      */
      @Override 
      public void publish(final LogRecord record) {
        SwingUtilities.invokeLater(new Runnable() {
          /**
          * {@inheritDoc}
          */
          @Override 
          public void run() {
            textArea.setText(...);
          }
        });
      }
    }
    Merci de penser au tag quand une réponse a été apportée à votre question. Aucune réponse ne sera donnée à des messages privés portant sur des questions d'ordre technique. Les forums sont là pour que vous y postiez publiquement vos problèmes.

    suivez mon blog sur Développez.

    Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to produce bigger and better idiots. So far, the universe is winning. ~ Rich Cook

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Août 2009
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2009
    Messages : 23
    Par défaut
    Bonjour, désolé du retard !
    Oui oui je connais le pattern Observateur ;D
    Je vous remercie, c'est bel et bien ça que je voulais
    J'avais cherché de ce coté là, je suis tombé sur pleins de sites où ils parlaient de TextHandler, mais je n'ai jamais pensé à faire quelque chose du style
    Bonne journée et merci pour l'aide !

  4. #4
    Membre très actif
    Homme Profil pro
    Inscrit en
    Avril 2011
    Messages
    214
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Avril 2011
    Messages : 214
    Par défaut
    Bonjour,

    Petite exception qui confirme la règle, il n'est pas nécessaire d'appeler setText depuis l'EDT. Dans le cas présent
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
      public void publish(final LogRecord record) {
        textArea.setText(...);
      }
    est donc suffisant.

    This method is thread safe, although most Swing methods are not. Please see Threads and Swing for more information
    source

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Ecriture de "LOG" dans JTextArea
    Par Supersonik dans le forum AWT/Swing
    Réponses: 4
    Dernier message: 18/05/2011, 17h33
  2. Insertion de tableau dans JTextArea et MouseListener
    Par Janitrix dans le forum Composants
    Réponses: 1
    Dernier message: 05/11/2005, 01h08
  3. Logs SQL des actions réalisées dans Enterprise Manager ?
    Par [DreaMs] dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 11/08/2005, 12h14
  4. [KeyLister] Probleme dans JTextArea
    Par gl0be dans le forum Composants
    Réponses: 9
    Dernier message: 12/05/2005, 14h25
  5. [Débutant] Scrolls dans JTextArea
    Par k-reen dans le forum Composants
    Réponses: 2
    Dernier message: 30/06/2004, 16h14

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo