JavaFX ListView for custom object |
Here we define a custom class, MyObject. And a List of object of MyObject class, myList. We have to generate ObservableList<myobject> from ArrayList<myobject> by calling FXCollections.observableList(myList). Also have to sets a new cell factory to use in the ListView, by calling setCellFactory() method.
Here is the example code:
package javafx_listview;
import java.util.ArrayList;
import java.util.List;
import javafx.application.Application;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.scene.Scene;
import javafx.scene.control.ListCell;
import javafx.scene.control.ListView;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;
import javafx.util.Callback;
/**
* @web http://java-buddy.blogspot.com/
*/
public class JavaFX_ListView extends Application {
class MyObject{
String day;
int number;
MyObject(String d, int n){
day = d;
number = n;
}
String getDay(){
return day;
}
int getNumber(){
return number;
}
}
List<MyObject> myList;
//Create dummy list of MyObject
private void prepareMyList(){
myList = new ArrayList<>();
myList.add(new MyObject("Sunday", 50));
myList.add(new MyObject("Monday", 60));
myList.add(new MyObject("Tuesday", 20));
myList.add(new MyObject("Wednesday", 90));
myList.add(new MyObject("Thursday", 30));
myList.add(new MyObject("Friday", 62));
myList.add(new MyObject("Saturday", 65));
}
@Override
public void start(Stage primaryStage) {
primaryStage.setTitle("http://java-buddy.blogspot.com/");
prepareMyList();
ListView<MyObject> listView = new ListView<>();
ObservableList<MyObject> myObservableList = FXCollections.observableList(myList);
listView.setItems(myObservableList);
listView.setCellFactory(new Callback<ListView<MyObject>, ListCell<MyObject>>(){
@Override
public ListCell<MyObject> call(ListView<MyObject> p) {
ListCell<MyObject> cell = new ListCell<MyObject>(){
@Override
protected void updateItem(MyObject t, boolean bln) {
super.updateItem(t, bln);
if (t != null) {
setText(t.getDay() + ":" + t.getNumber());
}
}
};
return cell;
}
});
StackPane root = new StackPane();
root.getChildren().add(listView);
primaryStage.setScene(new Scene(root, 300, 250));
primaryStage.show();
}
public static void main(String[] args) {
launch(args);
}
}
Next:
- Sort List of custom object
- Customized ListView
Related: Implement ListView using JavaFX