- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想知道 JavaFX 是否包含一种使 Accordion 或标题 Pane 水平的方法。我找不到任何东西,但我想我应该问一下。本质上,最终目标是拥有一个可以展开以显示树状 View 的侧边栏。以下是我的意图图片:
Collapsed
Expanded
最佳答案
JavaFX 2.2 中没有标准的水平方向 TitledPane。
您可以为 JavaFX issue tracker 中的一个创建功能请求.
实现您自己的水平 TitledPane 非常简单。
这是一个 demo of a similar thing只是在标准 Pane 上使用动画。
Sai 的博客文章中对所涉及技术的进一步解释:Sliding in JavaFX (It’s all about clipping) .
/** Animates a node on and off screen to the left. */
class SideBar extends VBox {
/** @return a control button to hide and show the sidebar */
public Button getControlButton() { return controlButton; }
private final Button controlButton;
/** creates a sidebar containing a vertical alignment of the given nodes */
SideBar(final double expandedWidth, Node... nodes) {
getStyleClass().add("sidebar");
this.setPrefWidth(expandedWidth);
// create a bar to hide and show.
setAlignment(Pos.CENTER);
getChildren().addAll(nodes);
// create a button to hide and show the sidebar.
controlButton = new Button("Collapse");
controlButton.getStyleClass().add("hide-left");
// apply the animations when the button is pressed.
controlButton.setOnAction(new EventHandler<ActionEvent>() {
@Override public void handle(ActionEvent actionEvent) {
// create an animation to hide sidebar.
final Animation hideSidebar = new Transition() {
{ setCycleDuration(Duration.millis(250)); }
protected void interpolate(double frac) {
final double curWidth = expandedWidth * (1.0 - frac);
setPrefWidth(curWidth);
setTranslateX(-expandedWidth + curWidth);
}
};
hideSidebar.onFinishedProperty().set(new EventHandler<ActionEvent>() {
@Override public void handle(ActionEvent actionEvent) {
setVisible(false);
controlButton.setText("Show");
controlButton.getStyleClass().remove("hide-left");
controlButton.getStyleClass().add("show-right");
}
});
// create an animation to show a sidebar.
final Animation showSidebar = new Transition() {
{ setCycleDuration(Duration.millis(250)); }
protected void interpolate(double frac) {
final double curWidth = expandedWidth * frac;
setPrefWidth(curWidth);
setTranslateX(-expandedWidth + curWidth);
}
};
showSidebar.onFinishedProperty().set(new EventHandler<ActionEvent>() {
@Override public void handle(ActionEvent actionEvent) {
controlButton.setText("Collapse");
controlButton.getStyleClass().add("hide-left");
controlButton.getStyleClass().remove("show-right");
}
});
if (showSidebar.statusProperty().get() == Animation.Status.STOPPED && hideSidebar.statusProperty().get() == Animation.Status.STOPPED) {
if (isVisible()) {
hideSidebar.play();
} else {
setVisible(true);
showSidebar.play();
}
}
}
});
}
}
关于javafx-2 - 水平 JavaFX 标题 Pane ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17287445/
我正在尝试设置一个具有三个分割 Pane 的用户界面。前两个是垂直 Pane ,位于屏幕的左侧和右侧。每个拆分的一侧都有一个标题 Pane 。用户可以从这些 Pane 中选择项目以包含在中央 Pane
我经常使用 SQL Server Management Studio,并且始终使用以下 Pane 来处理数据:图表、条件和 SQL。 SQL Panes that I always use 目前,我每
可能是一个有点愚蠢的问题。问题很简单,我倾向于有两个 Pane ,一个用于编写代码,另一个用于编译它。我用 windows 终端 (cmd + vim + Mingw) 做到了这一点,但有些事情困扰着
我想出了如何使用 the Working with Map Panes tutorial 在自定义 Pane 中创建多边形和 this Stack Overflow question及其相关的 Fid
如何将输出连接到 paneWithList? PaneWithList 在其 JList 上有一个监听器,以便将所选行输出到控制台。如何将该输出定向到输出上的 JTextPane? PaneWithL
横向和纵向不同布局之间的方向变化似乎很容易,但是我找不到适合我当前情况的解决方案。 我想在横向模式下使用带有两个 fragment 的双 Pane 布局 res\layout-land\dashboa
我在Xcode中使用Swift编程时,当我想使用实用程序 Pane 编辑按钮时,我意识到它变成了“不适用”。属性检查器,连接检查器等全部变为“不适用”,仅快速帮助检查器仍显示。 我已选择 Storyb
我正在 JavaFX 中编写 vector Canvas ( vector 图形, Canvas 上仅显示形状):好吧,这样您就可以四处移动并放大它。 由于翻译时节点左上角的位置发生变化,并且不再响应
我有一个带有中心 Pane 的边框 Pane - VBox。VBox 包含一个 GridPane 和一个 VBox Pane 。 垂直框(垂直框内的垂直框)最初设置为不可见。 我想要做的是,如果将 G
我正在 JavaFX 中编写 vector Canvas ( vector 图形, Canvas 上仅显示形状):好吧,这样您就可以四处移动并放大它。 由于翻译时节点左上角的位置发生变化,并且不再响应
简单地说,我想让 java 做我想做的事情,但我无法理解布局管理中的任何其他自动调整大小到它感觉要做的事情。 我想要的是一个固定高度的“页脚”和顶部“主”区域,以根据窗口的高度自动调整大小。 水平方向
我尝试创建一个在堆栈 Pane 中包含 2 个 Pane 的应用程序。一个 Pane 是主 Pane 并居中,第二个 Pane 较小并停靠在舞台的左下角。 问题是我试过使用“setAlignment”
我已经在我的第一个 android 应用程序中实现了滑动 Pane 布局,但是当我滑动菜单时,操作栏仍然保持静态,我想实现像 Google+ 应用程序那样的东西 在 Stack Overflow 中也
我只是 Java 的初学者。这是我的问题: 我用这段代码创建了一个可滚动的文本字段(1): jZone_Text = new JTextPane(); scrollPane = new JScroll
我在左 Pane 中创建了一个文件夹,其中包含各种图像。它被称为“wikiImages”。如何访问此文件夹或获取此文件夹的路径? 我找到了 Bundle.main.resourcePath!,但这似乎
好吧,我是 JavaFx 的新手,而且我已经很长时间没有使用 Java 了,所以我遇到了很多问题。最大的问题是如何更改该死的 Pane 的背景。 下面是Controller类 //Styling pr
我正在使用 JavaFX 编写一个程序,其中我有 边框 Pane -> 中心 -> VBox -> 滚动 Pane -> 网格 Pane 我希望能够向网格 Pane 添加任意多的行,并让滚动 Pane
我已经尝试使这项工作 2 天了,并且阅读了许多示例和堆栈溢出问题。我是 html 和 css 的新手,这是我的第 3 天。对于我做错了什么的任何提示或见解,以及一般性评论或批评,我们将不胜感激。 我试
我有一个位于另一个 Pane 内的可拖动 Pane 。我想让子 Pane 只能在父 Pane 的边界内拖动,但默认情况下,子 Pane 可以拖动到任何地方。如何解决这个问题。 最佳答案 看看这个dem
我现在正在学习基本的 JavaFX,我不明白我正在阅读的书中的这句话:“不,像文本字段这样的节点只能添加到一个 Pane 中一次。添加一个节点多次或不同的 Pane 将导致运行时错误。”从书上提供的U
我是一名优秀的程序员,十分优秀!