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 :

Probleme affichage jtable


Sujet :

Composants Java

  1. #1
    Membre averti
    Profil pro
    Étudiant
    Inscrit en
    Mai 2007
    Messages
    36
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2007
    Messages : 36
    Par défaut Probleme affichage jtable
    bonjour à tous, voila j'ai un petit probleme. j'initialise ma jTable à partir de resultats de requetes sql (données, nom de colonne et nombre de colonnes), l'utilisateur a le choix de ses prorpres colonnes via un popup, seulement quand je valide mon popup je n'arrive pas a recharger ma jTable.

    Comment faire? Serait il possible que l'évennement de mon popup puisse demander à ma jTable de se recharger?

    J'ai essaye quelques petites choses mais sans succès. Merci d'avance.

  2. #2
    Membre averti
    Profil pro
    Étudiant
    Inscrit en
    Mai 2007
    Messages
    36
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2007
    Messages : 36
    Par défaut
    Personne ne peut m'aider?

  3. #3
    Membre chevronné Avatar de bassim
    Homme Profil pro
    Ingénieur Réseaux
    Inscrit en
    Février 2005
    Messages
    666
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur Réseaux
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2005
    Messages : 666
    Par défaut
    essaye
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    taTable.getModel().fireTableStructureChanged()

  4. #4
    Membre averti
    Profil pro
    Étudiant
    Inscrit en
    Mai 2007
    Messages
    36
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2007
    Messages : 36
    Par défaut
    ça ne marche pas il me sort que fireTableStructureChanged() est indefinie pour le model ce qui doit etre normal vu que je n'ai pas de modele. Je suis dans la galere grave là je n'arrive pas a faire fonctionner la moindre solution.

  5. #5
    Membre averti
    Profil pro
    Étudiant
    Inscrit en
    Mai 2007
    Messages
    36
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2007
    Messages : 36
    Par défaut
    Merci d'avance à ceux qui sauront me dire quoi faire.

    Voici mon tableau
    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
     
    import java.awt.GraphicsEnvironment;
    import java.awt.Rectangle;
    import java.awt.event.MouseEvent;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    import javax.swing.JMenuItem;
    import javax.swing.JOptionPane;
    import javax.swing.JPanel;
    import javax.swing.JPopupMenu;
    import javax.swing.JScrollPane;
    import javax.swing.JTable;
     
    public class tableauclt extends JPanel
    {
    	private JScrollPane jScrollPane = null;
    	public JTable jTtableauclient = null;
    	public JPopupMenu popup;
    	public JMenuItem menuItem;
    	public tableauclt()
    	{
    		super();
    		initialize();
    	}
    	private void initialize() {
            this.setLayout(null);
            GraphicsEnvironment graphicsEnvironment = GraphicsEnvironment.getLocalGraphicsEnvironment();
    		Rectangle bounds = graphicsEnvironment .getMaximumWindowBounds();
    		this.setBounds(bounds);
            this.add(getJScrollPane(), null);
            this.setVisible(true);
    	}	
    	private JScrollPane getJScrollPane() {
    		if (jScrollPane == null) {
    			jScrollPane = new JScrollPane();
    			jScrollPane.setBounds(new Rectangle(0, 18, 1023, 720));
    			jScrollPane.setViewportView(getJTtableauclient());
    		}
    		return jScrollPane;
    	}
    	public JTable getJTtableauclient() {
    		if (jTtableauclient == null) {	
     
    ......code SQL....
     
     
    				      	jTtableauclient = new JTable(data,columnNames);				      	
    						jTtableauclient.setAutoCreateRowSorter(true);
    						jTtableauclient.setColumnSelectionAllowed(true);
    						jTtableauclient.setVisible(true);						
    						jTtableauclient.addMouseListener(new java.awt.event.MouseAdapter() {
    							public void mouseClicked(java.awt.event.MouseEvent e) {
    								if (e.getButton()== MouseEvent.BUTTON3) {
    									JPopupMenu contextMenu = new JPopupMenu() ;
    									JMenuItem choixcol = new JMenuItem("Choix des colonnes");	
    									contextMenu.add(choixcol) ;
    									JMenuItem autrechoix = new JMenuItem("autre");						
    									contextMenu.add(autrechoix) ;
    									contextMenu.setLocation(e.getXOnScreen(), e.getYOnScreen());
    								    contextMenu.setEnabled(true);
    									contextMenu.setVisible(true);
    									choixcol.addActionListener(new java.awt.event.ActionListener() {
    										public void actionPerformed(java.awt.event.ActionEvent e) {
    											modiftablclt md = new modiftablclt();
    											md.getJFchangercolonne();
    										}
    									});								
    								}	
    							}
    						});	
    				    }
    				    catch (ClassNotFoundException ex)
    				    {
    				      JOptionPane.showMessageDialog(null,
    				             "Classe introuvable " + ex.getMessage ());
    				    }
    				    catch (SQLException ex)
    				    {
    				      JOptionPane.showMessageDialog(null,
    				             "Erreur JDBC : " + ex.getMessage ());
    				    }
    				    finally
    				    {
    				      try
    				      {
    				        if (resultat != null)
    				          resultat.close();
    				        if (instruction != null)
    				          instruction.close();
    				        if (connexion != null)
    				          connexion.close();
    				      }
    				      catch (SQLException ex)
    				      {
    				        ex.printStackTrace ();
    				      }
    				    }			
    		}
    		return jTtableauclient;
    	}
     
    }
    Et voici mon popup

    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
    280
     
    import java.awt.Rectangle;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    import javax.swing.JButton;
    import javax.swing.JCheckBox;
    import javax.swing.JFrame;
    import javax.swing.JOptionPane;
    import javax.swing.JPanel;
     
    public class modiftablclt {
    	private JFrame jFchangercolonne = null;  //  @jve:decl-index=0:visual-constraint="281,117"
    	private JPanel jContentPane = null;
    	private JCheckBox jCBcodeclt = null;
    	private JCheckBox jCBadresse = null;
    	private JCheckBox jCBraisonsoc = null;
    	private JCheckBox jCBadresse2 = null;
    	private JCheckBox jCBville2 = null;
    	private JCheckBox jCBcodepost2 = null;
    	private JCheckBox jCBnumtel = null;
    	private JCheckBox jCBfax = null;
    	private JCheckBox jCBsiteweb = null;
    	private JCheckBox jCBtvaintracom = null;
    	private JCheckBox jCBnumport2 = null;
    	private JCheckBox jCBemail = null;
    	private JCheckBox jCBnumtel2 = null;
    	private JCheckBox jCBville = null;
    	private JCheckBox jCBcodepost = null;
    	private JCheckBox jCBnumport = null;
    	private JCheckBox jCBremisecou = null;
    	private JCheckBox jCBnumcpttva = null;
    	private JCheckBox jCBfax2 = null;
    	private JButton jBvaliderchoicol = null;
    	private JCheckBox jCBinfoclt = null;
    	private JCheckBox jCBcodefamclt = null;
    	public JFrame getJFchangercolonne() {
    		if (jFchangercolonne == null) {
    			jFchangercolonne = new JFrame();
    			jFchangercolonne.setTitle("Choix des colonnes du tableau de clients");
    			jFchangercolonne.setBounds(new Rectangle(200, 100, 362, 273));
    			jFchangercolonne.setContentPane(getJContentPane());
    			jFchangercolonne.setVisible(true);
    		}
    		return jFchangercolonne;
    	}
    	private JPanel getJContentPane() {
    		if (jContentPane == null) {
    			jContentPane = new JPanel();
    			jContentPane.setLayout(null);
    			jContentPane.add(getJCBcodeclt(), null);
    			jContentPane.add(getJCBadresse(), null);
    			jContentPane.add(getJCBraisonsoc(), null);
    			jContentPane.add(getJCBadresse2(), null);
    			jContentPane.add(getJCBville2(), null);
    			jContentPane.add(getJCBcodepost2(), null);
    			jContentPane.add(getJCBnumtel(), null);
    			jContentPane.add(getJCBfax(), null);
    			jContentPane.add(getJCBsiteweb(), null);
    			jContentPane.add(getJCBtvaintracom(), null);
    			jContentPane.add(getJCBnumport2(), null);
    			jContentPane.add(getJCBemail(), null);
    			jContentPane.add(getJCBnumtel2(), null);
    			jContentPane.add(getJCBville(), null);
    			jContentPane.add(getJCBcodepost(), null);
    			jContentPane.add(getJCBnumport(), null);
    			jContentPane.add(getJCBremisecou(), null);
    			jContentPane.add(getJCBnumcpttva(), null);
    			jContentPane.add(getJCBfax2(), null);
    			jContentPane.add(getJBvaliderchoicol(), null);
    			jContentPane.add(getJCBinfoclt(), null);
    			jContentPane.add(getJCBcodefamclt(), null);
    		}
    		return jContentPane;
    	}
    	private JCheckBox getJCBcodeclt() {
    		if (jCBcodeclt == null) {
    			jCBcodeclt = new JCheckBox();
    			jCBcodeclt.setBounds(new Rectangle(2, 1, 148, 21));
    			jCBcodeclt.setSelected(false);
    			jCBcodeclt.setText("Code client");
    		}
    		return jCBcodeclt;
    	}
    	private JCheckBox getJCBadresse() {
    		if (jCBadresse == null) {
    			jCBadresse = new JCheckBox();
    			jCBadresse.setBounds(new Rectangle(2, 45, 125, 21));
    			jCBadresse.setSelected(false);
    			jCBadresse.setText("Adresse");
    		}
    		return jCBadresse;
    	}
    	private JCheckBox getJCBraisonsoc() {
    		if (jCBraisonsoc == null) {
    			jCBraisonsoc = new JCheckBox();
    			jCBraisonsoc.setBounds(new Rectangle(2, 23, 125, 21));
    			jCBraisonsoc.setSelected(false);
    			jCBraisonsoc.setText("Raison sociale");
    		}
    		return jCBraisonsoc;
    	}
    	private JCheckBox getJCBadresse2() {
    		if (jCBadresse2 == null) {
    			jCBadresse2 = new JCheckBox();
    			jCBadresse2.setBounds(new Rectangle(2, 111, 125, 21));
    			jCBadresse2.setSelected(false);
    			jCBadresse2.setText("Adresse 2");
    		}
    		return jCBadresse2;
    	}
    	private JCheckBox getJCBville2() {
    		if (jCBville2 == null) {
    			jCBville2 = new JCheckBox();
    			jCBville2.setBounds(new Rectangle(2, 155, 125, 21));
    			jCBville2.setSelected(false);
    			jCBville2.setText("Ville 2");
    		}
    		return jCBville2;
    	}
    	private JCheckBox getJCBcodepost2() {
    		if (jCBcodepost2 == null) {
    			jCBcodepost2 = new JCheckBox();
    			jCBcodepost2.setBounds(new Rectangle(2, 133, 125, 21));
    			jCBcodepost2.setSelected(false);
    			jCBcodepost2.setText("Code postal 2");
    		}
    		return jCBcodepost2;
    	}
    	private JCheckBox getJCBnumtel() {
    		if (jCBnumtel == null) {
    			jCBnumtel = new JCheckBox();
    			jCBnumtel.setBounds(new Rectangle(2, 177, 169, 21));
    			jCBnumtel.setSelected(false);
    			jCBnumtel.setText("Numero de téléphone");
    		}
    		return jCBnumtel;
    	}
    	private JCheckBox getJCBfax() {
    		if (jCBfax == null) {
    			jCBfax = new JCheckBox();
    			jCBfax.setBounds(new Rectangle(169, 45, 199, 21));
    			jCBfax.setSelected(false);
    			jCBfax.setText("Fax");
    		}
    		return jCBfax;
    	}
    	private JCheckBox getJCBsiteweb() {
    		if (jCBsiteweb == null) {
    			jCBsiteweb = new JCheckBox();
    			jCBsiteweb.setBounds(new Rectangle(169, 111, 200, 21));
    			jCBsiteweb.setSelected(false);
    			jCBsiteweb.setText("Site web");
    		}
    		return jCBsiteweb;
    	}
    	private JCheckBox getJCBtvaintracom() {
    		if (jCBtvaintracom == null) {
    			jCBtvaintracom = new JCheckBox();
    			jCBtvaintracom.setBounds(new Rectangle(169, 155, 193, 21));
    			jCBtvaintracom.setSelected(false);
    			jCBtvaintracom.setText("N° TVA intracommunautaire");
    		}
    		return jCBtvaintracom;
    	}
    	private JCheckBox getJCBnumport2() {
    		if (jCBnumport2 == null) {
    			jCBnumport2 = new JCheckBox();
    			jCBnumport2.setBounds(new Rectangle(169, 23, 200, 21));
    			jCBnumport2.setSelected(false);
    			jCBnumport2.setText("Numéro de portable 2");
    		}
    		return jCBnumport2;
    	}
    	private JCheckBox getJCBemail() {
    		if (jCBemail == null) {
    			jCBemail = new JCheckBox();
    			jCBemail.setBounds(new Rectangle(169, 89, 200, 21));
    			jCBemail.setSelected(false);
    			jCBemail.setText("E-mail");
    		}
    		return jCBemail;
    	}
    	private JCheckBox getJCBnumtel2() {
    		if (jCBnumtel2 == null) {
    			jCBnumtel2 = new JCheckBox();
    			jCBnumtel2.setBounds(new Rectangle(169, 1, 169, 21));
    			jCBnumtel2.setSelected(false);
    			jCBnumtel2.setText("Numéro de téléphone 2");
    		}
    		return jCBnumtel2;
    	}
    	private JCheckBox getJCBville() {
    		if (jCBville == null) {
    			jCBville = new JCheckBox();
    			jCBville.setBounds(new Rectangle(2, 89, 125, 21));
    			jCBville.setSelected(false);
    			jCBville.setText("Ville");
    		}
    		return jCBville;
    	}
    	private JCheckBox getJCBcodepost() {
    		if (jCBcodepost == null) {
    			jCBcodepost = new JCheckBox();
    			jCBcodepost.setBounds(new Rectangle(2, 67, 125, 21));
    			jCBcodepost.setSelected(false);
    			jCBcodepost.setText("Code postal");
    		}
    		return jCBcodepost;
    	}
    	private JCheckBox getJCBnumport() {
    		if (jCBnumport == null) {
    			jCBnumport = new JCheckBox();
    			jCBnumport.setBounds(new Rectangle(2, 199, 149, 21));
    			jCBnumport.setSelected(false);
    			jCBnumport.setText("Numéro de portable");
    		}
    		return jCBnumport;
    	}
    	private JCheckBox getJCBremisecou() {
    		if (jCBremisecou == null) {
    			jCBremisecou = new JCheckBox();
    			jCBremisecou.setBounds(new Rectangle(169, 177, 200, 21));
    			jCBremisecou.setSelected(false);
    			jCBremisecou.setText("Remise courante");
    		}
    		return jCBremisecou;
    	}
    	private JCheckBox getJCBnumcpttva() {
    		if (jCBnumcpttva == null) {
    			jCBnumcpttva = new JCheckBox();
    			jCBnumcpttva.setBounds(new Rectangle(169, 133, 178, 21));
    			jCBnumcpttva.setSelected(false);
    			jCBnumcpttva.setText("Numéro compte TVA");
    		}
    		return jCBnumcpttva;
    	}
    	private JCheckBox getJCBfax2() {
    		if (jCBfax2 == null) {
    			jCBfax2 = new JCheckBox();
    			jCBfax2.setBounds(new Rectangle(169, 67, 200, 21));
    			jCBfax2.setSelected(false);
    			jCBfax2.setText("Fax 2");
    		}
    		return jCBfax2;
    	}
    	private JButton getJBvaliderchoicol() {
    		if (jBvaliderchoicol == null) {
    			jBvaliderchoicol = new JButton();
    			jBvaliderchoicol.setBounds(new Rectangle(6, 221, 60, 21));
    			jBvaliderchoicol.setText("Ok");
    			jBvaliderchoicol.addActionListener(new java.awt.event.ActionListener() {   
    				public void actionPerformed(java.awt.event.ActionEvent e) { 
    					jFchangercolonne.setVisible(false);
     
    ..... SQL....
     
    			});
    		}
    		return jBvaliderchoicol;
    	}
    	private JCheckBox getJCBinfoclt() {
    		if (jCBinfoclt == null) {
    			jCBinfoclt = new JCheckBox();
    			jCBinfoclt.setBounds(new Rectangle(169, 199, 166, 21));
    			jCBinfoclt.setText("Info client");
    		}
    		return jCBinfoclt;
    	}
    	private JCheckBox getJCBcodefamclt() {
    		if (jCBcodefamclt == null) {
    			jCBcodefamclt = new JCheckBox();
    			jCBcodefamclt.setBounds(new Rectangle(169, 221, 166, 21));
    			jCBcodefamclt.setText("Code famille");
    		}
    		return jCBcodefamclt;
    	}
    }

  6. #6
    Membre chevronné Avatar de bassim
    Homme Profil pro
    Ingénieur Réseaux
    Inscrit en
    Février 2005
    Messages
    666
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur Réseaux
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2005
    Messages : 666
    Par défaut
    attends tu crée une JTable en initialisant directement les données et les colonnes alors que tu charges ces meme données d'une BDD , et c'est là qu'il faut justement utiliser un modele de tableau par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    public class Modele extends AbstractTableModel {
    ....
    }
    et puis tu fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Modele tonModele = new Modele(parametres eventuels);
    tonTableau.setModel(tonModele);
    et chaque que la structure générale de la table change ,tu fais le code que je t'ai posté au dessus.

  7. #7
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 95
    Par défaut
    Merci d'avoir repondu, en gros il faut que je mette le code de mon tableau dans celui de mon model. Je vais tester ça dès que je peux merci de ta reponse.

  8. #8
    Membre averti
    Profil pro
    Étudiant
    Inscrit en
    Mai 2007
    Messages
    36
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2007
    Messages : 36
    Par défaut
    Ma table ne veut toujours pas se rafraichir je ne comprend pas pourquoi, dites moi si je suis à coté de la plaque

    table et modele:

    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
     
     
    import java.awt.GraphicsEnvironment;
    import java.awt.Rectangle;
    import java.awt.event.MouseEvent;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
     
    import javax.swing.JMenuItem;
    import javax.swing.JOptionPane;
    import javax.swing.JPanel;
    import javax.swing.JPopupMenu;
    import javax.swing.JScrollPane;
    import javax.swing.JTable;
    import javax.swing.table.AbstractTableModel;
     
    /** 
     * TableDemo is just like SimpleTableDemo, except that it
     * uses a custom TableModel.
     */
    public class modeletableclt	 extends JPanel {
        private boolean DEBUG = false;
        private JScrollPane jScrollPane = null;
    	public JTable jTtableauclient = null;
    	public JPopupMenu popup;
    	public JMenuItem menuItem;
    	Connection connexion = null,connexiongescom = null;				
    	Statement  instruction  = null,instructiongescom  = null;
    	ResultSet  resultat = null,resultatgescom = null;				
    	Integer nbrechamp=1,index=0,nbreenreg=0,index2=0,index3=0;
    	String[] columnNames;							
    	Object[][] data;
     
        public modeletableclt()
    	{
    		super();
    		initialize();
    	}
    	private void initialize() {
            this.setLayout(null);
            GraphicsEnvironment graphicsEnvironment = GraphicsEnvironment.getLocalGraphicsEnvironment();
    		Rectangle bounds = graphicsEnvironment .getMaximumWindowBounds();
    		this.setBounds(bounds);
            this.add(getJScrollPane(), null);
            this.setVisible(true);
    	}
     
    	private JScrollPane getJScrollPane() {
    		if (jScrollPane == null) {
    			jScrollPane = new JScrollPane();
    			jScrollPane.setBounds(new Rectangle(0, 18, 1023, 720));
    			jScrollPane.setViewportView(getJTtableauclient());
    		}
    		return jScrollPane;
    	}
     
    	public JTable getJTtableauclient() {
    		if (jTtableauclient == null) {
     
    ....SQL... // initialisation colonnes et données
     
    		      	jTtableauclient = new JTable();	
    		      	MyTableModel mod =new MyTableModel();
    		      	mod.fireTableDataChanged();
    		      	jTtableauclient.setModel(mod);
    		      	jTtableauclient.setAutoCreateRowSorter(true);
    				jTtableauclient.setColumnSelectionAllowed(true);
    				jTtableauclient.setVisible(true);						
    				jTtableauclient.addMouseListener(new java.awt.event.MouseAdapter() {
    					public void mouseClicked(java.awt.event.MouseEvent e) {
    						if (e.getButton()== MouseEvent.BUTTON3) {
    							JPopupMenu contextMenu = new JPopupMenu() ;
    							JMenuItem choixcol = new JMenuItem("Choix des colonnes");	
    							contextMenu.add(choixcol) ;
    							JMenuItem autrechoix = new JMenuItem("autre");						
    							contextMenu.add(autrechoix) ;
    							contextMenu.setLocation(e.getXOnScreen(), e.getYOnScreen());
    						    contextMenu.setEnabled(true);
    							contextMenu.setVisible(true);
    							choixcol.addActionListener(new java.awt.event.ActionListener() {
    								public void actionPerformed(java.awt.event.ActionEvent e) {
    									modiftablclt md = new modiftablclt();
    									md.getJFchangercolonne();
    								}
    							});								
    						}	
    					}
    				});	
    		    }
    		    catch (ClassNotFoundException ex)
    		    {
    		      JOptionPane.showMessageDialog(null,"Classe introuvable " + ex.getMessage ());
    		    }
    		    catch (SQLException ex)
    		    {
    		      JOptionPane.showMessageDialog(null,"Erreur JDBC : " + ex.getMessage ());
    		    }
    		    finally
    		    {
    		      try
    		      {
    		        if (resultat != null)
    		          resultat.close();
    		        if (instruction != null)
    		          instruction.close();
    		        if (connexion != null)
    		          connexion.close();
    		      }
    		      catch (SQLException ex)
    		      {
    		        ex.printStackTrace ();
    		      }
    		    }	
     
     
    		}
    		return jTtableauclient;
    	}
     
    	class MyTableModel extends AbstractTableModel {
     
            public int getColumnCount() {
                return columnNames.length;
            }
     
            public int getRowCount() {
                return data.length;
            }
     
            public String getColumnName(int col) {
                return columnNames[col];
     
            }
     
            public Object getValueAt(int row, int col) {
                return data[row][col];
            }
     
     
        }
    }
    Merci d'avance.

  9. #9
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 95
    Par défaut
    Svp aidez moi

  10. #10
    Membre chevronné Avatar de bassim
    Homme Profil pro
    Ingénieur Réseaux
    Inscrit en
    Février 2005
    Messages
    666
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur Réseaux
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2005
    Messages : 666
    Par défaut
    si tu utilises un modele , les données doivent etre dans le modele c lui qui les gère donc :
    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
    25
    26
    27
    28
    class MyTableModel extends AbstractTableModel {
     
            String[] columnNames;							
    	Object[][] data;
            //Constructeur
            public MyTableModel() {
     
             data = // ici tu ramenes les données depuis la base de données
            }
            public int getColumnCount() {
                return columnNames.length;
            }
     
            public int getRowCount() {
                return data.length;
            }
     
            public String getColumnName(int col) {
                return columnNames[col];
     
            }
     
            public Object getValueAt(int row, int col) {
                return data[row][col];
            }
     
     
        }

  11. #11
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 95
    Par défaut
    Ok j'avais déjà essayé un truc similaire mais il me renvoyait des erreurs sur mon try/catch.

    J'essaye de suite merci de ta reponse.

  12. #12
    Membre chevronné Avatar de bassim
    Homme Profil pro
    Ingénieur Réseaux
    Inscrit en
    Février 2005
    Messages
    666
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur Réseaux
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2005
    Messages : 666
    Par défaut
    Serait il possible que l'évennement de mon popup puisse demander à ma jTable de se recharger?
    oui , dans l'évenement tu dois mettre à jour le modele directement en changeant les noms de colonnes et le nombre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    public void updateModele() {
     
              columnNames = // nouvelles colonnes
              ...
              fireTableStructureChanged();
    }

  13. #13
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 95
    Par défaut
    Voila maintenant ça me donne ceci, dis moi si je me trompe :


    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
     
    import java.awt.GraphicsEnvironment;
    import java.awt.Rectangle;
    import java.awt.event.MouseEvent;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    import javax.swing.JButton;
    import javax.swing.JLabel;
    import javax.swing.JMenuItem;
    import javax.swing.JOptionPane;
    import javax.swing.JPanel;
    import javax.swing.JPopupMenu;
    import javax.swing.JScrollPane;
    import javax.swing.JTable;
    import javax.swing.JTextField;
    import javax.swing.table.AbstractTableModel;
     
     
    public class modeletableclt	 extends JPanel {
     
        private JScrollPane jScrollPane = null;
    	public JTable jTtableauclient = null;
    	public JPopupMenu popup;
    	public JMenuItem menuItem;
    	private JLabel jLabel = null;
    	private JTextField jTFrecherchecode = null;
    	private JTextField jTFnom = null;
    	private JButton jBrechercher = null;
     
     
     
        public modeletableclt()
    	{
    		super();
    		initialize();
    	}
    	private void initialize() {
            jLabel = new JLabel();
            jLabel.setBounds(new Rectangle(3, 0, 75, 16));
            jLabel.setText("Rechercher:");
            this.setLayout(null);
            GraphicsEnvironment graphicsEnvironment = GraphicsEnvironment.getLocalGraphicsEnvironment();
    		Rectangle bounds = graphicsEnvironment .getMaximumWindowBounds();
    		this.setBounds(bounds);
            this.add(getJScrollPane(), null);
            this.setVisible(true);
            this.add(jLabel, null);
            this.add(getJTFrecherchecode(), null);
            this.add(getJTFnom(), null);
            this.add(getJBrechercher(), null);
    	}
     
    	private JScrollPane getJScrollPane() {
    		if (jScrollPane == null) {
    			jScrollPane = new JScrollPane();
    			jScrollPane.setBounds(new Rectangle(0, 18, 1023, 694));
    			jScrollPane.setViewportView(getJTtableauclient());
    		}
    		return jScrollPane;
    	}
     
    	public JTextField getJTFrecherchecode() {
    		if (jTFrecherchecode == null) {
    			jTFrecherchecode = new JTextField();
    			jTFrecherchecode.setBounds(new Rectangle(101, 0, 94, 16));
    			jTFrecherchecode.setText("Code");
    			jTFrecherchecode.setToolTipText("");
    		}
    		return jTFrecherchecode;
    	}
     
    	public JTextField getJTFnom() {
    		if (jTFnom == null) {
    			jTFnom = new JTextField();
    			jTFnom.setBounds(new Rectangle(200, 0, 94, 16));
    			jTFnom.setText("Nom");
    		}
    		return jTFnom;
    	}
     
    	public JButton getJBrechercher() {
    		if (jBrechercher == null) {
    			jBrechercher = new JButton();
    			jBrechercher.setBounds(new Rectangle(297, 0, 53, 16));
    			jBrechercher.setText("Ok");
    		}
    		return jBrechercher;
    	}
     
    	public JTable getJTtableauclient() {
    		if (jTtableauclient == null) {	      
    		      	jTtableauclient = new JTable();
    		      	MyTableModel mod = new MyTableModel();
    		      	mod.fireTableStructureChanged();
    		      	jTtableauclient.setModel(mod);
     
    		      	jTtableauclient.setAutoCreateRowSorter(true);
    				jTtableauclient.setColumnSelectionAllowed(true);
    				jTtableauclient.setVisible(true);						
    				jTtableauclient.addMouseListener(new java.awt.event.MouseAdapter() {
    					public void mouseClicked(java.awt.event.MouseEvent e) {
    						if (e.getButton()== MouseEvent.BUTTON3) {
    							JPopupMenu contextMenu = new JPopupMenu() ;
    							JMenuItem choixcol = new JMenuItem("Choix des colonnes");	
    							contextMenu.add(choixcol) ;
    							JMenuItem autrechoix = new JMenuItem("autre");						
    							contextMenu.add(autrechoix) ;
    							contextMenu.setLocation(e.getXOnScreen(), e.getYOnScreen());
    						    contextMenu.setEnabled(true);
    							contextMenu.setVisible(true);
    							choixcol.addActionListener(new java.awt.event.ActionListener() {
    								public void actionPerformed(java.awt.event.ActionEvent e) {
    									modiftablclt md = new modiftablclt();
    									md.getJFchangercolonne();
    								}
    							});								
    						}	
    					}
    				});	
     
     
    		}
    		return jTtableauclient;
    	}
     
    	class MyTableModel extends AbstractTableModel {
     
    		Connection connexion = null,connexiongescom = null;				
    		Statement  instruction  = null,instructiongescom  = null;
    		ResultSet  resultat = null,resultatgescom = null;				
    		Integer nbrechamp=1,index=0,nbreenreg=0,index2=0,index3=0;
    		String[] columnNames;							
    		Object[][] data;
    	        public MyTableModel() {
    	        	try
    			    {				    
    			      Class.forName ("com.mysql.jdbc.Driver");  // Chargement de la classe du driver JDBC de MySQL	
    			      connexion = DriverManager.getConnection("jdbc:mysql://localhost/bdd_utilisateur");// Ouverture de la connexion avec MySQL sur la base utilisateur
    			      instruction = connexion.createStatement();	      
    			      resultat = instruction.executeQuery("select count(*)FROM param_utilisateur  where affichage='1'");//combien de colonnes à afficher?	
    			      resultat.next();
    			      nbrechamp=resultat.getInt("count(*)");
    			      columnNames = new String[nbrechamp];
     
    			      resultat = instruction.executeQuery("select champ FROM param_utilisateur where affichage ='1'");//selection des champs a afficher			      
     
    			      while(index<nbrechamp){ // initialisation des colonnes
    				    	resultat.next();
    				      	columnNames[index]=resultat.getString("champ");				      	
    				      	index++;
    						}
     
    			      connexiongescom = DriverManager.getConnection("jdbc:mysql://localhost/gescom2");// Ouverture de la connexion avec MySQL sur la base utilisateur
    			      instructiongescom = connexiongescom.createStatement();
    			      resultatgescom = instructiongescom.executeQuery("select count(*)FROM client");// combien d'enregistrement dans la table client?
    			      resultatgescom.next();
    			      nbreenreg=resultatgescom.getInt("count(*)");
     
    			      resultatgescom = instructiongescom.executeQuery("select * FROM client");
     
     
    			      data = new Object[nbreenreg][nbrechamp];
     
    			      while(index2<nbreenreg){ //initialisation des données
    			    	  resultatgescom.next();
    			    	  while(index3<nbrechamp){
    			    		  data[index2][index3]=resultatgescom.getString((index3+1));
    			    		  index3++;			    		  
    			    	  }
    			      index3=0;
    			      index2++;
    			      }			 
    			    }
    	        	catch (ClassNotFoundException ex)
    			    {
    			      JOptionPane.showMessageDialog(null,"Classe introuvable " + ex.getMessage ());
    			    }
    			    catch (SQLException ex)
    			    {
    			      JOptionPane.showMessageDialog(null,"Erreur JDBC : " + ex.getMessage ());
    			    }
    			    finally
    			    {
    			      try
    			      {
    			        if (resultat != null)
    			          resultat.close();
    			        if (instruction != null)
    			          instruction.close();
    			        if (connexion != null)
    			          connexion.close();
    			      }
    			      catch (SQLException ex)
    			      {
    			        ex.printStackTrace ();
    			      }
    			    }	
    	        }
     
            public int getColumnCount() {
                return columnNames.length;
            }
     
            public int getRowCount() {
                return data.length;
            }
     
            public String getColumnName(int col) {
                return columnNames[col];
     
            }
     
            public Object getValueAt(int row, int col) {
                return data[row][col];
            }      
        }
    }
    Pour actualiser les noms des colonnes faut que je rajoute une fonction du type setData à mon model?

  14. #14
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 95
    Par défaut
    oui , dans l'évenement tu dois mettre à jour le modele directement en changeant les noms de colonnes et le nombre :
    les nom de mes colonnes change grace a mon popup, si je te suis il faudrait donc que mon code sql je le mette sur l'evennement du bouton de mon popup en utilisant updateModele()?

  15. #15
    Membre chevronné Avatar de bassim
    Homme Profil pro
    Ingénieur Réseaux
    Inscrit en
    Février 2005
    Messages
    666
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur Réseaux
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2005
    Messages : 666
    Par défaut
    oula , j'ai pas bien compris tes requetes SQL .

    aussi , le code des evenements des menus PopUP est crée à la volée ce qui est difficilement lisible pour les autres (et pour moi aussi) , il vaut mieux séparer tout ça .

    maintenant , si à chaque fois que tu cliques sur un pop up , il doit transmettre les champs à afficher et là tu dois refaire ta requête or ici elle ne s'exécute qu'une seule fois dans le constructeur .

    pour les colonnes à afficher , j'ai jamais essayé ça mais je crois qu'il y a un composant qui implémente cette fonction le JXTable

    les nom de mes colonnes change grace a mon popup, si je te suis il faudrait donc que mon code sql je le mette sur l'evennement du bouton de mon popup en utilisant updateModele()?
    l'evenement ne vas servir qu'à transmettre au modele ce qui a changé .

  16. #16
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 95
    Par défaut
    Bah en fait l'utilisateur peut choisir son nombre de colonne donc j'ai construit une base externe au projet qui concerne les parametres de l'utilisateurs. Comme le nombre de colonne varie il faut aussi que les données affichées varient.

    Mon popup est rempli de checkbox, pour choisir les colones, au clic je passe toutes les checkbox cochées à 1 et au chargement de mon tableau j'affiche toutes les colonnes dont la valeur est a 1.

    Pour afficher les données faut donc que je prenne en compte le nombre de colonne affichées et le nombre d'enregistrements.


    J'ai essaye ton code mais il me sort que la structure est mal positionnée, pourtant il faut bien que je la place dans le code de l'évennement?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    public void actionPerformed(java.awt.event.ActionEvent e) {...}
    Désolé si c'est bordélique mon code je suis en stage et je viens juste de commencer le java et je suis grave dans la galere avec le boss sur le dos.

  17. #17
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 95
    Par défaut
    En fait quand je clic sur le bouton de mon popup la base sur laquelle s'initialise ma table change donc je ne devrais pas avoir besoin de l'updatemodele() non?

    Une fois la base changée si je veux voir les changement je suis obligé de coupé l'appli et de la relancer.

  18. #18
    Membre confirmé
    Inscrit en
    Mai 2007
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 95
    Par défaut
    Il n'y a vraiment personne pour m'aider?

Discussions similaires

  1. probleme affichage avec jtable
    Par lamine1987 dans le forum Composants
    Réponses: 4
    Dernier message: 03/08/2009, 03h26
  2. probleme Affichage JTable
    Par krikri150489 dans le forum Composants
    Réponses: 3
    Dernier message: 03/06/2009, 23h00
  3. Probleme affichage arraylist dans jtable
    Par brew94 dans le forum Collection et Stream
    Réponses: 1
    Dernier message: 19/12/2008, 14h31
  4. Probleme affichage noir quand Build/Compile
    Par balabi dans le forum MFC
    Réponses: 3
    Dernier message: 01/06/2005, 17h12
  5. Probleme affichage dans tableau selon requête
    Par moulette85 dans le forum Langage SQL
    Réponses: 11
    Dernier message: 01/03/2005, 16h44

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