- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 JavaFX TableColumn
中,右侧有一个排序箭头。
如何设置此箭头的对齐方式?
我问是因为我正在尝试申请 Material Design到 JavaFX 并且箭头需要在左边——否则箭头看起来属于相邻的列。
我知道您可以像这样访问 TableColumnHeader
:
for (final Node headerNode : tableView.lookupAll(".column-header")) {
TableColumnHeader tableColumnHeader = (TableColumnHeader) headerNode;
我知道 TableColumnHeader
有一个 Label 标签
和一个 GridPane sortArrowGrid
作为它的 child 。
如何将 sortArrowGrid
移动到 child 的前面? .toFront()
只是用于 z 顺序吗?
Node arrow = tableColumnHeader.lookup(".arrow");
if (arrow != null) {
GridPane sortArrowGrid = (GridPane) arrow.getParent();
// TODO: Move the sortArrowGrid to the front of the tableColumnHeader's children
}
我觉得我可能做错了——我很乐意用 CSS 来做。
最佳答案
对我的评论进行一些扩展(使用一些代码):如前所述,排序指示器的对齐方式(或 fx-speak:内容显示)是不可配置的,既不是样式也不是列/标题的任何属性 -相反,它被硬编码在 header 的布局代码中。
意味着我们需要实现一个支持可配置显示的自定义columnHeader。肉在一个自定义的 TableColumnHeader 中,它有:
sortIconDisplayProperty()
用于配置排序指示器的相对位置layoutChildren()
按照配置放置标签和排序指示符要使用,我们需要自定义 TableViewSkin、TableHeaderRow、NestedTableColumnHeader 的整个堆栈:所有这些都只是样板,用于在其相关工厂方法中创建和返回自定义 xx 实例。
下面是一个粗略的示例(阅读:布局不完美,应该有一些填充并保证不与文本重叠......但是,核心不是那么擅长,也不是)支持设置文本左侧的图标。为了获得完整的支持,您可能需要将其设置在顶部/底部……我现在太懒了;)
/**
* https://stackoverflow.com/q/49121560/203657
* position sort indicator at leading edge of column header
*
* @author Jeanette Winzenburg, Berlin
*/
public class TableHeaderLeadingSortArrow extends Application {
/**
* Custom TableColumnHeader that lays out the sort icon at its leading edge.
*/
public static class MyTableColumnHeader extends TableColumnHeader {
public MyTableColumnHeader(TableColumnBase column) {
super(column);
}
@Override
protected void layoutChildren() {
// call super to ensure that all children are created and installed
super.layoutChildren();
Node sortArrow = getSortArrow();
// no sort indicator, nothing to do
if (sortArrow == null || !sortArrow.isVisible()) return;
if (getSortIconDisplay() == ContentDisplay.RIGHT) return;
// re-arrange label and sort indicator
double sortWidth = sortArrow.prefWidth(-1);
double headerWidth = snapSizeX(getWidth()) - (snappedLeftInset() + snappedRightInset());
double headerHeight = getHeight() - (snappedTopInset() + snappedBottomInset());
// position sort indicator at leading edge
sortArrow.resize(sortWidth, sortArrow.prefHeight(-1));
positionInArea(sortArrow, snappedLeftInset(), snappedTopInset(),
sortWidth, headerHeight, 0, HPos.CENTER, VPos.CENTER);
// resize label to fill remaining space
getLabel().resizeRelocate(sortWidth, 0, headerWidth - sortWidth, getHeight());
}
// --------------- make sort icon location styleable
// use StyleablePropertyFactory to simplify styling-related code
private static final StyleablePropertyFactory<MyTableColumnHeader> FACTORY =
new StyleablePropertyFactory<>(TableColumnHeader.getClassCssMetaData());
// default value (strictly speaking: an implementation detail)
// PENDING: what about RtoL orientation? Is it handled correctly in
// core?
private static final ContentDisplay DEFAULT_SORT_ICON_DISPLAY = ContentDisplay.RIGHT;
private static CssMetaData<MyTableColumnHeader, ContentDisplay> CSS_SORT_ICON_DISPLAY =
FACTORY.createEnumCssMetaData(ContentDisplay.class,
"-fx-sort-icon-display",
header -> header.sortIconDisplayProperty(),
DEFAULT_SORT_ICON_DISPLAY);
// property with lazy instantiation
private StyleableObjectProperty<ContentDisplay> sortIconDisplay;
protected StyleableObjectProperty<ContentDisplay> sortIconDisplayProperty() {
if (sortIconDisplay == null) {
sortIconDisplay = new SimpleStyleableObjectProperty<>(
CSS_SORT_ICON_DISPLAY, this, "sortIconDisplay",
DEFAULT_SORT_ICON_DISPLAY);
}
return sortIconDisplay;
}
protected ContentDisplay getSortIconDisplay() {
return sortIconDisplay != null ? sortIconDisplay.get()
: DEFAULT_SORT_ICON_DISPLAY;
}
protected void setSortIconDisplay(ContentDisplay display) {
sortIconDisplayProperty().set(display);
}
/**
* Returnst the CssMetaData associated with this class, which may
* include the CssMetaData of its superclasses.
*
* @return the CssMetaData associated with this class, which may include
* the CssMetaData of its superclasses
*/
public static List<CssMetaData<? extends Styleable, ?>> getClassCssMetaData() {
return FACTORY.getCssMetaData();
}
/** {@inheritDoc} */
@Override
public List<CssMetaData<? extends Styleable, ?>> getCssMetaData() {
return getClassCssMetaData();
}
//-------- reflection acrobatics .. might use lookup and/or keeping aliases around
private Node getSortArrow() {
return (Node) FXUtils.invokeGetFieldValue(TableColumnHeader.class, this, "sortArrow");
}
private Label getLabel() {
return (Label) FXUtils.invokeGetFieldValue(TableColumnHeader.class, this, "label");
}
}
private Parent createContent() {
// instantiate the tableView with the custom default skin
TableView<Locale> table = new TableView<>(FXCollections.observableArrayList(
Locale.getAvailableLocales())) {
@Override
protected Skin<?> createDefaultSkin() {
return new MyTableViewSkin<>(this);
}
};
TableColumn<Locale, String> countryCode = new TableColumn<>("CountryCode");
countryCode.setCellValueFactory(new PropertyValueFactory<>("country"));
TableColumn<Locale, String> language = new TableColumn<>("Language");
language.setCellValueFactory(new PropertyValueFactory<>("language"));
TableColumn<Locale, String> variant = new TableColumn<>("Variant");
variant.setCellValueFactory(new PropertyValueFactory<>("variant"));
table.getColumns().addAll(countryCode, language, variant);
BorderPane pane = new BorderPane(table);
return pane;
}
/**
* Custom nested columnHeader, headerRow und skin only needed to
* inject the custom columnHeader in their factory methods.
*/
public static class MyNestedTableColumnHeader extends NestedTableColumnHeader {
public MyNestedTableColumnHeader(TableColumnBase column) {
super(column);
}
@Override
protected TableColumnHeader createTableColumnHeader(
TableColumnBase col) {
return col == null || col.getColumns().isEmpty() || col == getTableColumn() ?
new MyTableColumnHeader(col) :
new MyNestedTableColumnHeader(col);
}
}
public static class MyTableHeaderRow extends TableHeaderRow {
public MyTableHeaderRow(TableViewSkinBase tableSkin) {
super(tableSkin);
}
@Override
protected NestedTableColumnHeader createRootHeader() {
return new MyNestedTableColumnHeader(null);
}
}
public static class MyTableViewSkin<T> extends TableViewSkin<T> {
public MyTableViewSkin(TableView<T> table) {
super(table);
}
@Override
protected TableHeaderRow createTableHeaderRow() {
return new MyTableHeaderRow(this);
}
}
@Override
public void start(Stage stage) throws Exception {
stage.setScene(new Scene(createContent()));
URL uri = getClass().getResource("columnheader.css");
stage.getScene().getStylesheets().add(uri.toExternalForm());
stage.setTitle(FXUtils.version());
stage.show();
}
public static void main(String[] args) {
launch(args);
}
@SuppressWarnings("unused")
private static final Logger LOG = Logger
.getLogger(TableHeaderLeadingSortArrow.class.getName());
}
要配置的 columnheader.css:
.column-header {
-fx-sort-icon-display: LEFT;
}
版本说明:
该示例是针对 fx9 编码的——这将 Skins 与一系列其他更改一起移至公共(public)范围。让它与 fx8 一起工作
getTableViewSkin()
- 或类似的 - 具有 protected 范围,因此是子类可访问)关于javafx - 如何设置 TableColumn 的排序箭头对齐方式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49121560/
String[] titles = {"System Code","Domain Name","Organizational Unit","Organization Name"}; f
我在填充 javafx tableview 时遇到问题。 我目前正在开发基于 GUI 的事件管理工具(适用于大学),但我一直在尝试填充 Tableview 列表,该列表应该位于边框 Pane 布局的中
当我在 JavaFX 中生成表格时,列太大,我想在它出现在我的应用程序上时调整它们的大小以减少它们。我读了 stackOverflow 上的那些文章,这些文章很有用,但对我没有帮助:javafx co
我有一个账单表,我想在其中列出账单上的所有产品。我保存了ProductInBill ArrayList 内的对象在账单上。 当我创建TableView时我的常用方法是创建 JavaFX 字段。在 Co
我正在尝试使用 javaFX Scene builder 获取可编辑表的值,但无法获取更新的值。 我的表有 2 列:名称列和值列。每当用户更改 value 列的值时,我想使用react。 但是当我打印
我正在使用 JavaFX 制作表格。每行都有文字。一行有一个图形,因为该单元格的文本有多种颜色。 该代码仅在特定条件为真时才适用(该部分有效): departTimeCol.setCellFactor
我有一个包含三列的表,我想确保列的总宽度等于表的宽度,因此我使用 CONSTRAINED_RESIZE_POLICY。 我希望列以我指定的宽度开始,但用户可以修改。 如果我这样做: albumTabl
我正在制作一个使用表格 View 的程序。一切都很顺利,除了由于某种原因我无法将整数值填充到表中。下面是我在主程序中的代码,当我运行程序时,字符串和 double 会填充,但整数不会。在我的 Prod
我正在为我的 TableColumns 创建一个自定义标题,它是列的标签加上一个允许用户执行搜索的 TextField。我正在像这样设置列标题: getColumns().addListener(ne
我在调整包含环绕 TableCell 项目的文本项目的 TableView 大小时遇到问题。调整大小时,隐藏值会调整大小,但可见项不会重新计算文本换行。 红色框中的推文在调整大小时被隐藏,并按预期
要点 在 JavaFX TableColumn 中,右侧有一个排序箭头。 如何设置此箭头的对齐方式? 我的用例 我问是因为我正在尝试申请 Material Design到 JavaFX 并且箭头需要在
在 OpenJFX 11.0.2 & 12.0.1 SDK (Windows 10, x64) 中复制,不能在 JavaFX 8 中复制 右键单击表列,然后尝试调整列的大小。不会显示调整大小光标,并且
这是我的问题: 为 TableColumn 的默认排序设置自定义排序算法。 背景:作为示例列,我想使用将 IPv4 地址表示为 String 的列。因此默认排序是字典顺序(1.1.1.1、1.1.1.
有没有办法阻止用户调整TableView中的任何或至少所有JavaFX TableColumn的大小,同时仍然允许调整大小策略起作用? 存在 TableColumn::setResizing,但在阻止
我正在替换表列的 javafx 上下文菜单。上下文菜单将使用户能够访问 excel,例如表格 View 的过滤。一切正常,但我现在不想在列标题上的任何鼠标单击事件上打开上下文菜单。不仅仅是标准的右键单
以下场景:下表/列中有一些行具有长字符串值。我想出了如何通过手动调用“setCellFactory”并将“text.wrappingWidthProperty()”绑定(bind)到列的宽度来解决包装
我有追随者 http://code.makery.ch/library/javafx-8-tutorial/part2/并且在 TableColumn 中有一个使用 lambdas 的代码设置值: f
有人可以解释我的代码有什么问题吗? 我想创建一个简单的 swt 表。 Eclipse 注意到 TableColumn 是未定义的: TableColumn column = new Table
private float[] cwidth = { 0.1f, 0.3f, 0.3f, 0.2f, 0.1f }; setAutoResizeMode(JTable.AUTO_RESIZE_OFF)
我正在 Gluon Scene Builder 中构建一个 TableView。我想为每列中的单元格设置不同的背景颜色。我能否仅通过 FXML 文件和 CSS 来完成此操作? 使用 CSS 样式类 .
我是一名优秀的程序员,十分优秀!