0

每当有人单击单元格时,我都想执行操作。例如,打开另一个 gui。但是如何使单元格可点击但不可编辑?这些是 sql 查询的结果。不过,我无法使表格不可编辑。我需要一个听众还是什么?如果是的话,我应该把它放在哪里?

这是我的代码:

public class AllResultsFromDB extends JFrame
{

    GUI ins = new GUI();

    public AllResultsFromDB(GUI x)
    {
        Vector columnNames = new Vector();

        Vector data = new Vector();
        this.ins = x;

        try
        {   
            // Initializing GUI class in order to call getSelectedTable() method.
//            GUI ins = new GUI();
            //System.out.println(ins.getSelectedTable());
            Login sgui = new Login();

            String dburl = "jdbc:oracle:thin:@localhost:1521:ORCL";
            Connection connection = DriverManager.getConnection( dburl, sgui.getUsername(), sgui.getPassword() );


            //  Fetch data from table specified by user

            String query = "SELECT * FROM "  + ins.getSelectedTable() + " ORDER BY id";
            System.out.println(query);
            Statement stmt = connection.createStatement();
            ResultSet rset = stmt.executeQuery(query);   
            ResultSetMetaData metad = rset.getMetaData();
            int columns = metad.getColumnCount();



            //  This loop gets the names of the columns

            for (int i = 1; i <= columns; i++)
            {
                columnNames.addElement( metad.getColumnName(i) );
                //columnNames.addElement("PROFILES");
            }




            //  This loop gets the data inside the rows

            while (rset.next())
            {
                Vector row = new Vector(columns);

                //Vector b = new Vector((Collection)button);

                for (int i = 1; i <= columns; i++)
                {
                    row.addElement( rset.getObject(i) );
                }

                data.addElement( row );
                //data.addElement(b);
            }

            rset.close();
            stmt.close();
            connection.close();




            //  Create table with results

        JTable table = new JTable(data, columnNames)
        { 

            public Class getColumnClass(int column)
            { 
                for (int row = 0; row < getRowCount(); row++)
                {
                    Object obj = getValueAt(row, column);


                    if (obj != null)
                    {
                        return obj.getClass();
                    }
                }

                return Object.class;
            }

        };


        JScrollPane scroll = new JScrollPane( table );
        getContentPane().add( scroll );
        //table.addMouseListener(l);
        //table.setEnabled(false);
        //table.setDragEnabled(true);



        JPanel panel = new JPanel();
        getContentPane().add( panel, BorderLayout.SOUTH );

    } catch (SQLException e) {
        }


    }

}
4

1 回答 1

4

首先看看如何使用表格

确定单元格的isCellEditable方法TableModel是否可编辑。这个方法应该返回false

JTable当您直接向 提供列/数据信息时,会在内部JTable创建一个。DefaultTableModel此类的isCellEditiable方法将true默认返回。

通过使用类似的东西DefaultTableModel,您可以轻松地覆盖此方法并将模型直接设置到表中。

接下来,您需要将 a 附加MouseListener到表格

看看如何编写鼠标监听器

然后,您可以使用getSelectedColumngetSelectedRow来获取选定的单元格。

您还需要使用convertRowIndexToModelconvertColumnIndexToModel在视图和模型索引之间进行转换

于 2013-10-01T11:19:47.720 回答