0

我遇到了一个真正的大问题,而且问题如此之大,因为我到处搜索,但找不到解决方案。

我想把一整行永远染成黄色。黄色行表示客户已经付款。在那之后,我仍然需要能够选择行(他们选择的应该是蓝色的,其他的应该是白色的)来对它们做其他事情(更新、删除等)。但这一切都变得一团糟,最后,我刚刚按下的每一行都变黄了,我不明白为什么。我正在使用自定义 tableCellRenderer。

如果该行已付款,我是否必须在每次按行时证明该行是否已付款?然后把它涂成黄色或蓝色?

teilnehmertable.setDefaultRenderer(Object.class, new MyTableCellRender(teilnehmertable.getSelectedRow()));
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) {
        try {
            Class.forName("com.mysql.jdbc.Driver");
            con = DriverManager.getConnection("jdbc:mysql://10.0.0.1:3306/askoedb", "name", "pw");
            stmt = con.createStatement();
            rs1 = stmt.executeQuery("SELECT bezahlt FROM askoedb.teilnehmer");
            while (rs1.next()) {
                System.out.println(rs1.getString(1));
                if (rs1.getString(1) != null) {
                    if (selectedRow != -1) {
                        if (row == selectedRow) {
                            setForeground(Color.black);
                            setBackground(Color.yellow);
                        } else {
                            setForeground(Color.black);
                            setBackground(Color.white);
                        }
                    }
                    setText(value != null ? value.toString() : "");
                } else {
                    if (selectedRow != -1) {
                        if (row == selectedRow) {
                            setForeground(Color.white);
                            setBackground(Color.blue);
                        } else {
                            setForeground(Color.black);
                            setBackground(Color.white);
                        }
                    }
                }
            }

            return this;
        } catch (ClassNotFoundException | SQLException ex) {
            Logger.getLogger(Client.class.getName()).log(Level.SEVERE, null, ex);
        } finally {
            try {
                con.close();
            } catch (SQLException ex) {
                Logger.getLogger(Client.class.getName()).log(Level.SEVERE, null, ex);
            }
        }
        return this;
    }
4

1 回答 1

1

如果该行已付款,我是否必须在每次按行时证明该行是否已付款?然后把它涂成黄色或蓝色?

是的,每次选择/取消选择时都会呈现该行。

有关允许您根据特定列中的值为整行着色的方法,请参阅表格行渲染。

于 2013-10-06T02:41:35.563 回答