java - 如何在 JavaFX 中使用 ObservableMap<KeyObject, ObservableList<CustomObject>> 填充 TableView

标签 java javafx hashmap tableview tablecolumn

我的 Java 程序生成大量数据,我用这些数据构造单独的 ResultObject。因为只有某些 ResultsObjects 会令人感兴趣,所以我用我的结果填充 ObservableHashMap<>。 CustomObject 由少量 int + double 和一个 JSONObject 组成。通过这个 CustomObject,我想将类似的 ResultObjects(具有某些共同属性)映射到该 CustomObject。

虽然映射和处理这些结果按预期工作,但我几乎无法用 ObservableHashMap<> 填充 TableView。

我的 CustomObject(JSONObject 只是为了检查两个 CustomObject 是否具有相同的属性):

public CustomObject(Simulation data) {

    this.datapoint1 = data.datapoint1;
    this.datapoint2 = data.datapoint2;

    this.jsonCompareObject = new JSONObject()
            .put("datapoint1", data.datapoint1)
            .put("datapoint1", data.datapoint2);
}

我的 ObservableHashMap 对象:

private ObservableMap <CustomObject, ObservableList<Simulation>> topResultsList;

public SomeObjectWithObservableMap(){
    this.topResultsList = FXCollections.observableHashMap();
}

通过使用以下代码,我检查是否存在具有相应数据点的键,然后将其添加到其 ObservableList(值):

private boolean isKeyPresent(CustomObject newCustomObject, Simulation data) {
    for (CustomObject oldCustomObject : this.topResultsList.keySet()) {
        if (oldCustomObject.jsonCompareObject.toString().equals(newCustomObject.jsonCompareObject.toString())) {
            this.topResultsList.get(oldCustomObject).add(data);
            return true;
        }
    }
    return false;
}

我像这样填充其他一些 TableView:

{
    tableColumn.setCellValueFactory(new PropertyValueFactory<>("datapoint1"));
    tableColumn.setCellFactory(TextFieldTableCell.<SomeObject, Double>forTableColumn(twoDigits));
    tableView.setItems(someObject.getObservableList());
}

最后,我希望一些 TableColumns 显示 CustomObject 的属性。稍后,我希望所选 CustomObject 的各个映射 ObservableLists 显示在单独的 TableView 中。

我对 Java 和 JavaFX 还很陌生,我希望尽可能专业地描述我的问题。如果我错过了什么,请告诉我。

最佳答案

这应该适用于 List<Map<String,String>>

enter image description here

Main.java

package tester;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javafx.application.Application;
import javafx.collections.FXCollections;
import javafx.scene.Scene;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
import javafx.scene.layout.HBox;
import javafx.stage.Stage;

public class Tester extends Application
{

    @Override
    public void start(Stage primaryStage)
    {

        TableView<LineItem> table = new TableView<>();
        List<Map<String, String>> databaseObject = getDatabaseObject();

        for (String key : databaseObject.get(0).keySet())
        {
            TableColumn<LineItem, String> col = new TableColumn<>(key);
            col.setCellValueFactory((TableColumn.CellDataFeatures<LineItem, String> cellData) -> cellData.getValue().fieldProperty(key));            
            table.getColumns().add(col);

        }
        List<LineItem> data = new ArrayList<>();
        LineItem sequence1 = new LineItem(databaseObject.get(0));
        LineItem sequence2 = new LineItem(databaseObject.get(1));
        data.add(sequence1);
        data.add(sequence2);

        table.setItems(FXCollections.observableArrayList(data));

        table.setPrefWidth(500);

        HBox root = new HBox();
        root.getChildren().addAll(table);

        Scene scene = new Scene(root, 500, 500);

        primaryStage.setTitle("Hello World!");
        primaryStage.setScene(scene);
        primaryStage.show();
    }

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args)
    {
        launch(args);
    }

    private List<Map<String, String>> getDatabaseObject()
    {
        List<Map<String, String>> values = new ArrayList<>();

        Map<String, String> record1 = new HashMap<>();
        record1.put("firstName", "Joe");
        record1.put("lastName", "Blob");
        record1.put("address", "95 circle ave");
        record1.put("city", "Toronto");
        record1.put("postalCode", "L9Y4Z4");
        values.add(record1);

        Map<String, String> record2 = new HashMap<>();
        record2.put("firstName", "Sarah");
        record2.put("lastName", "Blob");
        record2.put("address", "92 main st");
        record2.put("city", "London");
        record2.put("postalCode", "T9Y4K4");
        values.add(record2);

        return values;
    }

}

LineItem.java

package tester;

import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import javafx.beans.property.SimpleStringProperty;
import javafx.beans.property.StringProperty;

public class LineItem
{

    private final Map<String, StringProperty> fields;

    public LineItem(Map<String, String> record)
    {
        this.fields = new HashMap<>();
        for (String key : record.keySet())
        {
            this.fields.put(key, new SimpleStringProperty());
        }
        for (Entry<String, String> entry : ((Set<Entry<String, String>>) record.entrySet()))
        {

            this.fields.get(entry.getKey()).set(entry.getValue());
        }
    }

    public final StringProperty fieldProperty(String key)
    {
        return this.fields.get(key);
    }

}

关于java - 如何在 JavaFX 中使用 ObservableMap<KeyObject, ObservableList<CustomObject>> 填充 TableView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55795528/

相关文章:

java - 如何声明该方法正在返回 Collections.unmodifiableMap

java - 使用 HashMap 时 Java 11 中的 ClassCastException 而不是 Java 8 中的?

java - 如何将命令模式与 JavaFX GUI 结合起来?

java - 运行weblogic 10.3.6配置向导时出错: JVM Launcher is showing 'could not create the java virtual machine' error

css - 删除选择框中的默认标记

java - 如何将数据添加到 JavaFX 表行/单元格

hashmap - 为什么使用HashMap的or_insert时会调用闭包?

java - 自定义 ViewPager 以允许子 GoogleMap 控件水平滚动

java - 如何使用sql事务?

Java 9 JavaFX 预加载器