状態に応じてテーブルの行を色付けしたいと思います。検索後、私はこれを見つけたFormatting Rows in a JavaFX TableView Using CSS Pseudo Classes。Javafxテーブルビューの変更リストが頻繁に変更されます
私の目的のために実装しようとしました。それも動作しますが、スクロールすると色はデフォルトのものに戻ります。
何が間違っていますか?
@FXML
private void initialize(){
PseudoClass online = PseudoClass.getPseudoClass("online");
PseudoClass offline = PseudoClass.getPseudoClass("offline");
PseudoClass unknown = PseudoClass.getPseudoClass("unknown");
//Set a rowFactory for the table view.
overviewTable.setRowFactory(tableView -> {
TableRow<State> row = new TableRow<>();
ChangeListener<String> changeListener = (obs, oldValue, newValue) -> {
System.out.println("1: " + obs + " : " + oldValue + " : " + newValue);
row.pseudoClassStateChanged(online, newValue.equals("online"));
row.pseudoClassStateChanged(offline, newValue.equals("offline"));
row.pseudoClassStateChanged(unknown, newValue.equals("unknown"));
};
row.itemProperty().addListener((obs, oldValue, newValue) -> {
System.out.println("2: " + obs + " : " + oldValue + " : " + newValue);
if (oldValue != null) {
oldValue.stateProperty().removeListener(changeListener);
}
if (newValue != null) {
newValue.stateProperty().addListener(changeListener);
row.pseudoClassStateChanged(online, newValue.equals("online"));
row.pseudoClassStateChanged(offline, newValue.equals("offline"));
row.pseudoClassStateChanged(unknown, newValue.equals("unknown"));
} else {
row.pseudoClassStateChanged(online, false);
row.pseudoClassStateChanged(offline, false);
row.pseudoClassStateChanged(unknown, false);
}
});
return row;
});
}
CSS:
.table-row-cell:unknown{
-fx-background-color: blue;
}
.table-row-cell:online{
-fx-background-color: #2EAB15;
}
.table-row-cell:offline{
-fx-background-color: #BB0000;
}
.table-row-cell .text{
-fx-fill: white;
}
"スクロールすると色がデフォルトのものに戻ります。"これはどういう意味ですか?擬似クラスは変更されていますか(IE:あなたはsysoを取得していますか?)疑似クラスはまだ同じですが、色はちょうど変化していますか? – Ironcache