我的Java程序产生了很多数据,我用它构建了单个的ResultObject。因为只有某些结果对象会引起兴趣,所以我填充了一个可观察的HashMap
虽然映射和处理这些结果按预期工作,但我很难用该ObservableHashMap填充TableView
我的CustomObject(如果两个CustomObject具有相同的属性,只需检查JSONObject):
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();
}
通过使用以下代码,我检查是否有一个已存在相应数据点的键,然后将其添加到其观察列表(值)中:
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());
}
最后,我希望一些TableClons显示CustomObject的属性。稍后,我希望在单独的TableView中显示所选CustomObject的单个映射的可观察列表。
我对Java和JavaFX很陌生,我希望尽可能专业地描述我的问题。如果我错过了什么,请告诉我。
使用一个映射创建表视图的另一种方法
主要的Java语言
package tester;
import java.util.HashMap;
import java.util.Map;
import javafx.application.Application;
import javafx.scene.Scene;
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)
{
MapTable mapTable = new MapTable(getDatabaseRecord());
TableView table = mapTable.getTableView();
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 Map<String, String> getDatabaseRecord()
{
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");
return record1;
}
}
可映射。Java语言
package tester;
import java.util.Map;
import javafx.beans.property.SimpleStringProperty;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.scene.control.SelectionMode;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
public class MapTable
{
private final TableView<Map.Entry<String, String>> table;
private final ObservableList<Map.Entry<String, String>> data;
public MapTable(Map map)
{
this.table = new TableView<>();
this.data = FXCollections.observableArrayList(map.entrySet());
setUpTable();
}
private void setUpTable()
{
this.table.setEditable(false);
this.table.setItems(this.data);
this.table.getSelectionModel().setSelectionMode(SelectionMode.MULTIPLE);
// use fully detailed type for Map.Entry<String, String>
TableColumn<Map.Entry<String, String>, String> column1 = new TableColumn<Map.Entry<String, String>, String>();
column1.setMinWidth(125);
column1.setSortable(false);
column1.setCellValueFactory((TableColumn.CellDataFeatures<Map.Entry<String, String>, String> p) -> new SimpleStringProperty(p.getValue().getKey()));
TableColumn<Map.Entry<String, String>, String> column2 = new TableColumn<Map.Entry<String, String>, String>();
column2.setMinWidth(350);
column2.setSortable(false);
column2.setCellValueFactory((TableColumn.CellDataFeatures<Map.Entry<String, String>, String> p) -> new SimpleStringProperty(p.getValue().getValue()));
this.table.getColumns().setAll(column1, column2);
}
public TableView getTableView()
{
return this.table;
}
}
这应该适用于<代码>列表
主要的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;
}
}
行项目。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);
}
}
我在互联网上找不到正确的答案,如何用ObservableMap作为MapProperty填充tableviw。我想在按值排序的tableview中显示文章。
我有一个简单的JavaFX类,对于这个问题,它的结构是这样的。 BorderPane包含包含FlowPane的StackPane。 几天来,我一直试图让StackPane填充其父级BorderPane,但似乎没有任何效果。最终结果应该是StackPane的背景设置为“红色”。 代码: 我的应用程序正在运行的照片 所以基本上这个左侧区域应该完全填充我的BorderPane的左侧,因此背景应该正确覆盖
问题内容: 我想填充与 我只有两列。我做不到 到目前为止,我尝试过的是: 桌上什么也没显示。但是当我进行打印时,我看到的是我添加的数据。但是在桌子上什么也没显示。 我创建列如下: 我在Internet上看到了一些示例,这些示例中创建了一个对象来填充对象,但我不想仅为表视图创建类。还有其他可行的方法吗? 编辑: 我只想拥有这样的东西: 问题答案: 首先,您必须在FXML文件或代码中创建table’c
我想在中显示以下可观察地图: 其中定义如下: 我希望TableView的第一列是Map键(称之为),第二列是,第三列是myShapes。拿到钥匙。getnumSides()。我希望地图更改时TableView会自动更新。 如果可能的话,让用户可以编辑TableView的第二列和第三列,并在Map中更新这些编辑,这也是非常好的。 我已经问过stackoverflow,如何用ObservableMap
因此,我试图在我的JavaFX应用程序中创建一个自定义节点,它从扩展而来,因此可以自己进行渲染。我一开始只是试着画一个文本“Hello world”在画布上,但可惜它没有出现,即使我可以通过鼠标事件处理程序确认应用程序中是否存在自定义节点。 简而言之,如果我将这个的一个新实例添加到一个
我无法用地图填充TableView 我有一个类,它拥有一个以产品名称为键、以正常价格为值的地图。我创建了一个tableView,其中一列是名称,一个主列是价格,分为两列normal和new,如下所示。 我已经做了这个方法使地图成为一个可观察列表。 这就是我卡住的地方。我不知道如何用这个可观察列表填充每个单元格。我确实知道我必须以某种方式使用“setCellFactory”。有人有什么建议吗?如何制