没有干净的方法可以做到这一点,但可以通过例如在SplitPane
.
由于分隔线具有 CSS 类,因此split-pane-divider
您可以从场景图中获取分隔线,它们实际上是StackPane
实例。
在这些上StackPane
,您可以注册一个鼠标按下和一个鼠标释放事件侦听器,并更新一个类成员,该成员指示当前分隔符“处于拖动状态”。然后在 position 属性监听器中可以检查这个类成员:如果为真,则表示分隔线正在被鼠标移动,否则可以忽略更改。
例子:
public class Main extends Application {
// Indicates that the divider is currently dragged by the mouse
private boolean mouseDragOnDivider = false;
@Override
public void start(Stage primaryStage) throws Exception{
SplitPane sp = new SplitPane();
sp.getItems().addAll(new StackPane(), new StackPane());
sp.setDividerPositions(0.3f);
// Listen to the position property
sp.getDividers().get(0).positionProperty().addListener((obs, oldVal, newVal) -> {
if(mouseDragOnDivider)
System.out.println("It's a mouse drag to pos: " + newVal.doubleValue());
});
primaryStage.setScene(new Scene(sp, 300, 275));
sp.requestLayout();
sp.applyCss();
// For each divider register a mouse pressed and a released listener
for(Node node: sp.lookupAll(".split-pane-divider")) {
node.setOnMousePressed(evMousePressed -> mouseDragOnDivider = true);
node.setOnMouseReleased(evMouseReleased -> mouseDragOnDivider = false );
}
primaryStage.show();
}
public static void main(String[] args) {
launch(args);
}
}
注意:
由于查找仅在创建布局并应用 CSS 时才有效,因此重要的是requestLayout()
和applyCss()
方法已经执行并且SplitPane
已经添加到场景图中(附加到 a Scene
)。