- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
好吧,我放弃了 GridPane 支持的表实现,转而使用适当的 TableView。
在表格中,左列是 ImageView,右列是带有标签的 VBox。
下面的代码经过修改,不包含我的数据库中的任何数据。
public ObservableList<Users> showUserData() {
for(int i = 0; i <= 5; i++) {
Image image = new Image("file:///" + [path to whatever image in your PC]);
VBox vbox = new VBox();
vbox.getChildren().addAll(new Label("Name: " + "a name"),
new Label("Username: " + "a username"),
new Label("Position: " + "a position"));
ImageView pic = new ImageView();
pic.setFitHeight(150);
pic.setFitWidth(150);
pic.setImage(image);
pic.setSmooth(true);
pic.setPreserveRatio(true);
users.add(new Users(pic, vbox));
}
return users;
}
然后将其传递到初始化方法,在该方法中进行表的实际填充。
顺便说一句,Users 类看起来像这样:
public class Users {
private ImageView userImage;
private VBox userDetails;
public Users() {
this.userImage = null;
this.userDetails = null;
}
public Users(ImageView userImage, VBox userDetails) {
this.userImage = userImage;
this.userDetails = userDetails;
}
public ImageView getUserImage() {
return userImage;
}
public void setUserImage(ImageView userImage) {
this.userImage = userImage;
}
public VBox getUserDetails() {
return userDetails;
}
public void setUserDetails(VBox userDetails) {
this.userDetails = userDetails;
}
}
程序按预期工作,我可以看到包含图像的表格和包含详细信息的 VBox。
现在我想添加一个用于过滤表格的 TextField,过滤器参数是标签内的文本。
我知道我需要将 ObservableList 放入 FilteredList,然后放入 SortedList。
但是由于过滤器参数放置在 VBox 内而不是单独的列中,因此我在互联网上看到的任何示例都不适用(除非我就是那么愚蠢)。另外,参数位于标签内,而不仅仅是普通字符串。
我一直在遵循本教程进行过滤:http://code.makery.ch/blog/javafx-8-tableview-sorting-filtering/ 。
我认为这几乎是一个特殊情况,但设计要求我坚持它。我需要帮助、提示或任何形式的指导。谢谢。
最佳答案
将数据存储在项目中,而不是显示它们的节点
!您可以使用 cellFactory
创建单元格,以您喜欢的方式显示数据:
public class UserDetails {
private final String name;
private final String username;
private final String position;
public UserDetails(String name, String username, String position) {
this.name = name;
this.username = username;
this.position = position;
}
public String getName() {
return name;
}
public String getUsername() {
return username;
}
public String getPosition() {
return position;
}
}
public class User {
private UserDetails userDetails;
private Image image;
public User(UserDetails userDetails, Image image) {
this.userDetails = userDetails;
this.image = image;
}
public UserDetails getUserDetails() {
return userDetails;
}
public Image getImage() {
return image;
}
}
public ObservableList<User> showUserData() {
ObservableList<User> users = FXCollections.observableArrayList();
for (int i = 0; i <= 5; i++) {
users.add(new User(
new UserDetails("a name", "a username", "a position"),
new Image("https://cdn.sstatic.net/Sites/stackoverflow/company/img/logos/so/so-icon.png")));
}
return users;
}
@Override
public void start(Stage primaryStage) {
TableView<User> table = new TableView<>(showUserData());
TableColumn<User, Image> imageColumn = new TableColumn<>();
TableColumn<User, UserDetails> userDetailsColumn = new TableColumn<>();
table.getColumns().addAll(imageColumn, userDetailsColumn);
imageColumn.setCellValueFactory(new PropertyValueFactory<>("image"));
userDetailsColumn.setCellValueFactory(new PropertyValueFactory<>("userDetails"));
imageColumn.setCellFactory(col -> new TableCell<User, Image>() {
private final ImageView imageView = new ImageView();
{
imageView.setFitHeight(150);
imageView.setFitWidth(150);
imageView.setSmooth(true);
imageView.setPreserveRatio(true);
}
@Override
protected void updateItem(Image item, boolean empty) {
super.updateItem(item, empty);
if (empty) {
imageView.setImage(null);
setGraphic(null);
} else {
imageView.setImage(item);
setGraphic(imageView);
}
}
});
userDetailsColumn.setCellFactory(col -> new TableCell<User, UserDetails>() {
private final Label nameLabel = new Label();
private final Label userNameLabel = new Label();
private final Label positionLabel = new Label();
private final VBox vbox = new VBox(nameLabel, userNameLabel, positionLabel);
@Override
protected void updateItem(UserDetails item, boolean empty) {
super.updateItem(item, empty);
if (empty) {
setGraphic(null);
} else {
nameLabel.setText("Name: "+item.getName());
userNameLabel.setText("Username: "+item.getUsername());
positionLabel.setText("Position: "+item.getPosition());
setGraphic(vbox);
}
}
});
Scene scene = new Scene(table);
primaryStage.setScene(scene);
primaryStage.show();
}
如果创建大量用户,这可以大大减少占用空间,因为它不会为每个项目存储大型Node
类,而是重用与每个单元格关联的类。 .
这应该允许您轻松地根据文本创建谓词:
TextField textField = ...
FilteredList<User> filteredList = ...
textField.textProperty().addListener((observable, oldValue, newValue) -> filteredList.setPredicate(newValue.isEmpty()
? null
: user -> user.getName().contains(newValue)
|| user.getUsername().contains(newValue)
|| user.getPosition().contains(newValue)));
关于java - 使用 VBox JavaFX-8 内的过滤器参数过滤 TableView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42941545/
VBox classBox = new VBox(); className = new Text("defaultClass"); classBox.setAlignment(Pos.CENTER);
VBox classBox = new VBox(); className = new Text("defaultClass"); classBox.setAlignment(Pos.CENTER);
JavaFX GridPane、VBox、HBox 是否有预定义的 CSS 类? 我在 CSS reference 中找不到任何内容,但默认组件没有定义似乎很奇怪。 如果没有预定义的类,有没有比在所有
我正在尝试为我的 JavaFX 项目添加拖放功能。它有点有效,但并不是同时有效 VBox questions = new VBox(); questions.getChildren().add(cre
我已经编写了使用 VBox 作为布局的代码。我希望按钮出现在顶行,然后绘制 2 条水平线,在 400x400 场景中应位于 y=200 和 300 处。但输出显示了我给出的不同坐标处的线条。 我知道这
如何使用 JavaFX 和 VBox 在一行中包含多个元素。假设我需要一个 TextField 和一个 Button。 最佳答案 将它们放入HBox中,并将HBox放入VBox中。 VBox vbox
对于我正在开发的程序,我决定创建自己的“命令提示符”,这意味着通常发送到控制台的错误消息将发送到它进行调试。以前,当唯一的功能是显示文本时,一切都工作正常。然而现在,当我将根设为 VBox 而不是 S
我正在基于 JavaFX 的游戏中创建弹出确认消息,并试图弄清楚布局是如何工作的。我的 PopUp 类扩展了 StackPane,其构造函数如下所示: public PopUp (String str
我正在创建一个视频分析系统。目前,我正在使用 JavaFX 处理播放器本身。在我的播放器旁边,我想要一个在分析过程中放置的标记列表(见图)。 我想要什么: 但它又重叠了... 直到它变成这样: 列
我在 ScrollPane 中有一个 JavaFx VBox: VBox container = new VBox(); container.setAlignment(Pos.CENTER); ...
我使用 VBox 提供 3 个输入字段。 它们都是这样设置的: tf = new TextField(); tf.setPrefWidth(Double.MAX_VALUE); sp = new Sp
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve th
我无法在 Java 代码中将 VBox 中的 Button 居中!我使用 Scene Builder 创建了一个 SplitPane,其中左侧的 AnchorPane 有一个位于 VBox 中心的 B
我有几个 UI 元素,我想垂直堆叠在面板的中心,所有元素都在中心的左边缘对齐。我试着用 VBox 来做这件事,它一直有效,直到我添加了一个文本太长的项目;它总是用省略号截断文本,我无法让它将文本换行到
我正在做一个涉及复选框数组的项目。但是当我在 VBox 中添加所有复选框时遇到问题。下面是我的屏幕截图 无法查看其他复选框。 这是我的复选框代码 public void initializeSenat
我有一个包含两行的 vbox 布局。第一行有一个菜单栏,第二行有一个 TabPane 布局。 Vbox 布局的第二行可见,第一行不出现。我提供了 fxml 以及渲染窗口的屏幕截图。我认为菜单栏应该位于
我正在尝试构建一个 javafx 修剪器,我已经做到了,但是当我在 ImageViews 上添加 setOnMouseClicked 时,我制作的修剪器隐藏了这些节点,因此未处理该操作。 我已经设置了
问题:我对 vbox 和 gridpane 之间有一个困惑。通常当你可以使用 vbox 时,你也可以使用 1 列和 n 行的 gridPane,所以我不确定何时使用它们和区别。 事实: 我知道网格 P
我在向 fxml 文件静态添加标签时遇到一些问题。这是我尝试过的,但它不起作用,placeholder 以红色突出显示。我基本上想要一个 ListView 的标题/标题。
我试图将 Hbox 放置在 Vbox 中,这意味着每个 Hbox 应该是一行,但我得到了这个结果 标签的名字及其对应的文本框应为一行,姓氏应为另一行。 我该怎么做才能使每个水平盒成为垂直盒中的单独行。
我是一名优秀的程序员,十分优秀!