简体   繁体   中英

display resultset in jtable cell with multiline

I am pulling database records from MySql , I am able to do this using the method below

private void txt_clientNameKeyReleased(java.awt.event.KeyEvent evt) {                                           

    String sql = "Select client_id as 'Client ID', name_lastName as 'Full Name', case_number as 'Case #', hearing_date as 'Hearing Date', rtc_mtc as 'RTC/MTC', place as 'Place', status as 'Status', note as 'Notes', billing as 'Billed' from hearing_history where name_lastName like '%"+ txt_clientName.getText() +"%' ";

    try{
        if(conn==null){

            conn = ConnectDB.ConDB();
        }else{
            conn = ConnectDB.ConDB();
        }

        pst = conn.prepareStatement(sql);
        rs = pst.executeQuery();

        jTable1.setModel(DbUtils.resultSetToTableModel(rs));            

    }catch(Exception e){
        JOptionPane.showMessageDialog(null, e);
    }finally {
        close();

    }
} 

it is working fine but I have a column that should have a multiple line or to wrap the words to increase the height of the cell.

I am using java swing for 4 months now and I haven't seen/encountered advanced tricks to manipulate jtable as I wanted it to perform.

I searched this site and found shortest way to do it from this link

Auto adjust the height of rows in a JTable

from camickr

private void updateRowHeights()
{
try 
{
    for (int row = 0; row < table.getRowCount(); row++)
    {
        int rowHeight = table.getRowHeight();

        for (int column = 0; column < table.getColumnCount(); column++)
        {
            Component comp = table.prepareRenderer(table.getCellRenderer(row, column), row, column);
            rowHeight = Math.max(rowHeight, comp.getPreferredSize().height);
        }

        table.setRowHeight(row, rowHeight);
    }
}
catch(ClassCastException e) {}

}

It is really a nice code I think but I tried it and I noticed that the height increase from 16 (default row height) to 20 and so I still have one line in the cells.

I called this method after the line

        jTable1.setModel(DbUtils.resultSetToTableModel(rs));            
        updateRowHeights();

I will really appreciate any help that will put my feet on the right track to make this work for me..

Thanks in advance..

Default renderer/editor doesn't support multiple lines. You can try to use custom TableCellEditor / TableCellRenderer . Examine next example with JTextArea in table cell:

import java.awt.Component;

import javax.swing.AbstractCellEditor;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextArea;
import javax.swing.table.TableCellEditor;
import javax.swing.table.TableCellRenderer;

public class TestFrame extends JFrame {

    public TestFrame() {
        init();
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        pack();
        setLocationRelativeTo(null);
        setVisible(true);
    }

    private void init() {
        JTable t = new JTable(new Object[][]{{"a\n\rb","1"},{"a\n\rb","2"}},new Object[]{1,2});

        add(new JScrollPane(t));
        t.getColumnModel().getColumn(0).setCellRenderer(new JTextAreaColumn());
        t.getColumnModel().getColumn(0).setCellEditor(new JTextAreaColumn());
        t.setRowHeight(50);
    }


    public static void main(String args[]) {
        new TestFrame();
    }


    private class JTextAreaColumn extends AbstractCellEditor implements TableCellRenderer,TableCellEditor {

        private JTextArea area = new JTextArea();
        private JScrollPane pane = new JScrollPane(area);

        @Override
        public Object getCellEditorValue() {
            return area.getText();
        }

        @Override
        public Component getTableCellEditorComponent(JTable table,
                Object value, boolean isSelected, int row, int column) {
            area.setText(value == null ? "" : value.toString());        
            return pane;
        }

        private void setColor(boolean isSelected, JTable table) {
            area.setBackground(isSelected ? table.getSelectionBackground() : table.getBackground());
            area.setForeground(isSelected ? table.getSelectionForeground() : table.getForeground());
        }

        @Override
        public Component getTableCellRendererComponent(JTable table,
                Object value, boolean isSelected, boolean hasFocus, int row,
                int column) {
            area.setText(value == null ? "" : value.toString());
            setColor(isSelected,table);
            return pane;
        }

    }

}

在此处输入图片说明

Read more in tutorial

EDIT:

Try next, seems it what you want;

import java.awt.Component;

import javax.swing.AbstractCellEditor;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextArea;
import javax.swing.event.CellEditorListener;
import javax.swing.event.ChangeEvent;
import javax.swing.table.TableCellEditor;
import javax.swing.table.TableCellRenderer;

public class TestFrame extends JFrame {

    private JTable t;


    public TestFrame() {
        init();
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        pack();
        setLocationRelativeTo(null);
        setVisible(true);
    }

    private void init() {
        t = new JTable(new Object[][]{{"a\n\rb","1"},{"a\n\rb\n\rb\n\rb\n\rb","2"}},new Object[]{1,2});

        add(new JScrollPane(t));
        t.getColumnModel().getColumn(0).setCellRenderer(new JTextAreaColumn());
        JTextAreaColumn editor = new JTextAreaColumn();
        editor.addCellEditorListener(getEditorListener());
        t.getColumnModel().getColumn(0).setCellEditor(editor);
        updateRowHeights(t);
    }

    private CellEditorListener getEditorListener() {
        return new CellEditorListener() {

            @Override
            public void editingStopped(ChangeEvent e) {
                updateRowHeights(t);
            }

            @Override
            public void editingCanceled(ChangeEvent e) {
                updateRowHeights(t);
            }
        };
    }

    private void updateRowHeights(JTable table) {
        try {
            for (int row = 0; row < table.getRowCount(); row++) {
                int rowHeight = table.getRowHeight();

                for (int column = 0; column < table.getColumnCount(); column++) {
                    Component comp = table.prepareRenderer(
                            table.getCellRenderer(row, column), row, column);
                    rowHeight = Math.max(rowHeight,
                            comp.getPreferredSize().height);
                }

                table.setRowHeight(row, rowHeight);
            }
        } catch (ClassCastException e) {
        }
    }

    public static void main(String args[]) {
        new TestFrame();
    }


    private class JTextAreaColumn extends AbstractCellEditor implements TableCellRenderer,TableCellEditor {

        private JTextArea area = new JTextArea();
        private JScrollPane pane = new JScrollPane(area);

        @Override
        public Object getCellEditorValue() {
            return area.getText();
        }

        @Override
        public Component getTableCellEditorComponent(JTable table,
                Object value, boolean isSelected, int row, int column) {
            area.setText(value == null ? "" : value.toString());        
            return pane;
        }

        private void setColor(boolean isSelected, JTable table) {
            area.setBackground(isSelected ? table.getSelectionBackground() : table.getBackground());
            area.setForeground(isSelected ? table.getSelectionForeground() : table.getForeground());
        }

        @Override
        public Component getTableCellRendererComponent(JTable table,
                Object value, boolean isSelected, boolean hasFocus, int row,
                int column) {
            area.setText(value == null ? "" : value.toString());
            setColor(isSelected,table);
            return area;
        }

    }

}

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM