2012-04-14 38 views
38

我有一个JavaFX 2表格显示人员的联系信息,可以想象有三列:名字,姓氏和电子邮件地址。当我的应用程序启动时,它会在表中填入几行关于系统中已有人员的数据。JavaFX 2自动列宽

问题是,列的宽度都是一样的。大多数情况下,姓和名都显示完整,但电子邮件地址已被剪辑。用户可以双击标题中的分隔符来调整列的大小,但这会很快变得乏味。

一旦表已被预先填充,我想以编程方式调整所有列的大小以显示它们包含的数据,但我无法弄清楚如何实现这一点。我可以看到,我可以拨打col.setPrefWidth(x)但这并没有什么帮助,因为我不得不猜测宽度。

回答

56

如果您的总列数是预先知道的。您可以在tableview中的宽度之间分配列宽:

nameCol.prefWidthProperty().bind(personTable.widthProperty().divide(4)); // w * 1/4 
surnameCol.prefWidthProperty().bind(personTable.widthProperty().divide(2)); // w * 1/2 
emailCol.prefWidthProperty().bind(personTable.widthProperty().divide(4)); // w * 1/4 

在这段代码中,列的宽度比例保持同步时的tableview被调整,所以你不需要做手工。另外surnameCol占用桌面视图宽度的一半空间。

42

除了Uluk答案,使用widthProperty().multiply(x)而不是widthProperty().divide(x)看起来更加方便和准确。

nameCol.prefWidthProperty().bind(personTable.widthProperty().multiply(0.25)); 
surnameCol.prefWidthProperty().bind(personTable.widthProperty().multiply(0.50)); 
emailCol.prefWidthProperty().bind(personTable.widthProperty().multiply(0.25)); 
+15

可能更具可读性,但没有更准确的:它做的完全一样的东西... – assylias 2013-10-07 11:43:58

9

这对我的作品在JavaFX的8

table.setColumnResizePolicy(TableView.CONSTRAINED_RESIZE_POLICY); 
col1.setMaxWidth(1f * Integer.MAX_VALUE * 50); // 50% width 
col2.setMaxWidth(1f * Integer.MAX_VALUE * 30); // 30% width 
col3.setMaxWidth(1f * Integer.MAX_VALUE * 20); // 20% width 

在你有问题的其他例子,垂直滚动条的宽度被忽略。

+0

你在哪里看到你可以将百分数传递给setMaxWidth? – 2016-02-18 13:34:51

+0

聪明的技巧 - 足够大的数字,以便按比例调整大小以适应实际大小。 – Suma 2016-03-30 22:55:33

2

,因为我用SceneBuider,我只是定义了MinWidth和MaxWidth一些列和主塔我只定义其中prefWidth为“USE_COMPUTED_SIZE”

+1

这个编程版本只是'col.setPrefWidth(Control.USE_COMPUTED_SIZE);' – 2016-03-24 08:37:02

0

你也可以做到这一点通过编辑,如果你的FXML文件有一个。

<TableColumn fx:id="blackout_number_column" prefWidth="30.0" text="%number"> 

参数prefWidth允许您修改列的默认值。

3

3年后,终于被我找到了解决办法,javafx column in tableview auto fit size

import com.sun.javafx.scene.control.skin.TableViewSkin; 
import javafx.scene.control.Skin; 
import javafx.scene.control.TableColumn; 
import javafx.scene.control.TableView; 
import java.lang.reflect.InvocationTargetException; 
import java.lang.reflect.Method; 

public class GUIUtils { 
    private static Method columnToFitMethod; 

    static { 
     try { 
      columnToFitMethod = TableViewSkin.class.getDeclaredMethod("resizeColumnToFitContent", TableColumn.class, int.class); 
      columnToFitMethod.setAccessible(true); 
     } catch (NoSuchMethodException e) { 
      e.printStackTrace(); 
     } 
    } 

    public static void autoFitTable(TableView tableView) { 
     tableView.getItems().addListener(new ListChangeListener<Object>() { 
      @Override 
      public void onChanged(Change<?> c) { 
       for (Object column : tableView.getColumns()) { 
        try { 
         columnToFitMethod.invoke(tableView.getSkin(), column, -1); 
        } catch (IllegalAccessException | InvocationTargetException e) { 
         e.printStackTrace(); 
        } 
       } 
      } 
     }); 
    } 
} 
+0

我无法找到或导入类TableViewSkin。我正在使用Java 8,这个类似乎不存在。 – Spen 2018-01-07 17:36:49

1

如果你有4列,只扩大到填满表格的宽度的其余部分,其它列所需的最后一栏仍是大小我在Scene Builder中设置。

double width = col1.widthProperty().get(); 
width += col2.widthProperty().get(); 
width += col3.widthProperty().get(); 

col4.prefWidthProperty().bind(table.widthProperty().subtract(width)); 

或者如果您有2列需要扩展然后。

double width = col1.widthProperty().get(); 
width += col3.widthProperty().get(); 

col2.prefWidthProperty().bind(table.widthProperty().subtract(width).divide(2)); 
col4.prefWidthProperty().bind(table.widthProperty().subtract(width).divide(2)); 
0

要generelize宽度和使用任意数量,并确保宽度是表格的宽度为100%,则可以使用:

double[] widths = {20, 30, 50, 20, 30, 70, 50};//define the width of the columns 

//calculate the sum of the width 
double sum = 0; 
for (double i : widths) { 
    sum += i; 
} 

//set the width to the columns 
for (int i = 0; i < widths.length; i++) { 
    table.getColumns().get(i).prefWidthProperty().bind(
      table.widthProperty().multiply(sizes[i]/sum)); 
    //---------The exact width-------------^-------------^ 
}