如果使用java满足某些条件,如何为某一行设置颜色?

2023-12-14

我有一个jtable。 (表格摘要)。其中一栏是 EXPIRY。我想突出显示客户的行,其到期日已在当前日期失效。

我已经有了逻辑,但我无法使该行变成红色或任何其他颜色。 这是我的代码:

         int count = (tableSummary.getRowCount());
         NumberFormat formatter = new DecimalFormat("###,###");          
         String no = formatter.format(count);
         txtNo.setText(no);

            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");     
            Calendar cal  = Calendar.getInstance();           
            String expDateString = sdf.format(cal.getTime()).toString();

            for(int i=0; i<=tableSummary.getRowCount()-1; i++){
                String nnn= tableSummary.getModel().getValueAt(i, 6).toString();   
                System.out.println(nnn);
                int res = nnn.compareTo(expDateString); 
                    if(res>=0){
                        System.out.println("if ni " + (res>=0));
                    }
                    else{ 
                        System.out.println("else ni" + (res>=0));
                        rowrenderer.setBackground(Color.RED);


                    }                        
            }

谁能帮我这个?因为它是我界面的主要亮点之一。 提前致谢 !! :)


...在之前的线程和答案中描述,仅是示例

enter image description here

从代码

import java.awt.*;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.swing.*;
import javax.swing.border.LineBorder;
import javax.swing.table.*;

public class TablePrepareRenderer extends JFrame {

    private static final long serialVersionUID = 1L;
    private JTable table;
    private Date maturityDate = new Date();
    private Date todayDate = new Date();
    private SimpleDateFormat sdf = new SimpleDateFormat("dd.MM.yyyy");
    private Date tableDate = new Date();
    private String strDate = "";
    private Date modifDate = new Date();
    private Calendar cal;

    public TablePrepareRenderer() {
        Object[] columnNames = {"Type", "Company", "Shares", "Price", "Date"};
        Object[][] data = {
            {"Buy", "IBM", new Integer(1000), new Double(80.50), new Date()},
            {"Sell", "MicroSoft", new Integer(2000), new Double(6.25), new Date()},
            {"Sell", "Apple", new Integer(3000), new Double(7.35), new Date()},
            {"Buy", "Nortel", new Integer(4000), new Double(20.00), new Date()}
        };
        DefaultTableModel model = new DefaultTableModel(data, columnNames) {

            private static final long serialVersionUID = 1L;

            @Override
            public Class getColumnClass(int column) {
                return getValueAt(0, column).getClass();
            }
        };
        table = new JTable(model) {

            private static final long serialVersionUID = 1L;

            @Override
            public Component prepareRenderer(TableCellRenderer renderer, int row, int column) {
                Component c = super.prepareRenderer(renderer, row, column);
                /*int firstRow = 0;
                int lastRow = table.getRowCount() - 1;
                if (row == lastRow) {
                ((JComponent) c).setBackground(Color.red);
                } else if (row == firstRow) {
                ((JComponent) c).setBackground(Color.blue);
                } else {
                ((JComponent) c).setBackground(table.getBackground());
                }*/
                if (!isRowSelected(row)) {
                    if (table.getColumnCount() >= 0) {
                        String type = (String) getModel().getValueAt(row, 0);
                        c.setBackground("Buy".equals(type) ? Color.YELLOW : Color.GREEN);
//
                        maturityDate = new Date();
                        todayDate = new Date();
                        strDate = sdf.format(todayDate);
                        try {
                            todayDate = sdf.parse(strDate);
                        } catch (ParseException ex) {
                            Logger.getLogger(TablePrepareRenderer.class.getName()).log(Level.SEVERE, null, ex);
                        }
                        tableDate = (Date) table.getValueAt(row, 4);
                        strDate = sdf.format(tableDate);
                        if (strDate != null) {
                            if (!strDate.isEmpty()) {
                                try {
                                    maturityDate = sdf.parse(strDate);
                                } catch (ParseException ex) {
                                    Logger.getLogger(TablePrepareRenderer.class.getName()).log(Level.SEVERE, null, ex);
                                }
                                if (maturityDate != null) {
                                    int mmDiffDealToValue = (maturityDate).compareTo(todayDate);
                                    if (((mmDiffDealToValue < 0))) {
                                        c.setBackground(Color.orange);
                                        c.setFont(new Font("Serif", Font.BOLD, 12));
                                    }
                                }
                            }
                        }
//
                    }
                }
                if (isRowSelected(row) && isColumnSelected(column)) {
                    ((JComponent) c).setBorder(new LineBorder(Color.red));
                }
                return c;
            }
        };
        modifyDateInTable();
        table.setPreferredScrollableViewportSize(table.getPreferredSize());
        JScrollPane scrollPane = new JScrollPane(table);
        getContentPane().add(scrollPane);
    }

    private void modifyDateInTable() {
        Calendar c = Calendar.getInstance();
        c.setTime(modifDate);
        c.add(Calendar.DATE, - 1);
        modifDate = c.getTime();
        table.setValueAt(modifDate, 0, 4);
        c.setTime(modifDate);
        c.add(Calendar.DATE, +5);
        modifDate = c.getTime();
        table.setValueAt(modifDate, 1, 4);
        c.setTime(modifDate);
        c.add(Calendar.DATE, +1);
        modifDate = c.getTime();
        table.setValueAt(modifDate, 1, 4);
        c.setTime(modifDate);
        c.add(Calendar.DATE, - 16);
        modifDate = c.getTime();
        table.setValueAt(modifDate, 3, 4);
    }

    public static void main(String[] args) {
        SwingUtilities.invokeLater(new Runnable() {

            @Override
            public void run() {
                TablePrepareRenderer frame = new TablePrepareRenderer();
                frame.setDefaultCloseOperation(EXIT_ON_CLOSE);
                frame.pack();
                frame.setLocation(150, 150);
                frame.setVisible(true);
            }
        });
    }
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如果使用java满足某些条件,如何为某一行设置颜色? 的相关文章

随机推荐