JTable:如何在中心对齐数据或如何设置行背景颜色交替

JTable : how to align data in the center or how to set row background color alternate

如何在 JTable 中设置行背景颜色并将数据与 center.The 对齐 JTable1 是动态的。 JTable 使用 defaultTableModel 设置数据。我想如果 i%==0 背景颜色是 #Color.GRAY 否则 #Color.WHITE 我阅读了渲染器 class 但无法理解渲染器 class

import java.awt.Dimension;
import java.awt.Font;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;

class FacultyList extends JPanel {

    static DefaultTableModel dm;
    JTable table;
    JScrollPane jsp_table;
    static Connection conn;
    static Statement stmt;
    static ResultSet rs;

    public FacultyList(Connection c) {
        conn = c;
        String col_name[] = {"S.No.", "Name", "Father Name", "College ID", 
            "Gender", "Date of Birth", "Branch", "Contact No."};
        dm = new DefaultTableModel(null, col_name);
        table = new JTable(dm);
        table.getTableHeader().setFont(new Font("Goudy Old Style", Font.BOLD, 15));
        table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
        table.getColumnModel().getColumn(0).setPreferredWidth(50);
        table.getColumnModel().getColumn(1).setPreferredWidth(150);
        table.getColumnModel().getColumn(2).setPreferredWidth(150);
        table.getColumnModel().getColumn(3).setPreferredWidth(125);
        table.getColumnModel().getColumn(4).setPreferredWidth(50);
        table.getColumnModel().getColumn(5).setPreferredWidth(125);
        table.getColumnModel().getColumn(6).setPreferredWidth(225);
        table.getColumnModel().getColumn(7).setPreferredWidth(150);
        jsp_table = new JScrollPane(table);
        jsp_table.setPreferredSize(new Dimension(975, 520));
        addRowTable();
        add(jsp_table);
    }

    public static void addRowTable() {
        try {
            int a = dm.getRowCount();
            int i = 0;
            while (i < a) {
                dm.removeRow(0);
                i++;
            }
            String fac = "Faculty";
            stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, 
                    ResultSet.CONCUR_UPDATABLE);
            rs = stmt.executeQuery("SELECT NAME, FNAME, CLG_ID, GANDER, "
                    + "DOB, BRANCH, CONTACT FROM PROFILE "
                    + "where I_AM = '" + fac + "'");
            int count = 1;
            while (rs.next()) {
                String s[] = new String[8];
                s[0] = "" + count;
                s[1] = rs.getString(1);
                s[2] = rs.getString(2);
                s[3] = rs.getString(3);
                s[4] = rs.getString(4);
                s[5] = rs.getString(5);
                s[6] = rs.getString(6);
                s[7] = "" + rs.getLong(7);
                count++;
                if (i % 2 == 0) {
                } else {
                }
                dm.addRow(s);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

on this site or java oracle doc

  • TableCellRenderer只是绘画,是基于XxxTableCellRenderer中设置的静态绘画,不是交互式的,是绘画幻觉,

  • XxxTableCellRenderer中的绘制非常复杂,并且从所有键和鼠标事件调用,相关 API 中实现的方法

  • 它可以是 JTable 的单独定义或单独的 class 那就是 returns 规则,JTable 视图的绘画定义

  • JDBC 不是设置或定义渲染器的好地方,关于从数据库添加新数据到 DefaultTableModel

  • ResultSet.CONCUR_UPDATABLE 无法为 JTable 设置,是 ResultSet 的快照,它没有任何返回数据库的操作

  • 为什么returns从JDBC限制到String s[] = new String[8];,设置data typed correctly by override getColumnClass

  • 在 Renderer 中设置对齐方式(数据类型默认为 returns 对齐方式),例如,通过转换为 JLabel,然后在 JLabels API 中实现的所有方法都可以在那里使用

  • 默认使用 prepareRenderer, getTableCellRendererComponent,用于整个 JTable 视图和 Renderer 的许多不同尝试仅适用于具体的 Columns[=26] =]

您可以使用自定义渲染器来执行此操作。可以按如下方式完成:

 table1 = new JTable(){

public Component prepareRenderer(TableCellRenderer tcr, int row,
    int column) {
    Component c = super.prepareRenderer(tcr, row, column);

    if (isRowSelected(row)) {

        c.setForeground(getSelectionForeground());
        c.setBackground(getSelectionBackground());

    } else {

        c.setForeground(getForeground());
        c.setBackground((row % 2 == 0) ? getBackground()
            : Color.lightGray);
    }

    int rendererWidth = c.getPreferredSize().width;
    TableColumn tableColumn = getColumnModel().getColumn(column);
    tableColumn.setPreferredWidth(Math.max(rendererWidth
        + getIntercellSpacing().width,
        tableColumn.getPreferredWidth()));

DefaultTableCellRenderer rightRenderer = new DefaultTableCellRenderer();
rightRenderer.setHorizontalAlignment(SwingConstants.CENTER);
table1.getColumnModel().getColumn(column).setCellRenderer(rightRenderer);
return c;
    }

  };;