Есть ли способ, которым я могу выделить или покрасить различные строки таблицы на основе данных, введенных в текстовое поле? - PullRequest
0 голосов
/ 21 июня 2019

То, что я пытаюсь сделать, это выделить серийный номер, который я сканирую из коробки предметов.

Так что, когда я сканирую S / N. Моя идея состоит в том, что таблица, которая содержит элементы в коробке, меняет свой цвет. Мой английский отстой, поэтому я думаю, что картинки могут объяснить мою идею лучше.

Итак, мой код выполняет следующие действия:

Сначала я загружаю таблицу с информацией из поля 1 («Gaveta»):

http://prntscr.com/o4ykdy

Затем, когда я фильтрую S / N элемента в коробке:

http://prntscr.com/o4yly4

Я сталкиваюсь с моей проблемой, поиск рисует правильный S / N, но это повреждает мою табличную модель.

Мой код:

Поиск данных:

public void buscarNumeroSerie (String nserie) { попробуй {

             String [] campos={"NUMERO_SERIE","MARCA","GAVETA"};
             String filtroNS = nserie;
             String NSSQL = "SELECT NUMERO_SERIE,MARCA,GAVETA FROM"
                     + "(SELECT NUMERO_SERIE,MARCA,GAVETA FROM discos_wd "
                     + "UNION "
                     + "SELECT NUMERO_SERIE,MARCA,GAVETA FROM discos_toshiba "
                     + "UNION "
                     + "SELECT NUMERO_SERIE,MARCA,GAVETA FROM discos_seagate "
                     + "UNION "
                     + "SELECT NUMERO_SERIE,MARCA,GAVETA FROM discos_samsung "
                     + "UNION "
                     + "SELECT NUMERO_SERIE,MARCA,GAVETA FROM discos_hitachi )"
                     + "AS TROUBLE WHERE NUMERO_SERIE LIKE '%"+filtroNS+"%'";

            System.out.println(NSSQL); 
                    nsconn = metodosPool.dataSource.getConnection();
                    //ModeloTablaLista = new DefaultTableModel(null, campos);
                    stmnt = nsconn.prepareStatement(NSSQL);
                    ResultSet nsrs = stmnt.executeQuery(NSSQL);
                    String [] nsfila = null;
            //if(nsrs.next()== true){
             //       String [] nsfila = new String[3];



                while (nsrs.next())
                    {   
                        nsfila = new String[3];
                        nsfila[0]=nsrs.getString("Numero_Serie");
                        nsfila[1]=nsrs.getString("Marca");
                        nsfila[2]=nsrs.getString("Gaveta");
                       // ModeloTablaLista.addRow(nsfila);
                    }

                if (nsfila == null) 
                    {
                               Object[] opcionesPurga = {"Agregar Disco Hitachi",
                                   "Agregar Disco Toshiba",
                                   "Agregar Disco Seagate",
                                   "Agregar Disco Samsung",
                                   "Agregar Disco WD",
                                   "Omitir"};

                               int sinDiscoEnTabla = JOptionPane.showOptionDialog
                                            (rootPane, 
                                            "Disco no encontrado, ¿que desea hacer?:", 
                                            "Disco no encontrado", 
                                            JOptionPane.YES_NO_OPTION, 
                                            JOptionPane.QUESTION_MESSAGE, 
                                            null, 
                                            opcionesPurga,
                                            opcionesPurga[1]);

                               System.out.println(sinDiscoEnTabla);

                    switch (sinDiscoEnTabla){

                            case 0:
                            sinDiscoAddHi.setVisible(true);
                            break;

                            case 1:
                            sinDiscoAddTo.setVisible(true);    
                            break;

                            case 2:
                            sinDiscoAddSe.setVisible(true);      
                            break;

                            case 3:
                            sinDiscoAddHi.setVisible(true);        
                            break;

                            case 4:
                            sinDiscoAddWD.setVisible(true);        
                            break;

                            case 5:
                            JOptionPane.showMessageDialog(null,"Por favor ingrese un nuevo disco:");  
                            tfNumeroSeriePurga.setText("");
                            break;
                    }
                    }
                nsrs.close();
                        stmnt.close();
                       // tablaDiscosGaveta.setModel(ModeloTablaLista);
                        ClaseColor colorear = new ClaseColor(0);
                        tablaDiscosGaveta.getColumnModel().getColumn(0).setCellRenderer(colorear);
           }

           //else
           //  {

            //    System.err.println("No existen datos asociados");
            //         JOptionPane.showMessageDialog(rootPane, "Disco no encontrado, quiere:");
           //    } 


catch (SQLException nseerr) 
                    {
                      System.err.println(""+nseerr.getSQLState());
                      JOptionPane.showMessageDialog(null, "Error al buscar \n"
                      +nseerr, "Error en la operacion ", JOptionPane.ERROR_MESSAGE);
                    }                    

}  

Таблица Renderer:

открытый класс ClaseColor extends DefaultTableCellRenderer {

private final int patron;  

public ClaseColor(int patron) {
    this.patron = patron;
}

@Override
public Component getTableCellRendererComponent
           (JTable tablaDiscosGaveta, 
            Object value, 
            boolean Selected, 
            boolean hasFocus, 
            int row, 
            int col) 
    {

    if (!tfNumeroSeriePurga.getText().equals(tablaDiscosGaveta.getValueAt(row, patron).toString())) 

    {
        System.out.println("FramePurgar.PurgarDiscos1.ClaseColor.methodName()"+"no pille nada !");
    } 
   else
    {
        setForeground(Color.RED);
        //setFont(font);
        //
        super.getTableCellRendererComponent(tablaDiscosGaveta, value, Selected, hasFocus, row, col);
        return this;
    }

вернуть это;

} }

Я пытаюсь нарисовать каждый S / N, который совпадает с «Serial Number» textField, который выполняет поиск.

Примерно так:

http://prntscr.com/o4ynui

поэтому любой новый S / N i search, получить отметку, пока я продолжаю сканировать S / N, а затем S / N, которые не отмечены, удаляются из таблицы.

Ответы [ 3 ]

1 голос
/ 21 июня 2019

Поскольку вы не даете нам минимально воспроизводимый пример , я создал свой собственный пример, чтобы показать вам, как это можно сделать.Использование подчеркивания к JTable было бы сложно, так как (я думаю) JTextPane требуется.Однако добиться чего-то похожего легче, выделив текст поиска в ячейке таблицы.Конечно, для этого нам нужно создать свой собственный TableCellRenderer .

Код:

public class TableExample extends JFrame {
    private static final Color HIGHLIGHT_COLOR = Color.GREEN;
    private JTextField textField;

    TableExample() {
        String data[][] = { { "101", "Mike", "17" }, { "102", "Thomas", "21" }, { "103", "Brian", "42" }, { "104", "George", "24" } };
        String column[] = { "ID", "NAME", "AGE" };

        JPanel inputpanel = new JPanel(new BorderLayout(10, 10));

        JTable table = new JTable();
        JScrollPane sp = new JScrollPane(table); // You were not adding the sp into your panel, take care that next time.
        DefaultTableModel dtm = new DefaultTableModel(data, column); // Create the model with our data.
        table.setModel(dtm);
        table.setDefaultRenderer(Object.class, new CellHighlightRenderer());

        textField = new JTextField();
        textField.getDocument().addDocumentListener(new DocumentListener() {

            @Override
            public void removeUpdate(DocumentEvent e) {
                table.repaint();

            }

            @Override
            public void insertUpdate(DocumentEvent e) {
                table.repaint();
            }

            @Override
            public void changedUpdate(DocumentEvent e) {
                table.repaint();
            }
        });

        inputpanel.add(textField, BorderLayout.PAGE_START);
        inputpanel.add(sp);

        add(inputpanel);
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        setSize(300, 400);
        setLocationRelativeTo(null);
        pack();
    }

    class CellHighlightRenderer extends JTextField implements TableCellRenderer {
        public DefaultHighlighter high = new DefaultHighlighter();
        public DefaultHighlighter.DefaultHighlightPainter highlight_painter = new DefaultHighlighter.DefaultHighlightPainter(HIGHLIGHT_COLOR);

        public CellHighlightRenderer() {
            setBorder(BorderFactory.createEmptyBorder());
            setHighlighter(high);
        }

        @Override
        public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) {
            setBackground(isSelected ? table.getSelectionBackground() : table.getBackground());
            setForeground(isSelected ? table.getSelectionForeground() : table.getForeground());

            setFont(table.getFont());
            setValue(value);
            int pos = 0;
            String word = textField.getText();
            word = word.toLowerCase();// In order to improve search?
            String stringValue = value.toString();
            stringValue = stringValue.toLowerCase(); // In order to improve search?
            if (!word.isEmpty()) {
                if ((pos = stringValue.indexOf(word, pos)) >= 0) {
                    try {
                        high.addHighlight(pos, pos + word.length(), highlight_painter);
                        pos += word.length();
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            }
            return this;
        }

        protected void setValue(Object value) {
            setText((value == null) ? "" : value.toString());
        }
    }

    public static void main(String[] args) {
        SwingUtilities.invokeLater(() -> {
            TableExample te = new TableExample();
            te.setVisible(true);
        });

    }
}

Предварительный просмотр:

enter image description here

0 голосов
/ 25 июня 2019

Окончательное обновление при этом, я исправил свою проблему, изменив значение в следующей строке:

   Component comp = super.getTableCellRendererComponent(tablaDiscosGaveta, col, rootPaneCheckingEnabled, rootPaneCheckingEnabled, row, col);

для

        Component comp = super.getTableCellRendererComponent(tablaDiscosGaveta, value, rootPaneCheckingEnabled, rootPaneCheckingEnabled, row, col);

Наконец-то!

0 голосов
/ 25 июня 2019

Ну, я действительно могу делать то, что хочу, теперь мне нужно уточнить некоторые детали.

Сначала код рендерера:

 public class ClaseColor extends DefaultTableCellRenderer {

private final int patronSerie;

public ClaseColor(int patron) {
    this.patronSerie = patron;
}

@Override
public Component getTableCellRendererComponent
           (JTable tablaDiscosGaveta, 
            Object value, 
            boolean Selected, 
            boolean hasFocus, 
            int row, 
            int col) 
    {
    Component comp = super.getTableCellRendererComponent(tablaDiscosGaveta, col, rootPaneCheckingEnabled, rootPaneCheckingEnabled, row, col);

    for (int i = 0; i < tablaDiscosGaveta.getRowCount(); i++) 
    {
                        if(tablaDiscosGaveta.getValueAt(i, 0).toString().equals(tfNumeroSeriePurga.getText()))
                        {
                        System.out.println("El número si existe");
                        }
                        else
                        {
                        System.out.println("El número no existe");
                        }

    if (!tablaDiscosGaveta.isRowSelected(row))
            {
                comp.setBackground(getBackground());
                                    int modelRow = tablaDiscosGaveta.convertRowIndexToModel(row);
                if(tablaDiscosGaveta.getValueAt(i, 0).toString().equals(tfNumeroSeriePurga.getText()))
                                    {
                comp.setBackground(Color.GREEN);

            }
    }}return this;}

тогда я применяю это к столу

nsrs.close();
                        stmnt.close();
                        tablaDiscosGaveta.setModel(ModeloTablaLista);
                        ClaseColor comp = new ClaseColor(0);                            
                        tablaDiscosGaveta.getColumnModel().getColumn(0).setCellRenderer(comp);

           }

с этим я мог фильтровать и устанавливать зеленый фон, когда я соответствую фильтру.

но при фильтрации показываются только "нули", поэтому мне нужно это исправить.

Фильтр исправен

Показывает фон, который я хотел, но не серийный номер, который мне нужен

...