I have a JavaFX 2 table that is displaying contact details for people, lets imagine there are three columns: first name, last name and email address. When my application starts it populates the table with several rows of data about the people already in the system.
The problem is that the column widths are all the same. Most of the time the first and last name is displayed in full but the email address is getting clipped. The user can double click the divider in the header to resize the column but that will become tedious quickly.
Once the table has been pre-populated I would like to programatically resize all the columns to display the data they contain but I can't figure out how to achieve this. I can see that I can call col.setPrefWidth(x)
but that doesn't really help as I would have to guess the width.
Also, a very simple trick based on an
AnchorPane
will be a good solution.We gonna wrap the
TableView
into aAnchorPane
but also we gonna anchor the left and right side of theTableView
like this:This simple code will stretch the
TableView
in both directions (right and left) also, it will adjust whenever the scrollbar is added.You can get an idea of how this works watching this animated gif.
Now you can resize the columns, adding these lines:
After 3 years, finally I found the solution, javafx column in tableview auto fit size