comment faire en sorte que un Jtextarea [java] - Java - Programmation
Marsh Posté le 16-11-2004 à 20:11:08
alors on va commencer par apprendre à écrire et énoncer son problème correctement.
tu ne peux pas utiliser l'héritage? pourquoi? et c'est quoi le rapport?
Marsh Posté le 16-11-2004 à 22:35:42
il faut que tu passes la référence de ton Jtextarea ou de ton objet principal aux autres objets qui en ont besoin (ceux qui veulent modifier le JTextArea).
Tu peux par exemple le leur passer au moment où tu les construit (en parmatêtre du constructeur), ou avec une méthode genre setTaClassPrincipale(TaClassPrincipale t). Les objets en question garde une référence de cet objet et quand ils en ont besoin, il l'appelle.
Ca s'appelle de l'agrégation ...
Marsh Posté le 16-11-2004 à 22:41:20
question dans le même style, mais plus poussée : g plusieurs JInternalFrame qui contiennent plein de champs dont je veux récupérer les valeurs (des JTextField et JComboBox principalement), et qui contient aussi un tableau qui interragit avec les champs (si tu sélectionnes une ligne, ca remplit les champs avec les bonnes valeurs)
Pour le moment j'ai tous les listener dans chaque classe, mais ca me broute, parce que :
- les traitements sont les mêmes
- c sale 30.000 innerclasses en fin de classe...
Marsh Posté le 16-11-2004 à 22:43:28
benou a écrit : il faut que tu passes la référence de ton Jtextarea ou de ton objet principal aux autres objets qui en ont besoin (ceux qui veulent modifier le JTextArea). |
euh , ha, c'était ça la question? pfiou, on revient de loin là
Marsh Posté le 16-11-2004 à 22:54:33
jubijub >> c'est quoi ton probleme? tes listeners? t'est pas obligé d'en faire des inner class hein.. tu peux avoir une classe propre et l'instancier plusieurs fois ...
Marsh Posté le 16-11-2004 à 23:01:11
comment expliquer ca : l'idée c que pour chaque fenetre, je dois pouvoir faire des set et des get sur les valeurs des fields...les gets étant pour activer un constructeur avec les paramètres, et les sets pour réagir au recherches dans le tableau...
sinon je sais bien qu'on peut les sortir, mais le pb, si je les sort, c comment récupérer facilement ce que j'ai dans mes fields ?
j'ai pensé peut etre en passant une ref sur le JPanel qui les contient...mais après comment récupérer ce qu'il contient dans un ordre fixe ?
Marsh Posté le 16-11-2004 à 23:06:45
dans tous tes panels, c'est les memes infos? si oui, tu dois avoir un model? (ie, un pauvre bean)
Marsh Posté le 16-11-2004 à 23:49:21
euh
Code :
|
spadur hein
Marsh Posté le 16-11-2004 à 23:55:11
oui mai sy'a plein de trucs associés que je maitrise pas....ca a des avantages de faire des beans, or je maitrise pas lesquels...pis c pas forcément le sujet... ...si j'avais un modèle je ferais des vues dessus, et j'aurai pas de soucis...mais je peux pas faire de modèle...
en gros pour etre clair :
g des arbitres, des joueurs, des entraineurs...avec un surtype personne qui encapsule nom,prenom (c tout ce qu'il y a de commun)...
au max, y'a 4 attributs : nom, prenom, licence, poste...ca vaudrait le coup de faire un modèle pour ca ?
Marsh Posté le 17-11-2004 à 00:18:07
ben tu l'as ton modele: tes objets Arbitre, Joueur etc...
et ce sont probablement des beans ou qqch de proche, que tu n'utilises les bidules que seul nraynaud se risque a utiliser, c'est autre chose...
ce que je voulais te dire c'est que tu pourrais utiliser ceux-ci dans tes events pour recuperer les valeurs modifiées
Marsh Posté le 17-11-2004 à 00:20:18
tu veux dire passer carrément l'objet Arbitre par ex au listener ? le pb c que le listener marche avec des actionPerformed, dont la signature ne prend que des events...comment refiler l'objet au modèle ? la source de l'event c un jButton, pas l'objet...
Marsh Posté le 17-11-2004 à 00:20:24
Jubi > c'est obligatoire de faire un modèle pour ça, parce que sinon, c'est pelle à clou. Et Puis ça t'apprendra à utiliser PropertyChangeSupport et à faire des modèles petits.
Marsh Posté le 17-11-2004 à 00:22:54
PropertyChangeMachin, faudra que j'y jette un oeil un jour, mais ça m'avait fait peur à l'epoque: c'est completement pas typé si je ne m'abuse? genre tu passe un nom arbitraire de propriétés, sous forme d'une String
Marsh Posté le 17-11-2004 à 01:03:06
oulà ...
caramba, malgré mes précautions, il est venu ...
bon, j'explique proprement le truc, sinon on s'en sortira pas :
J'ai une belle BDD Objet qui stocke tt un bouzin.
J'ai une fenetre de ma GUI qui sert à gérer les personnes :
Elle contient un champs non, prénom, et une combobox (qui permet de choisir le soustype) et un tableau (qui liste le soustype sélectionné, ou tt les personnes selon le choix
selon le choix dans la combobox, des champs optionnels apparaissent.
Cette GUI sert à plusieurs choses :
à coté de ca je v avoir une fenetre recherche, qui utilise les meme champs, pour rechercher...et donc le même tableau...y'a plein de taches qui seront similaires (à tel point que je me demande encore si ca vaut le coup de séparer la recherche...)...
pour l'instant ca marche au poil, c juste que à part le tableModel que g fait propre à coté, tt est dans ma classe GUI, ce que je trouve un poil sale...(ca me fait tjs soucis ca d'avoir 30.000 listenenrs dans la classe, mais j'y coupe jamais parce que je sais pas comment router les événèements ET le contexte au listenenr...
en gros, je fous tout en inner, parcce que comme ca pour récupérer la valeur des champs, ben c facile, je suis dans la classe...alors que si je sors le listener, je peux récupérer que la source de l'event, donc g rien à foutre...
ma question c y'a-t-il un moyen propre ?
ton truc j'ai regardé g pas compris à quoi ca sert...en gros on le fout en membre de la classe qui gère le modèle, et après ?
sachant que g une contrainte : la base acceptera peut etre pas de sérialiser mes classes si ce truc est dedans...(c tatillon les bases objets, c surtout bordélique)
Marsh Posté le 19-11-2004 à 19:51:07
the real moins moins a écrit : PropertyChangeMachin, faudra que j'y jette un oeil un jour, mais ça m'avait fait peur à l'epoque: c'est completement pas typé si je ne m'abuse? genre tu passe un nom arbitraire de propriétés, sous forme d'une String |
c'est le standard javabeans.
edit : et oui, c'est pas typé.
un exemple :
Code :
|
Marsh Posté le 19-11-2004 à 20:03:01
j'ai regardé mais pas vraiment compris comment on s'en servait...
le petit détail de mon truc, c que la plupart des réactions de mon interface sont en réalité des modif de la vue, le modèle change peut, et c bien géré...
mais je voudrais sortir de ma GUI les listeners, tout en gardant une possibilité de mettre à jour tt ce qu'elle contient avec ces listeners...sans les mettre en public, ca va de soi
j'avais pensé à un truc lourdingue, mais qui marcherait
c mettre tt les composant dans une collection quelconque, et passer l'array en paramètre à la construction du listener...
Marsh Posté le 19-11-2004 à 20:05:45
tu nous montre ça pendant que j'afute mes clous ?
Marsh Posté le 19-11-2004 à 20:11:55
je l'ai pas implémenté, j'y ai juste réfléchi
je v poster un screen ce sera plus simple
Code :
|
Marsh Posté le 19-11-2004 à 20:48:58
Jubi > je pense qu'il faut tronçonner.
Tu fais une classe qui représente la liste.
Concernant tes boutons, regarde la classe Action, elle correspond à ton besoin.
Pour la comboBox, le switch-case c'est pelle à clous, c'est aux objets qui sont dedans d'avoir un comportement, et c'est la modification du modèle qui doit modifier la vue, pas le contrôleur. On modifie pas la vue soi-même. Et il est hors de question que le comportement du truc dépende de l'ordre d'une liste qui a été instanciée potentiellement à 30km.
Marsh Posté le 19-11-2004 à 20:59:25
là g une contrainte : la BDD derrière...
en gros ca marche comme ca POET (enfin Versant FastObjects) :
Pour toute action sur la base, faut etre dans une transaction...bon ok.donc si par ex tu fait un select all arbitre (c pas la syntaxe mais bon), ca va te cracher une classe qui est un genre de collection (BagOfObject, c du ODMG)...tout va bien...mais qd tu fermes la transaction, Poet vire les références aux objets : en gros tu peux trimbaler le pointer, mais tt action sur ton objet plante...si tu veux réagir dessus, il faut redemander une transaction, et ensuite les réveiller avec une commande spéciale.
Petit pb : le fait d'etre dans une transaction fait ramer la GUI, or, je suis obligé d'etre dans une transaction pour récupérer, c mort...
Workaround : je récupère ma liste d'objet, et de suite, je me crée un tableau de String...l'intéret de cette technique c que ca crée des String (sic), et donc ca me vire les pointeurs moisis....
donc ensuite dans ma GUI je bosse avec que des string...et dès qu'un utilisateur veut faire un truc...je récupère les string qui correspondent aux identifiants, je récupère tt les objets dans une transaction, je fais les OP, et je referme la transaction...
c lourdingue, mais c une contrainte que j'ai que je peux pas contourner...c pas vraiment optimisé pour faire une GUI dynamique sur les objets...parce que pour des raisons liés à une base, Poet désactive les pointeurs pour etre sur que tu n'aie pas un objet "périmé"...
donc vu que ce sont des String, ben je peux rien faire...
Sinon pour les 2 listes (les postes et les types de personnes), ce sont des constantes final...donc l'ordre changera pas...
Les actions je connais...mais g tjs le meme pb : en ultra résumé : comment mettre à jour des composants de la GUI hors de la GUI ? les textField et tout ca, y ont pas de modèle que je puisse taper de dehors ?
Marsh Posté le 19-11-2004 à 21:10:39
tu as plusieurs solutions, la première, c'est de faire des snapshots de tes données active. Une autre, c'est de faire des "transactoins longues", qui consiste à garder les transactions dans la gui (à coups de "select for update" ).
Les logiciels classiques font simplement un snapshot (surtout en client/serveur). En gros, au lieu de travailler sur le domaine, tu travailles sur un proxy/cache de l'objet. et tu devra faire explicitement l'update en fin d'édition.
Marsh Posté le 19-11-2004 à 21:14:42
jubi > de toutes façons, dans une certaine mesure, tu peux taper une sousclasse de DefaultDocument de dehors.
Sinon, toujours pareil, pour dialoguer entre 2 taches, c'est file de messages ou locking de l'objet.
Marsh Posté le 19-11-2004 à 22:23:12
--> si je garde les transactions dans la GUI, elle freeze (g testé)
--> les snapshot, ca implique de garder une copie de l'objet, c bien ca ? Je fais comment pour faire ca ? je me fous clonable sur mes modèles ?
sinon je comprends pas ce que tu veux que je fasse...
Marsh Posté le 20-11-2004 à 11:56:47
jubi > tu fais 2 classes par entité, une classe qui ne fait que stocker les valeurs et que tu fileras à la base objet pour qu'elle joue. Une vraie classe qui représente l'entité, avec un comportement etc. qui sera réellement utilisée. Cette deuxième classe aura des points dans ses méthodes où elle sauvera son état dans la classe de sauvegarde correspondante.
Bref, tu fais un conteneur d'EJB maison et tu comprends pourquoi les BDD objet sont un échec, ça ne t'apporte rien de plus qu'une BDD relationelle dans ton dev.
Marsh Posté le 20-11-2004 à 14:36:18
donc si j'ai suivi, qd je récupère l'objet, je choppse tt ses valeurs, et j'instancie un nouveau truc avec...c ca ?
l'idée à l'air bien, mais g très peur que ma prof trouve ca nul, pour la raison suivante : l'(intéret du méchanisme de Poet, c que tu récupères les objets pour bosser cash dessus...dans le fond, ca revient à les dupliquer...
donc si g tjs bien compris, sans passer par un modèle, j'ai aucun moyen de faire ce que je veux...à savoir modifier une GUI hors de la GUI...
Marsh Posté le 20-11-2004 à 14:46:01
Jubijub a écrit : |
bah oui, mais si il se dit que les bases de données Objet sont un échec complet, il y a une raison, tout le monde aimerait que ça fonctionne. Donc soit tu fais ton truc (qui rame donc) dans la transaction, comme ta prof le voudrait, soit tu copies tes données (ce que tu fais actuellement, mais comme un porc) mais dans tous les cas, ben c'est pas de ta faute, tu es avec du matos vicié, il faut gérer la crise. Il est courant de copier ses données dans le tiers de présentation, ça se fait en web, ça se fait en client-serveur.
L'avantage de copier, c'est que tu peux virer la BDD Objet qui est derrière et changer le backend de persistance, par contre, gérer les transactions à la main, c'est la galère (et je te déconseille de t'y lancer, c'est complexe et si tu les veux, bah tu fais comme la prof te dit, avec un truc qui rame). Mais tu retrouves le même problème en web, tu peux te faire piquer le dernier article du stock pendant que tu fais ton paiement en ligne.
Marsh Posté le 20-11-2004 à 15:17:50
En fait ma prof fait aussi partie du centre de recherche (comme tt l'équipe de mon DESS en fait), et à ce titre elle a déployé POET C++ chez FT...et visiblement ils en étaient super content...donc l'argument : mais c nul madame passera difficilement... ...c vrai que dans l'idée c bien, parce que tu choppes l'objet et ses méthodes...et qu'en relationnel t forcé de reprendre les données que tu sors pour réinstancier le truc...mais c vrai aussi que c trop contraignant à utiliser
c un dilème que tu me poses là...d'un autre coté g pas forcément le temps de me rechanger tt l'appli (et mon binome va hurler ) ...d'un autre je sais que c sale...et lent ...d'un autre coté je saurais meme pas quelle règles appliquer pour resynchroniser les infos (par ex tu choppes un objet, tu change le nom de paul vers jacques, et tu resynchronises, et là pan, un autre avait eu l'idée de changer de paul vers pierre...qui a raison ? vu que l'objet est dans la base, je peux pas gérer le lock moi même
Marsh Posté le 20-11-2004 à 15:27:38
Jubijub a écrit : je saurais meme pas quelle règles appliquer pour resynchroniser les infos (par ex tu choppes un objet, tu change le nom de paul vers jacques, et tu resynchronises, et là pan, un autre avait eu l'idée de changer de paul vers pierre...qui a raison ? vu que l'objet est dans la base, je peux pas gérer le lock moi même |
tu est en concurrence en plus ?
La règle est la même qu'en EJB, tu es exactement dans le besoin de ce truc.
mais si vraiment la prof est à fond dedans, alors fait des transactions longues, en utilisant des "select for update", c'est le truc "pur" (et accessoirement le plus facile à faire).
Marsh Posté le 16-11-2004 à 20:02:13
re salut deux msg en deux min c bcp mais :
je voudrais savoir comment faire pour q'une JTextArea soit accessible pas n'importe qu'elle classe ?
pour plus de precision:
g un programme qui fait pour l'instant 4 ou 5 classe c peut mais bon....
et dans le programme pricipale ou dans la classe principale g declaré un Jtextarea qui devrai me servir comme indicateur de progression et d'action en cour mais je sais pas comment faire pour qu'il soit accessible par tt les classe surtout que je peut pas utiliser l'heritage,ni les implementation . faut il que je fasse un nouveau package ? declare une fonction d'alteration mais le probleme reste le meme)