安装JTable来填充JPanel

Chr*_*ris 1 java swing jtable

嗨,这是我的表格设置的代码:

String [] column = {"MacAddress","PcName","OperatingSystem","IpAddress","Port","Status"};
    model = new DefaultTableModel(0,column.length);
    model.setColumnIdentifiers(column);
    mainTable = new JTable(model);
    mainTable.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
    for(int i=0;i<=column.length-1;i++){
    mainTable.getColumnModel().getColumn(i).setPreferredWidth(300);
    }
    pane = new JScrollPane(mainTable);
    pnlTabel = new JPanel();
    pnlTabel.setBorder(BorderFactory.createTitledBorder(""));
    pnlTabel.setPreferredSize(new Dimension(dim.width*70/100, dim.height*60/100));
    pnlTabel.add(pane);
addMainPanel(pnlTabel);
Run Code Online (Sandbox Code Playgroud)

这是我的addMainPanel()函数:

public void addMainPanel(Component pnl){
    mainPanel.add(pnl);
    mainPanel.revalidate();
}
Run Code Online (Sandbox Code Playgroud)

这是我的mainPanel的代码:

    mainPanel = new JPanel();
mainPanel.setLayout(new FlowLayout(FlowLayout.LEFT));
add(mainPanel,"Center");
Run Code Online (Sandbox Code Playgroud)

我正在为我的框架使用边框布局:

setLayout(new BorderLayout(0,0));
Run Code Online (Sandbox Code Playgroud)

我的问题是,即使我使用这组代码来设置我的JTable以适应但似乎所有这一切都失败了,这段代码:

 mainTable.setAutoResizeMode(JTa![enter image description here][1]ble.AUTO_RESIZE_OFF);
for(int i=0;i<=column.length-1;i++){
mainTable.getColumnModel().getColumn(i).setPreferredWidth(300);
}
Run Code Online (Sandbox Code Playgroud)

何时使用该代码,我的jtable不会调整大小,只会添加到底部的水平滚动条上.

kle*_*tra 5

没有冒犯意味着但是..你的代码,因此你的问题是一团糟;-)而且你没有解释你想要达到的目的.

试图解开,采用嵌套布局/调整大小的特征(如片段中所示,可能不完整):

frame // BorderLayout
   mainPanel // FlowLayout
       pnlTabel  // FlowLayout, hard-coded prefSize
           pane // scrollPane 
               mainTable // auto-resize-off
Run Code Online (Sandbox Code Playgroud)

旁白:故意保留未命名的名称,以证明混合命名方案如何导致整体混淆:-)无论你决定使用pre或postFixing某些类型相关的标记,但是如果你确实是一致的,那无关紧要.

在该层次结构中,有两个级别的FlowLayout 基本上将它们的子节点布置在它们各自的prefs并相应地调整它们自己的pref,以免 pref在pnlTable的级别上被硬编码:但是表的pref将被更改(通过改变列prefs)它不能进一步冒泡,因为...硬编码pref导致计算它的大小(既不是通过layoutManager也不是uiDelegate,两者都没有机会去做)

另一个问题 - 更有趣的一个:-) - 是JScrollPane有点特别

  • 从视图的pref/scrollablePrefViewportSize计算它自己的prefSize,具体取决于视图是否实现Scrollable(JTable这样做,但是以一种糟糕的方式)
  • 作为validationRoot:使视图(或任何子项)无效不会在层次结构中进一步冒泡

假设如果列的prefWidts发生变化,你希望表的scrollPane增长,那么有两件事需要调整:

  • 实现表的getPreferredScrollableWidth以返回基于列的prefWidth计算的值
  • 重新验证层次结构中更高的容器

一些代码可以使用:

final JTable table = new JTable(50, 10) {
    // properties to base a reasonable prefScrollable size
    int visibleColumns = 3;
    int visibleRows = 10;
    // hard-coded default in super
    Dimension dummySuper = new Dimension(450, 400);
    @Override
    public Dimension getPreferredScrollableViewportSize() {
        Dimension dim =  super.getPreferredScrollableViewportSize();
        if (!dummySuper.equals(dim)) return dim;
        dim = new Dimension();
        for (int column = 0; column < Math.min(visibleColumns, getColumnCount()); column++) {
            dim.width += getColumnModel().getColumn(column).getPreferredWidth();
        }
        dim.height = visibleRows * getRowHeight();
        return dim;
    }

};
table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
for (int i = 0; i < table.getRowCount(); i++) {
    table.setValueAt("row: " + i, i, 0);
}
JComponent tablePanel = new JPanel();
tablePanel.add(new JScrollPane(table));

Action sizeColumns = new AbstractAction("size columns") {
    int prefWidth = 75;
    @Override
    public void actionPerformed(ActionEvent e) {
        int newWidth = prefWidth + 15;
        for (int i = 0; i < table.getColumnCount(); i++) {
            if (table.getColumnModel().getColumn(i).getPreferredWidth() == prefWidth)
                table.getColumnModel().getColumn(i).setPreferredWidth(newWidth);
        }
        prefWidth = newWidth;
        // revalidate "higher up" than the table itself
        frame.revalidate();
    }
};
frame.add(new JButton(sizeColumns), BorderLayout.SOUTH);
Run Code Online (Sandbox Code Playgroud)