Class TreeItemPropertyValueFactory<S,T>
- Type Parameters:
S
- the TableView typeT
- the TreeTableColumn type
- All Implemented Interfaces:
Callback<TreeTableColumn.CellDataFeatures<S,
T>, ObservableValue<T>>
TreeTableColumn
cell value factory
. An example
of how to use this class is:
TreeTableColumn<Person,String> firstNameCol = new TreeTableColumn<Person,String>("First Name");
firstNameCol.setCellValueFactory(new TreeItemPropertyValueFactory<Person,String>("firstName"));
In this example, Person
is the class type of the TreeItem
instances used in the TreeTableView
.
The class Person
must be declared public.
TreeItemPropertyValueFactory
uses the constructor argument,
"firstName"
, to assume that Person
has a public method
firstNameProperty
with no formal parameters and a return type of
ObservableValue<String>
.
If such a method exists, then it is invoked, and additionally assumed
to return an instance of Property<String>
. The return value is used
to populate the TreeTableCell
. In addition, the TreeTableView
adds an observer to the return value, such that any changes fired will be
observed by the TreeTableView
, resulting in the cell immediately
updating.
If no such method exists, then TreeItemPropertyValueFactory
assumes that Person
has a public method getFirstName
or
isFirstName
with no formal parameters and a return type of
String
. If such a method exists, then it is invoked, and its return
value is wrapped in a ReadOnlyObjectWrapper
and returned to the TreeTableCell
. In this situation,
the TreeTableCell
will not be able to observe changes to the property,
unlike in the first approach above.
For reference (and as noted in the TreeTableColumn
cell value factory
documentation), the
long form of the code above would be the following:
TreeTableColumn<Person,String> firstNameCol = new TreeTableColumn<Person,String>("First Name");
firstNameCol.setCellValueFactory(new Callback<CellDataFeatures<Person, String>, ObservableValue<String>>() {
public ObservableValue<String> call(CellDataFeatures<Person, String> p) {
// p.getValue() returns the TreeItem<Person> instance for a particular
// TreeTableView row, and the second getValue() call returns the
// Person instance contained within the TreeItem.
return p.getValue().getValue().firstNameProperty();
}
});
}
Deploying an Application as a Module
If the referenced class is in a named module, then it must be reflectively
accessible to the javafx.base
module.
A class is reflectively accessible if the module
opens
the containing package to at
least the javafx.base
module.
Otherwise the call(TreeTableColumn.CellDataFeatures)
method
will log a warning and return null
.
For example, if the Person
class is in the com.foo
package
in the foo.app
module, the module-info.java
might
look like this:
module foo.app {
opens com.foo to javafx.base;
}
Alternatively, a class is reflectively accessible if the module
exports
the containing package
unconditionally.
- Since:
- JavaFX 8.0
- See Also:
-
Constructor Summary
ConstructorDescriptionTreeItemPropertyValueFactory
(String property) Creates a default PropertyValueFactory to extract the value from a given TableView row item reflectively, using the given property name. -
Method Summary
Modifier and TypeMethodDescriptioncall
(TreeTableColumn.CellDataFeatures<S, T> param) Thecall
method is called when required, and is given a single argument of type P, with a requirement that an object of type R is returned.final String
Returns the property name provided in the constructor.
-
Constructor Details
-
TreeItemPropertyValueFactory
Creates a default PropertyValueFactory to extract the value from a given TableView row item reflectively, using the given property name.- Parameters:
property
- The name of the property with which to attempt to reflectively extract a corresponding value for in a given object.
-
-
Method Details
-
call
Thecall
method is called when required, and is given a single argument of type P, with a requirement that an object of type R is returned. -
getProperty
Returns the property name provided in the constructor.- Returns:
- the property name provided in the constructor
-