- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的应用程序有一个 TableView
,其中填充了对图像文件的引用列表。
数据从数据库加载,仅提供有关如何定位图像文件本身的信息(因此它指示图像的子文件夹和文件名)。
在我的 TableView
中,如果物理文件不存在,我想将“文件名”列的文本设置为红色。我已经实现了 CellFactory,有时它“有点”有效。 updateItem()
方法被重写以检查相关文件是否存在,但它并不总是正确的:某些行将使用红色文本样式,其他行则不会,即使它们指向相同的文件。
此外,滚动列表时,值可能会偶尔发生变化。
很难描述,所以我在下面创建了一个 MCVE。
Main.java
import javafx.application.Application;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.geometry.Insets;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.control.TableCell;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
import java.io.File;
public class Main extends Application {
private ObservableList<DataItem> dataItems;
public static void main(String[] args) {
launch(args);
}
@Override
public void start(Stage primaryStage) {
initData();
// Main interface
VBox root = new VBox(10);
root.setAlignment(Pos.CENTER);
root.setPadding(new Insets(10));
// Setup the TableView
TableView<DataItem> tableView = new TableView<>();
TableColumn<DataItem, ImageCategory> colCategory = new TableColumn<>("Category");
TableColumn<DataItem, String> colFilename = new TableColumn<>("Filename");
// Initialize the column data
colCategory.setCellValueFactory(cellData -> cellData.getValue().categoryProperty());
colFilename.setCellValueFactory(cellData -> cellData.getValue().filenameProperty());
tableView.getColumns().add(colCategory);
tableView.getColumns().add(colFilename);
// Style text based on file exists
colFilename.setCellFactory(filenameCell -> new TableCell<DataItem, String>() {
@Override
protected void updateItem(String item, boolean empty) {
super.updateItem(item, empty);
if (item == null || empty) {
setText(null);
setStyle("");
} else {
// Check if file exists
DataItem thisItem = getTableView().getItems().get(getIndex());
File imageFile = new File("C:\\Users\\XXX\\Desktop\\"
+ thisItem.getCategory().getCategoryName() + "\\"
+ item);
if (!imageFile.exists()) {
setStyle("-fx-text-fill: red");
}
setText(item);
}
}
});
tableView.setItems(dataItems);
root.getChildren().add(tableView);
primaryStage.setScene(new Scene(root));
primaryStage.setWidth(300);
primaryStage.setHeight(200);
primaryStage.show();
}
private void initData() {
dataItems = FXCollections.observableArrayList();
for (int i = 0; i < 15; i++) {
dataItems.add(new DataItem(
new ImageCategory(1, "Application Icon"),
"icon.png"));
}
for (int i = 0; i < 15; i++) {
dataItems.add(new DataItem(
new ImageCategory(1, "Logo"),
"logo.png"));
}
}
}
DataItem.java
import javafx.beans.property.SimpleObjectProperty;
import javafx.beans.property.SimpleStringProperty;
class DataItem {
private SimpleObjectProperty<ImageCategory> category = new SimpleObjectProperty<>();
private SimpleStringProperty filename = new SimpleStringProperty();
public DataItem(ImageCategory category, String filename) {
this.category.set(category);
this.filename.set(filename);
}
public ImageCategory getCategory() {
return category.get();
}
public SimpleObjectProperty<ImageCategory> categoryProperty() {
return category;
}
public String getFilename() {
return filename.get();
}
public SimpleStringProperty filenameProperty() {
return filename;
}
}
ImageCategory.java
import javafx.beans.property.SimpleIntegerProperty;
import javafx.beans.property.SimpleStringProperty;
class ImageCategory {
private SimpleIntegerProperty categoryId = new SimpleIntegerProperty();
private SimpleStringProperty categoryName = new SimpleStringProperty();
public ImageCategory(int categoryId, String categoryName) {
this.categoryId.set(categoryId);
this.categoryName.set(categoryName);
}
public int getCategoryId() {
return categoryId.get();
}
public SimpleIntegerProperty categoryIdProperty() {
return categoryId;
}
public String getCategoryName() {
return categoryName.get();
}
public SimpleStringProperty categoryNameProperty() {
return categoryName;
}
@Override
public String toString() {
return getCategoryName();
}
}
显然,您需要一个示例文件来测试这一点。这是运行结果的屏幕截图。请注意,Logo/logo.png
确实存在:
您会看到第一个“logo.png”的样式正确,为纯文本,但后续条目似乎表明该文件不存在。调整窗口大小或滚动列表有时也会导致样式文本从一行更改为另一行;这是相当随机的。
如何准确测试该行代表的文件是否确实存在?
附带问题:在我的生产应用程序中,滚动非常慢且延迟,因为通过网络共享驱动器检查文件是否存在很慢。有没有办法在这些项目第一次加载时设置样式,而不是每次渲染单元格时设置样式?
最佳答案
关于单元格样式不当:
如果该项目更改为现有项目,则无需更改样式。这意味着,如果您从不存在的文件更改为现有文件,您的单元格文本将保持红色。您需要妥善处理此案:
@Override
protected void updateItem(String item, boolean empty) {
super.updateItem(item, empty);
if (item == null || empty) {
setText(null);
setStyle("");
} else {
// Check if file exists
DataItem thisItem = getTableView().getItems().get(getIndex());
File imageFile = new File("C:\\Users\\XXX\\Desktop\\"
+ thisItem.getCategory().getCategoryName() + "\\"
+ item);
if (!imageFile.exists()) {
setStyle("-fx-text-fill: red");
} else {
// modification here ----------------------------------------------
setStyle("");
}
setText(item);
}
}
至于滚动问题:
updateItem
在 JavaFX 应用程序线程上运行。在此线程上执行长时间运行的操作(例如与远程目录通信)会使 UI 无响应。通过将信息存储在项目类本身中或添加一些包含数据的结构,例如,您可以轻松避免多次检查。一张 map
。
与远程目录的通信仍应在单独的线程上完成。您可以对安排在某个任务上的Task
进行文件状态(EXISTENT
、NON_EXISTENT
/UNKNOWN
)的分配。 ExecutorService
...
关于java - 如何根据行项的属性设置 TableCell 的样式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51011382/
这个问题已经有答案了: Is there any way to accept only numeric values in a JTextField? (20 个回答) It's possible i
我使用戴尔 XPS M1710。笔记本电脑的盖子、侧面扬声器和前置扬声器都有灯(3 组灯可以单独调节)和鼠标垫下方的灯。在 BIOS 中,我可以更改这些灯的颜色,至少是每个组。另外,我可以在鼠标垫下打
我知道我可以使用 在 iOS 5 中打开设置应用 [[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"prefs://"
我有一个 Django 应用程序,我正在尝试为其设置文档。目录结构如下: - doc - project | - manage.py 我已经设置了路径以便 Sphinx 可以看到东西,但是当我尝试使用
我正在使用 768mb ram 运行 centos 5.5。我一直在日志中获取 server reached MaxClients setting, consider raising the MaxC
我在具有以下配置的服务器内运行了 Drupal 安装: StartServers 5 MinSpareServers 5 MaxSpareServers 15 MaxClien
是否可以使用 Microsoft.Web.Administration 包为给定的 location 配置 asp 设置? 我想以编程方式将以下部分添加到本地 IIS applicationHost.
我一直在阅读为 kube-proxy 提供参数的文档,但没有解释应该如何使用这些参数。我使用 az aks create 创建我的集群使用 azure-cli 程序,然后我获得凭据并使用 kubect
我想知道与在 PHP 中使用 setcookie() 函数相比,在客户端通过 JavaScript 设置一些 cookie 是否有任何明显的优势?我能想到的唯一原因是减少一些网络流量(第一次)。但不是
我有一个按钮可以将 body class 设置为 .blackout 我正在使用 js-cookie设置cookie,下面的代码与我的按钮相关联。 $('#boToggle').on('click'
我有一堆自定义的 HTML div。我将其中的 3 存储在具有 slide 类的 div 中。然后,我使用该幻灯片类调用 slick 函数并应用如下设置: $('.slide').slick({
我正在创建一个应该在 Windows 8(桌面)上运行的应用 我需要: 允许用户使用我的应用启动“文件历史记录”。我需要找到打开“文件历史记录”的命令行。 我需要能够显示“文件历史记录”的当前设置。
我刚买了一台新的 MacBook Pro,并尝试在系统中设置 RVM。我安装了 RVM 并将默认设置为 ➜ rvm list default Default Ruby (for new shells)
由于有关 Firestore 中时间戳行为即将发生变化的警告,我正在尝试更改我的应用的初始化代码。 The behavior for Date objects stored in Firestore
在 ICS 中,网络 -> 数据使用设置屏幕中现在有“限制后台数据”设置。 有没有办法以编程方式为我的应用程序设置“限制后台数据”? 或 有没有办法为我的应用程序调出具有选项的“数据使用”设置? 最佳
我正在尝试使用 NextJS 应用程序设置 Jest,目前在 jest.config.js : module.exports = { testPathIgnorePatterns: ["/.n
我最近升级到 FlashDevelop 4,这当然已经将我之前的所有设置恢复到原来的状态。 我遇到的问题是我无法在新设置窗口的哪个位置找到关闭它在方括号、大括号等之前插入的自动空格的选项。 即它会自动
有没有办法以编程方式访问 iPhone/iPod touch 设置? 谢谢。比兰奇 最佳答案 大多数用户设置可以通过读取存储在 /User/Library/Preferences/ 中的属性列表来访问
删除某些值时,我需要选择哪些设置来维护有序队列。我创建了带有自动增量和主键的 id 的表。当我第一次插入值时,没问题。就像 1,2,3,4,5... 当删除某些值时,顺序会发生变化,例如 1,5,3.
我正在尝试设置示例 Symfony2 项目,如此处所示 http://symfony.com/doc/current/quick_tour/the_big_picture.html 在访问 confi
我是一名优秀的程序员,十分优秀!