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 :

JTable appliqué plusieurs filtres


Sujet :

Composants Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Janvier 2010
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 21
    Par défaut JTable appliqué plusieurs filtres
    Bonjour à tous,

    Voici mon problème :
    j'aimerai pouvoir affecter plusieurs filtres à ma JTable.
    Ce sont des filtres de recherches. Donc des JTextField, qui actualise la JTable en fonction de ce qu'on tape dedans ( dynamique ) .

    Ce que j'ai fait :
    Pour le moment, j'arrive à avoir un JTextfield pour chaque colonne de ma JTable et la recherche d'un jtextfield ( lui seul uniquement ) marche parfaitement.

    Ou ca coince :
    Lorsque je combine plusieurs filtres en même temps ( donc quand je renseigne par exemple deux jtextfield ) ma deuxieme recherche ne prend pas en compte la première mais ma JTable de base.

    C'est un problème assez récurrent, mais malgré mes recherches je n'ai pas trouvez de solution.
    Merci d'avance pour une quelconque aide.

    Mon code :

    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
    package elements;
     
    import elements.Connexion;
    import elements.Connexion;
     
    import java.sql.SQLException;
    import java.util.logging.Level;
    import java.util.logging.Logger;
    import javax.swing.*;
    import javax.swing.event.*;
    import javax.swing.table.AbstractTableModel;
    import javax.swing.table.TableRowSorter;
     
    import java.awt.*;
    import java.awt.event.ActionEvent;
    import java.awt.event.ActionListener;
    import java.awt.event.MouseAdapter;
    import java.awt.event.MouseEvent;
    import java.awt.event.MouseListener;
    import java.sql.ResultSet;
    import java.sql.ResultSetMetaData;
    import java.util.Vector;
    import javax.swing.table.DefaultTableModel;
     
    public class TableFilterDemo extends JPanel
    {
        private boolean DEBUG = false;
        public JTable table; // JTable de notre JPanel
        public static int i; // sert à associer un JTextField de recherche à sa colonne
        public TableRowSorter<DefaultTableModel> sorter; // sert à la fonction recherche
        public DefaultTableModel model; // le modèle de notre JTable
        public JPanel top; // panel contenant les JTextField de recherche
        Boolean booltop=false; // booléan pour afficher/enlever le panel top
     
        public static int identify;
     
     
     
        public TableFilterDemo(String query) throws ClassNotFoundException, SQLException 
        {
     
            super();
            top=new JPanel(new FlowLayout(FlowLayout.LEFT,15,0));
     
            this.i=i;
            setLayout(new BorderLayout());
     
            Vecteur v=new Vecteur(query);
     
            model = new DefaultTableModel(v.ligne,v.colonne);
     
     
            sorter = new TableRowSorter<DefaultTableModel>(model);
            table = new JTable(model);
            table.setRowSorter(sorter);
            table.setPreferredScrollableViewportSize(new Dimension(500, 70));
            table.setFillsViewportHeight(true);
     
     
            table.setSelectionMode(ListSelectionModel.SINGLE_SELECTION); // mode de séléction : unique
     
     
            // fonction pour afficher/enlever le panel top             
            this.table.getTableHeader().addMouseListener(new MouseAdapter()
            {
                public void mouseReleased(MouseEvent event)
                {
    		if(event.getButton() == event.BUTTON3)
                    {
                        //Si on est dans le tableau
                        if(table.columnAtPoint(new Point(event.getX(), event.getY())) != -1)
                        {
    			if(booltop==true)
                            {
                               top.setVisible(false);
                               booltop=false;
                             }
                             else
                             {
                                top.setVisible(true);
                                booltop=true;
                             }
                        }
    		}
                }
    	});             
            JScrollPane scrollPane = new JScrollPane(table);
     
            add(scrollPane);
     
        }
     
        /** 
         * Update the row filter regular expression from the expression in
         * the text box.
         */
     
        // fonction pour le filtrage
        private void newFilter(int i,JTextField jt) 
        {
            RowFilter<DefaultTableModel, Object> rf = null;
            table.clearSelection();
     
            try 
            {
                rf = RowFilter.regexFilter(jt.getText(), i);
            } 
            catch (java.util.regex.PatternSyntaxException e) 
            {
                return;
            }
            sorter.setRowFilter(rf);
        }
     
     
        // fonction qui créé un JTextField de recherche pour chaque colonne
        public void createTextField()
        {   
     
            for(i=0;i<model.getColumnCount();i++)
            {
                top.add(new JLabel(model.getColumnName(i)+" :"));
                JTextField jt= new JTextField(7);
     
                jt.getDocument().addDocumentListener(
                new documentListener(i,jt));
     
                jt.addMouseListener(new MouseListener(){
     
                    public void mouseClicked(MouseEvent e) 
                    {
                        table.clearSelection();
     
                    }
     
                    public void mousePressed(MouseEvent e) 
                    {
     
                    }
     
                    public void mouseReleased(MouseEvent e) 
                    {
     
                    }
     
                    public void mouseEntered(MouseEvent e) 
                    {
     
                    }
     
                    public void mouseExited(MouseEvent e) 
                    {
     
     
                    }
                });
                top.add(jt); 
            }
            this.add(top,BorderLayout.NORTH);
            top.setVisible(false);
     
     
     
     
     
     
        }
     
     
     
        // documentListener pour nos JTextField de recherche
        class documentListener implements DocumentListener
        {
            int i;
            JTextField jt;
            public documentListener(int i,JTextField jt)
            {
                this.i=i;
                this.jt=jt;
            }
     
            public void insertUpdate(DocumentEvent e) {
                newFilter(i,jt);
            }
     
            public void removeUpdate(DocumentEvent e) {
                newFilter(i,jt);
            }
     
            public void changedUpdate(DocumentEvent e) {
                newFilter(i,jt);
            }
     
        }  
     
    }

  2. #2
    Rédacteur/Modérateur
    Avatar de Logan Mauzaize
    Homme Profil pro
    Architecte technique
    Inscrit en
    Août 2005
    Messages
    2 894
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Transports

    Informations forums :
    Inscription : Août 2005
    Messages : 2 894
    Par défaut
    Dans ta méthode newFilter tu devrais gérer une liste ou un tableau de filtre.
    Utilises le paramètre i pour voir retrouver ton filtre.
    Java : Cours et tutoriels - FAQ - Java SE 8 API - Programmation concurrente
    Ceylon : Installation - Concepts de base - Typage - Appels et arguments

    ECM = Exemple(reproduit le problème) Complet (code compilable) Minimal (ne postez pas votre application !)
    Une solution vous convient ? N'oubliez pas le tag
    Signature par pitipoisson

  3. #3
    Membre averti
    Inscrit en
    Janvier 2010
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 21
    Par défaut
    il serait possible que tu me donne un coup de pouce un peu plus fort ?
    j'ai vraiment du mal avec cet algorithme.
    J'ai compris à peu près ou tu voulais en venir. Une liste pour pouvoir la parcourir et appliquer un à un les filtre de dans. Mais je vois pas trop comment mettre ca en place


    edit : enfait mon problème vient de ma variable sorter. A chaque fois mon filtre s'applique dessus et donc prend ma table d'origine. yaurai pas moyen de créer un nouveau sorter après l'application d'un filtre ? Comme ca j'utiliserai ce sorter la pour les autres filtres et non le sorter d'origine.

  4. #4
    Rédacteur/Modérateur
    Avatar de Logan Mauzaize
    Homme Profil pro
    Architecte technique
    Inscrit en
    Août 2005
    Messages
    2 894
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Transports

    Informations forums :
    Inscription : Août 2005
    Messages : 2 894
    Par défaut
    Utilises un tableau de String dont la taille correspond au nombre de colonne.
    Le paramètre i te servira à savoir quel indice du tableau tu dois mettre à jour.

    Pour constuire le rowFilter, utilises le and.
    Java : Cours et tutoriels - FAQ - Java SE 8 API - Programmation concurrente
    Ceylon : Installation - Concepts de base - Typage - Appels et arguments

    ECM = Exemple(reproduit le problème) Complet (code compilable) Minimal (ne postez pas votre application !)
    Une solution vous convient ? N'oubliez pas le tag
    Signature par pitipoisson

  5. #5
    Membre averti
    Inscrit en
    Janvier 2010
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 21
    Par défaut
    Merci beaucoup Nemek !! J'ai enfin réussit !!!

    Je sais pas si j'ai fait exactement comme tu me l'a conseillé. Tu me diras.

    Voici mon code :

    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
    package elements;
    
    import elements.Connexion;
    import elements.Connexion;
    
    import java.sql.SQLException;
    import java.util.logging.Level;
    import java.util.logging.Logger;
    import javax.swing.*;
    import javax.swing.event.*;
    import javax.swing.table.AbstractTableModel;
    import javax.swing.table.TableRowSorter;
    
    import java.awt.*;
    import java.awt.event.ActionEvent;
    import java.awt.event.ActionListener;
    import java.awt.event.MouseAdapter;
    import java.awt.event.MouseEvent;
    import java.awt.event.MouseListener;
    import java.sql.ResultSet;
    import java.sql.ResultSetMetaData;
    import java.util.ArrayList;
    import java.util.Vector;
    import javax.swing.table.DefaultTableModel;
    
    public class TableFilterDemo extends JPanel
    {
        private boolean DEBUG = false;
        public JTable table; // JTable de notre JPanel
        public static int i; // sert à associer un JTextField de recherche à sa colonne
        public TableRowSorter<DefaultTableModel> sorter; // sert à la fonction recherche
        public DefaultTableModel model; // le modèle de notre JTable
        public JPanel top; // panel contenant les JTextField de recherche
        Boolean booltop=false; // booléan pour afficher/enlever le panel top
    
        public static int identify;
        ArrayList<RowFilter<Object,Object>> filters = new ArrayList<RowFilter<Object,Object>>();
       
             
         
    
        public TableFilterDemo(String query) throws ClassNotFoundException, SQLException 
        {
            
            super();
            top=new JPanel(new FlowLayout(FlowLayout.LEFT,15,0));
           
            this.i=i;
            setLayout(new BorderLayout());
             
            Vecteur v=new Vecteur(query);
            
            model = new DefaultTableModel(v.ligne,v.colonne);
            
            
            sorter = new TableRowSorter<DefaultTableModel>(model);
            table = new JTable(model);
            table.setRowSorter(sorter);
            table.setPreferredScrollableViewportSize(new Dimension(500, 70));
            table.setFillsViewportHeight(true);
    
            
            table.setSelectionMode(ListSelectionModel.SINGLE_SELECTION); // mode de séléction : unique
    
                 
            // fonction pour afficher/enlever le panel top             
            this.table.getTableHeader().addMouseListener(new MouseAdapter()
            {
                public void mouseReleased(MouseEvent event)
                {
    		if(event.getButton() == event.BUTTON3)
                    {
                        //Si on est dans le tableau
                        if(table.columnAtPoint(new Point(event.getX(), event.getY())) != -1)
                        {
    			if(booltop==true)
                            {
                               top.setVisible(false);
                               booltop=false;
                             }
                             else
                             {
                                top.setVisible(true);
                                booltop=true;
                             }
                        }
    		}
                }
    	});             
            JScrollPane scrollPane = new JScrollPane(table);
        
            add(scrollPane);
        
        }
    
        /** 
         * Update the row filter regular expression from the expression in
         * the text box.
         */
        
     
        private void setFilter(int i, JTextField jt)
        {
            filters.set(i,RowFilter.regexFilter(jt.getText(), i));
            RowFilter<Object,Object> rff = RowFilter.andFilter(filters);
            
            sorter.setRowFilter(rff);
        }
        
        
        // fonction qui créé un JTextField de recherche pour chaque colonne
        public void createTextField()
        {   
             
            for(i=0;i<model.getColumnCount();i++)
            {
                        
            
                top.add(new JLabel(model.getColumnName(i)+" :"));
                JTextField jt= new JTextField(7);
                filters.add(RowFilter.regexFilter(jt.getText(), i));
            
                jt.getDocument().addDocumentListener(
                new documentListener(i,jt));
                
                jt.addMouseListener(new MouseListener(){
    
                    public void mouseClicked(MouseEvent e) 
                    {
                        table.clearSelection();
          
                    }
    
                    public void mousePressed(MouseEvent e) 
                    {
                        
                    }
    
                    public void mouseReleased(MouseEvent e) 
                    {
                        
                    }
    
                    public void mouseEntered(MouseEvent e) 
                    {
                        
                    }
    
                    public void mouseExited(MouseEvent e) 
                    {
                      
                       
                    }
                });
                top.add(jt); 
            }
            this.add(top,BorderLayout.NORTH);
            top.setVisible(false);
            
            
            
            
            
           
        }
        
        
        
        // documentListener pour nos JTextField de recherche
        class documentListener implements DocumentListener
        {
            int i;
            JTextField jt;
            public documentListener(int i,JTextField jt)
            {
                this.i=i;
                this.jt=jt;
            }
    
            public void insertUpdate(DocumentEvent e) {
             
                setFilter(i,jt);
            }
    
            public void removeUpdate(DocumentEvent e) 
            {
               
                setFilter(i,jt);
            }
    
            public void changedUpdate(DocumentEvent e) {
             
            }
            
        }  
        
    }
    Les modifications sont en rouges. Voila d'après ce que j'ai testé le multi-filtrage fonctionne correctement et je n'ai pas de bug.

    Encore merci Nemek, sans toi je n'y serais jamais arrivé !

  6. #6
    Rédacteur/Modérateur
    Avatar de Logan Mauzaize
    Homme Profil pro
    Architecte technique
    Inscrit en
    Août 2005
    Messages
    2 894
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Transports

    Informations forums :
    Inscription : Août 2005
    Messages : 2 894
    Par défaut
    Ca sera suffisant, sauf que j'aurais également mis sur la méthode changedUpdate
    Java : Cours et tutoriels - FAQ - Java SE 8 API - Programmation concurrente
    Ceylon : Installation - Concepts de base - Typage - Appels et arguments

    ECM = Exemple(reproduit le problème) Complet (code compilable) Minimal (ne postez pas votre application !)
    Une solution vous convient ? N'oubliez pas le tag
    Signature par pitipoisson

  7. #7
    Membre averti
    Inscrit en
    Janvier 2010
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 21
    Par défaut
    J'ai changé le titre du post en "[Résolu]" . Voilou merci

  8. #8
    Rédacteur/Modérateur
    Avatar de Logan Mauzaize
    Homme Profil pro
    Architecte technique
    Inscrit en
    Août 2005
    Messages
    2 894
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Transports

    Informations forums :
    Inscription : Août 2005
    Messages : 2 894
    Par défaut
    En général on utilise le bouton ^_^
    Java : Cours et tutoriels - FAQ - Java SE 8 API - Programmation concurrente
    Ceylon : Installation - Concepts de base - Typage - Appels et arguments

    ECM = Exemple(reproduit le problème) Complet (code compilable) Minimal (ne postez pas votre application !)
    Une solution vous convient ? N'oubliez pas le tag
    Signature par pitipoisson

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 27/03/2014, 20h33
  2. [SP-2013] Appliquer plusieurs filtres = impossible ?
    Par Kael_004 dans le forum SharePoint
    Réponses: 2
    Dernier message: 16/01/2014, 09h55
  3. [XL-2007] Filtre avec plusieurs éléments appliqué à plusieurs TCD
    Par Olivm dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 18/03/2011, 09h15
  4. [XSL]Appliquer plusieurs feuilles XSL successivement
    Par philemon_siclone dans le forum XSL/XSLT/XPATH
    Réponses: 8
    Dernier message: 12/12/2003, 19h11
  5. appliquer plusieurs templates
    Par Manu_Just dans le forum XSL/XSLT/XPATH
    Réponses: 7
    Dernier message: 04/04/2003, 16h26

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