javafx - 在 CSS 不起作用的情况下删除 JavaFX TitledPane 中的插图

标签 javafx javafx-8

基于我尝试过的 James_D ( How to set/remove insets in JavaFX TitledPane ) 的解决方案,似乎通过 CSS 从 JavaFX TitledPane 中删除插图不起作用?它确实在 Scene Builder 中正确更新,但在运行时插入保持不变。甚至 Scenic View 8.0 也报告了 9.6 的填充。

FXML 示例:

<?xml version="1.0" encoding="UTF-8"?>

<?import java.lang.*?>
<?import java.util.*?>
<?import javafx.scene.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>

<AnchorPane id="AnchorPane" prefHeight="200" prefWidth="320" stylesheets="@newCascadeStyleSheet.css" xmlns:fx="http://javafx.com/fxml/1" xmlns="http://javafx.com/javafx/8" fx:controller="test3.FXMLDocumentController">
    <children>
      <Accordion layoutX="14.0" layoutY="14.0" prefHeight="270.0" prefWidth="320.0" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
        <panes>
          <TitledPane animated="false" text="untitled 1">
            <content>
              <AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="180.0" prefWidth="200.0">
                     <children>
                          <Button fx:id="button" layoutX="9.600000381469727" layoutY="9.600000381469727" prefHeight="124.0" prefWidth="318.0" text="Click Me!" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0" />
                     </children>
                  </AnchorPane>
            </content>
              </TitledPane>
              <TitledPane animated="false" text="untitled 2">
            <content>
              <AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="180.0" prefWidth="200.0" />
            </content>
          </TitledPane>
          <TitledPane animated="false" text="untitled 3">
            <content>
              <AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="180.0" prefWidth="200.0" />
            </content>
          </TitledPane>
        </panes>
      </Accordion>
    </children>
</AnchorPane>

CSS:
.titled-pane {
    -fx-text-fill: rgb(0,100,157);
}
.titled-pane:focused {
    -fx-color: -fx-base;
    -fx-text-fill: white;
}
.titled-pane > .title {
    -fx-text-fill: rgb(0,100,157);
    -fx-font-weight: bold;
}
titled-pane > .title  > .label{
    -fx-text-fill: rgb(0,100,157);
    -fx-font-weight: bold;
}
.titled-pane:focused > .title {
    -fx-color: rgb(0,100,157); 
    -fx-text-fill: white;
}
.titled-pane > .title:hover {
    -fx-color: lightgrey;
}
.titled-pane > * > * > AnchorPane {
    -fx-padding: 0px ;
}

在场景生成器中查看:(预览)

preview in scene builder

运行时查看:

view at runtime

所以似乎由于某种原因没有应用填充。在我的主要应用程序中,我使用了很多 Accordion容器。另一种选择是将 FXML 代码中的填充添加到 AnchorPaneTitledPane ,这行得通,但是是一项耗时的工作。我在 CSS 中遗漏了什么吗?

最佳答案

设置 -fx-padding在以下样式类上设置为 0。

.titled-pane .content AnchorPane {
    -fx-padding: 0px;
}

关于javafx - 在 CSS 不起作用的情况下删除 JavaFX TitledPane 中的插图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29607725/

相关文章:

java - 线程 "main"java.lang.NoSuchMethodException : after I add ArrayList 中的异常

java - 从更新的 SQL 数据库刷新 JavaFX 场景?

java - 每当鼠标在场景上移动时如何使节点移动(在 JavaFX 中)?

java - NetBeans 错误显示在书籍 "Pro JavaFX 8: A Definitive Guide"初始化 FXML 文件中的对象中的示例代码中

java - 创建完全动态的 GUI

java - 如果从 JavaFX 中的结果集中找不到任何内容,则显示警报

java - TextFormatter 在绑定(bind)(双向)到空字符串时抛出异常

java - 如何修复 Kotlin 中的重载分辨率歧义(无 lambda)?

java - MenuItem 和图标图形 JavaFX 的大小调整和对齐

单击弹出窗口时,JavaFX 8 过滤的 ComboBox 抛出 IndexOutOfBoundsException