(Swing) 在JTable中实现复选框,一种更好的方法

 

这种方法的好处是,比较容易得到复选框的返回值,只需使用getValuteAt( )

方法就可以得到一个boolean型的返回值

 

有两个文件:MyTableModel.java,MyTableDemo.java(包含main)

 

1、MyTableModel.java


import javax.swing.table.AbstractTableModel;

class MyTableModel extends AbstractTableModel {
  private String[] columnNames ;
  private Object[][] data ;
  public final Object[] longValues ;
  public MyTableModel(Object[][] Tabledate,String[] Tabletitle){
    columnNames = new String[Tabletitle.length ];
    columnNames = Tabletitle;
    data = new Object[Tabledate.length ][Tabledate[0].length ];
    data = Tabledate;
    longValues =new Object[Tabletitle.length];
  }

  public int getColumnCount() {
    return columnNames.length;
  }

  public int getRowCount() {
    return data.length;
  }

  public String getColumnName(int col) {
    return columnNames[col];
  }

  public Object getValueAt(int row, int col) {
    return data[row][col];
  }

  public Class getColumnClass(int c) {
    return getValueAt(0, c).getClass();
  }

  public boolean isCellEditable(int row, int col) {
    if (col < 2) {
      return false;
    }
    else {
      return true;
    }
  }

  public void setValueAt(Object value, int row, int col) {
    data[row][col] = value;
    fireTableCellUpdated(row, col);
  }
}

 

 

 

 

 

 

2、MyTableDemo.java


import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.TableCellRenderer;
import javax.swing.table.TableColumn;
import java.awt.Component;
import java.awt.Dimension;
import java.awt.GridLayout;

public class MyTableDemo extends JPanel {
  private String[] columnNames = {"学号", "姓名", "年龄", "专业", "选取"};
  private Object[][] data = {{"001","张三", new Integer(19), "计算机", new Boolean(true)},
                              {"002","李四", new Integer(20), "微电子", new Boolean(true)},
                              {"003","王五", new Integer(22),"数学",  new Boolean(false)},
                             };

  public MyTableDemo() {
    super(new GridLayout(1, 0));
    JTable table = new JTable(new MyTableModel(data, columnNames));
    table.setPreferredScrollableViewportSize(new Dimension(500, 70));
    JScrollPane scrollPane = new JScrollPane(table);
    initColumnSizes(table);
    add(scrollPane);
  }

  private void initColumnSizes(JTable table) {
    MyTableModel model = (MyTableModel) table.getModel();
    TableColumn column = null;
    Component comp = null;
    int headerWidth = 0;
    int cellWidth = 0;
    Object[] longValues = model.longValues;
    TableCellRenderer headerRenderer =
        table.getTableHeader().getDefaultRenderer();
    for (int i = 0; i < table.getColumnCount(); i++) {
      column = table.getColumnModel().getColumn(i);
      comp = headerRenderer.getTableCellRendererComponent(
          null, column.getHeaderValue(),
          false, false, 0, 0);
      headerWidth = comp.getPreferredSize().width;
      comp = table.getDefaultRenderer(
          model.getColumnClass(i)).getTableCellRendererComponent(
          table, longValues[i],
          false, false, 0, i);
      cellWidth = comp.getPreferredSize().width;
      column.setPreferredWidth(Math.max(headerWidth, cellWidth));

    }
  }

  private static void CreateAndShowGUI() {
    JFrame frame = new JFrame("MyTableDemo");
    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

    MyTableDemo newContentPane = new MyTableDemo();
    newContentPane.setOpaque(true);
    frame.setContentPane(newContentPane);

    frame.pack();
    frame.setVisible(true);
  }

  public static void main(String[] args) {
    javax.swing.SwingUtilities.invokeLater(new Runnable() {
      public void run() {
        CreateAndShowGUI();
      }
    });
  }
}

 

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
为了在Java SwingJTable显示MySQL数据库的记录,你需要执行以下步骤: 1. 连接到MySQL数据库:使用JDBC API连接到MySQL数据库。你需要提供MySQL数据库的URL、用户名和密码。 2. 准备SQL查询:使用SQL查询语句从MySQL数据库检索数据。 3. 执行SQL查询:执行SQL查询并将结果存储在ResultSet对象。 4. 创建TableModel:TableModel是JTable显示数据的核心。你需要从ResultSet对象检索列名和数据,并创建一个DefaultTableModel对象。 5. 创建JTable:使用DefaultTableModel对象创建JTable对象。 6. 添加JTable到JFrame:将JTable对象添加到JFrame。 下面是一个示例代码,它演示了如何在Java SwingJTable显示MySQL数据库的记录: ```java import java.sql.*; import javax.swing.*; import javax.swing.table.*; public class MySQLJTableExample extends JFrame { private JTable table; public MySQLJTableExample() { setTitle("MySQL JTable Example"); setSize(500, 500); setDefaultCloseOperation(EXIT_ON_CLOSE); // 连接到MySQL数据库 String url = "jdbc:mysql://localhost:3306/mydatabase"; String username = "root"; String password = "mypassword"; String query = "SELECT * FROM mytable"; try (Connection connection = DriverManager.getConnection(url, username, password); Statement statement = connection.createStatement(); ResultSet resultSet = statement.executeQuery(query)) { // 创建TableModel DefaultTableModel tableModel = new DefaultTableModel(); ResultSetMetaData metaData = resultSet.getMetaData(); int columnCount = metaData.getColumnCount(); for (int i = 1; i <= columnCount; i++) { tableModel.addColumn(metaData.getColumnName(i)); } while (resultSet.next()) { Object[] row = new Object[columnCount]; for (int i = 1; i <= columnCount; i++) { row[i - 1] = resultSet.getObject(i); } tableModel.addRow(row); } // 创建JTable table = new JTable(tableModel); // 添加JTable到JFrame add(new JScrollPane(table)); } catch (SQLException e) { e.printStackTrace(); } } public static void main(String[] args) { new MySQLJTableExample().setVisible(true); } } ``` 这个示例代码连接到名为"mydatabase"的MySQL数据库,用户名为"root",密码为"mypassword"。它从"mytable"表检索所有记录,并在JTable显示它们。你可以根据自己的需要修改代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值