Java 为什么自动调整行高在Jtable中不起作用
我已经实现了updateRowHeights,一种自动调整Jtable中行高度的方法, 尽管我的代码到目前为止运行良好,但它仍然不起作用。我忘了什么吗? (见:) 这是我的密码:Java 为什么自动调整行高在Jtable中不起作用,java,swing,jtable,tablecellrenderer,preferredsize,Java,Swing,Jtable,Tablecellrenderer,Preferredsize,我已经实现了updateRowHeights,一种自动调整Jtable中行高度的方法, 尽管我的代码到目前为止运行良好,但它仍然不起作用。我忘了什么吗? (见:) 这是我的密码: import javax.swing.*; import java.awt.*; public class ExampleTable { JTable textTable; public JPanel createTable() { JPanel totalGUI = new
import javax.swing.*;
import java.awt.*;
public class ExampleTable {
JTable textTable;
public JPanel createTable() {
JPanel totalGUI = new JPanel();
//define titles for table
String[] title = {"TITLE1", "TITLE2", "TITLE3"};
//table data
Object[][] playerdata = {
{new Integer(34), "Steve", "test test test"},
{new Integer(32), "Patrick", "du hu hu hu hu hu hu hu uh u kkkkkk oooo pppp"},
{new Integer(10), "Sarah", "xxxxxxxxxxxxx aaaaaaaaaa bbbbbbbbbbbbb dddddddddddd xxxxxxx gggewr eeeeeeeeee ddd g fffffff zzzzzzz"},};
//create object 'textTable'
textTable = new JTable(playerdata,title);
//set column width
textTable.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
textTable.getColumnModel().getColumn(0).setPreferredWidth(45);
textTable.getColumnModel().getColumn(1).setPreferredWidth(45);
textTable.getColumnModel().getColumn(2).setPreferredWidth(200);
textTable.setDefaultRenderer(String.class, new RowHeightCellRenderer());
//adjust dynamically the Row height of each cell
updateRowHeights();
//put line breaks if string is longer than cell-width
RowHeightCellRenderer dynRow = new RowHeightCellRenderer();
textTable.getColumnModel().getColumn(2).setCellRenderer(dynRow);
System.out.println(textTable.getPreferredSize().height);
//scrollbar
JScrollPane scrollPane = new JScrollPane(textTable);
totalGUI.add(scrollPane);
return totalGUI;
}
private void updateRowHeights() {
/*
* Auto adjust the height of rows in a JTable.
* The only way to know the row height for sure is to render each cell
* to determine the rendered height. After your table is populated with
* data you can do:
*
*/
for (int row = 0; row < textTable.getRowCount(); row++) {
int rowHeight = textTable.getRowHeight();
for (int column = 0; column < textTable.getColumnCount(); column++)
{
Component comp = textTable.prepareRenderer(textTable.getCellRenderer(row, column), row, column);
System.out.println("Row: "+row+" Column: "+column+ " preferredHeight: "+comp.getPreferredSize().height);
rowHeight = Math.max(rowHeight, comp.getPreferredSize().height);
System.out.println("Row: "+row+" Column: "+column+ " RowHeight: "+rowHeight);
}
textTable.setRowHeight(row, rowHeight);
}
}
private static void createAndShowGUI() {
//create main frame
JFrame mainFrame = new JFrame("");
ExampleTable test = new ExampleTable();
JPanel totalGUI = new JPanel();
totalGUI = test.createTable();
//visible mode
mainFrame.add(totalGUI); //integrate main panel to main frame
mainFrame.pack();
mainFrame.setVisible(true);
}
public static void main (String[] args) {
createAndShowGUI();
}//main
}
import java.awt.*;
import javax.swing.*;
import javax.swing.table.*;
非常感谢 看看你的代码:
updateRowHeights();
//put line breaks if string is longer than cell-width
RowHeightCellRenderer dynRow = new RowHeightCellRenderer();
textTable.getColumnModel().getColumn(2).setCellRenderer(dynRow);
随后将更新行高并设置单元渲染器。因此,更新方法显然不能使用预期的单元渲染器。更改顺序:
//put line breaks if string is longer than cell-width
RowHeightCellRenderer dynRow = new RowHeightCellRenderer();
textTable.getColumnModel().getColumn(2).setCellRenderer(dynRow);
updateRowHeights();
在计算和应用衍生单元高度之前,必须确保设置了影响单元视觉外观的所有属性
另一个问题是AWT布局概念,即
getPreferredSize()
,与需要查询“给定实际宽度下的首选高度”的单词换行概念不太匹配。您必须与Swing text API交互才能执行此类查询:
private void updateRowHeights() {
final TableColumnModel columnModel = textTable.getColumnModel();
Insets i=null;
for(int row = 0; row < textTable.getRowCount(); row++) {
int rowHeight = textTable.getRowHeight();
for(int column = 0; column < textTable.getColumnCount(); column++) {
Component comp = textTable.prepareRenderer(
textTable.getCellRenderer(row, column), row, column);
final int height;
if(comp instanceof JTextComponent) {
final JTextComponent tc = (JTextComponent)comp;
final View rootView = tc.getUI().getRootView(tc);
i=tc.getInsets(null);
rootView.setSize(columnModel.getColumn(column)
.getPreferredWidth()-i.left-i.right,
Integer.MAX_VALUE);
height=(int)rootView.getPreferredSpan(View.Y_AXIS);
}
else height = comp.getPreferredSize().height;
rowHeight = Math.max(rowHeight, height);
}
textTable.setRowHeight(row, rowHeight);
}
}
private void updateRowHeights(){
final TableColumnModel columnModel=textTable.getColumnModel();
插入i=空;
对于(int row=0;row
在此处搜索JTable+doLayout(),这很简单我更改了Holger提到的顺序,但仍然没有任何效果,我知道原因:渲染器在UpdateRowhight中始终获得18作为首选高度,尽管它肯定必须更高,但为什么?您注意到我答案的更新了吗?我想知道它是否对你有用…谢谢你的建议。我如前所述更改了顺序,但仍然没有任何效果,我知道原因:渲染器在updateRowHeight中始终获得18作为首选高度,虽然它肯定必须更高,但为什么???@user3300710:然后你必须显示你的单元格渲染器的代码。在这里搜索Swing+JTable+JTextArea(在@aterai的帖子中)或者在我的帖子Swing+JTable+JTextArea+doLayout()中为第二个问题添加了解决方案。
private void updateRowHeights() {
final TableColumnModel columnModel = textTable.getColumnModel();
Insets i=null;
for(int row = 0; row < textTable.getRowCount(); row++) {
int rowHeight = textTable.getRowHeight();
for(int column = 0; column < textTable.getColumnCount(); column++) {
Component comp = textTable.prepareRenderer(
textTable.getCellRenderer(row, column), row, column);
final int height;
if(comp instanceof JTextComponent) {
final JTextComponent tc = (JTextComponent)comp;
final View rootView = tc.getUI().getRootView(tc);
i=tc.getInsets(null);
rootView.setSize(columnModel.getColumn(column)
.getPreferredWidth()-i.left-i.right,
Integer.MAX_VALUE);
height=(int)rootView.getPreferredSpan(View.Y_AXIS);
}
else height = comp.getPreferredSize().height;
rowHeight = Math.max(rowHeight, height);
}
textTable.setRowHeight(row, rowHeight);
}
}