gpt4 book ai didi

java - 在 JavaFX 中重新定位 Accordion 箭头

转载 作者:行者123 更新时间:2023-11-30 08:02:33 25 4
gpt4 key购买 nike

我想将一个 Accordion 控件嵌套在另一个控件中,虽然这按预期工作,但我想对其进行自定义,以便嵌套的 Accordion 箭头相对于顶层缩进。此链接显示当前情况:- The bottom level arrows need to move in 20px

我想不出在代码或 scenebuilder 中设置它的方法。但是,如果我在 scenicview 中打开正在运行的应用程序,它似乎会以不同的方式显示,我可以看到 TitledPane 组成为:TitleRegion>StackPane arrowRegion>StackPane 箭头。如果我向其中添加 fx-translateX 20.0,它就会执行我想要的操作。

code或者fxml有没有好的解决方案?或者我可以让 css 做 scenicview 可以做的事情吗(我也找不到 scenicview 的导出)。

我刚刚在 scenebuilder 中修改了 Netbeans 模板 JavaFX fxml 元素。使用 JAVA 1.8.0.92., nb8.0.2, latest sb +sv.我的 fxml 是:

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

<?import javafx.scene.control.Accordion?>
<?import javafx.scene.control.Label?>
<?import javafx.scene.control.TitledPane?>
<?import javafx.scene.layout.AnchorPane?>
<?import javafx.scene.text.Text?>

<AnchorPane id="AnchorPane" prefHeight="200" prefWidth="320" xmlns="http://javafx.com/javafx/8.0.65" xmlns:fx="http://javafx.com/fxml/1" fx:controller="accordianchildtitledpanearrrowcustom.FXMLDocumentController">
<children>
<Label fx:id="label" alignment="CENTER" contentDisplay="CENTER" layoutX="79.0" layoutY="14.0" minHeight="16" minWidth="69" text="Example nested accordian" />
<Accordion layoutY="38.0" prefHeight="54.0" prefWidth="320.0">
<panes>
<TitledPane alignment="CENTER" animated="false" text="Top Level 1">
<content>
<Accordion>
<panes>
<TitledPane alignment="CENTER" animated="false" text="Bottom Level 1">
<content>
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="example text 1" />
</content></TitledPane>
<TitledPane alignment="CENTER" animated="false" contentDisplay="CENTER" text="Bottom Level 2">
<content>
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="example text 2" />
</content></TitledPane>
</panes>
</Accordion>
</content>
</TitledPane>
<TitledPane alignment="CENTER" animated="false" text="Top Level 2" />
</panes>
</Accordion>
</children>
</AnchorPane>

最佳答案

在应用程序的 css 文件中,您可以添加以下行来翻译箭头按钮:

.accordion .title > .arrow-button .arrow{
-fx-translate-x: 20;
}

如果你只想翻译嵌套的TitledPanes的箭头按钮,你可以使用:

.titled-pane .accordion .title > .arrow-button .arrow{
-fx-translate-x: 20;
}

可以按如下方式添加样式表:

 scene.getStylesheets().add(getClass().getResource("/yourPackage/yourStyleSheet.css").toExternalForm());

关于java - 在 JavaFX 中重新定位 Accordion 箭头,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36902532/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com