當在 Java Swing 中更改列寬時,如何僅對 JTable 的下一列應用調整?


要僅對下一列應用調整,請使用 setAutoResizeMode 並設定模式。此處的模式將是 AUTO_RESIZE_NEXT_COLUMN。即使拖動任何列頭進行調整大小,這也會允許你僅調整下一列。

我們先來看一個建立表的示例 -

示例

package my;
import java.awt.Font;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;
public class SwingDemo {
   public static void main(String[] argv) throws Exception {
      DefaultTableModel tableModel = new DefaultTableModel();
      JTable table = new JTable(tableModel);
      tableModel.addColumn("Technology");
      tableModel.addColumn("BCA");
      tableModel.addColumn("MCA");
      tableModel.addColumn("Lectures");
      // applying adjustments to the next column only
      table.setAutoResizeMode(JTable.AUTO_RESIZE_NEXT_COLUMN);
      tableModel.addRow(new Object[] { "F#", "Yes", "No", "20"});
      tableModel.addRow(new Object[] { "Blockchain", "Yes", "No", "30"});
      tableModel.addRow(new Object[] { "SharePoint", "Yes", "Yes", "25"});
      tableModel.addRow(new Object[] { "AWS", "No", "Yes", "25"});
      tableModel.addRow(new Object[] { "Python", "Yes", "No", "20"});
      tableModel.addRow(new Object[] { "Scala", "Yes", "No", "30"});
      tableModel.addRow(new Object[] { "Swift", "No", "Yes", "35"});
      tableModel.addRow(new Object[] { "C#", "Yes", "Yes", "50"});
      tableModel.addRow(new Object[] { "NodeJS", "No", "Yes", "40"});
      tableModel.addRow(new Object[] { "MVC", "Yes", "No", "30"});
      tableModel.addRow(new Object[] { "ASP.NET", "Yes", "Yes", "35"});
      tableModel.addRow(new Object[] { "Java", "Yes", "No", "55"});
      tableModel.addRow(new Object[] { "jQuery", "Yes", "Yes", "30"});
      Font font = new Font("Verdana", Font.PLAIN, 12);
      table.setFont(font);
      JFrame frame = new JFrame();
      frame.setSize(600, 400);
      frame.add(new JScrollPane(table));
      frame.setVisible(true);
   }
}

輸出

現在,如果你要調整任何一列的大小(在這種情況下為 BCA),那麼所有調整都將影響該列本身以及下一列(在這種情況下為 MCA) -

更新於: 2019-07-30

144 次瀏覽

開啟你的 職業生涯

完成課程並獲得認證

開始吧
廣告
© . All rights reserved.