当我有透明的SplitPane时,设置pickOnBounds = false不起作用,我无法点击splitpane后面的按钮。 我有一个带有透明VBox的splitPane,其中pickOnBounds = false 我还使用pickOnBounds = false设置splitpane,但是鼠标单击不会直到它们下面的按钮。
我的顶部有一个部分被SplitPane覆盖的按钮, 底部有按钮可打开/关闭mousetransparency和pickOnBounds。
启用MouseTransparency'没有检查, 和'启用选择界限'未经检查,那么您应该可以点击SplitPane后面的按钮,但是你不能。image of app
可能是Splitpane的skinclass没有继承pickOnBounds设置???
以下是说明问题的示例代码:
package splitpaneprob;
import javafx.application.Application;
import javafx.beans.binding.Bindings;
import javafx.geometry.Orientation;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.CheckBox;
import javafx.scene.control.SplitPane;
import javafx.scene.control.ToggleButton;
import javafx.scene.layout.StackPane;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
// Demonstrates the JavaFX node mouseTransparent and pickOnBounds properties.
// shows that 'PickOnBounds=false' does not work for a SplitPane that has a transparent background and you want mouseclicks to go thru
public class PickOnBoundsFails extends Application {
public static void main(String[] args) {
launch(args);
}
@Override
public void start(Stage stage) throws Exception {
ToggleButton testButton = new ToggleButton("");
VBox layer1 = new VBox();
layer1.getChildren().add(testButton);
SplitPane layer3 = new SplitPane();
layer3.setMaxWidth(140);
layer3.setOrientation(Orientation.VERTICAL);
layer3.setStyle("-fx-background-color:transparent;-fx-border-color:teal");
layer3.setPrefWidth(120);
VBox topItem = new VBox();
topItem.setPickOnBounds(false);
topItem.setPrefHeight(100);
topItem.setAlignment(Pos.BOTTOM_LEFT);
Button topButton = new Button();
topButton.setMouseTransparent(false);
topItem.getChildren().add(topButton);
VBox bottomItem = new VBox();
Button bottomButton = new Button("click me");
bottomItem.getChildren().add(bottomButton);
layer3.getItems().add(topItem);
layer3.getItems().add(bottomItem);
StackPane stack = new StackPane();
stack.getChildren().setAll(layer1, layer3);
stack.setStyle("-fx-background-color: azure;");
VBox layout = new VBox();
layout.getChildren().setAll(
stack,
createControls(testButton, layer3, topButton)
);
stage.setScene(new Scene(layout));
stage.show();
}
private VBox createControls(ToggleButton controlledButton, SplitPane controlledNode, Button buttonOnSplitPane) {
controlledButton.textProperty().bind(
Bindings
.when(controlledNode.mouseTransparentProperty()).then("Completely Clickable")
.otherwise(Bindings
.when(controlledNode.pickOnBoundsProperty()).then("Partially clickable")
.otherwise("Should Be fully Clickable")
)
);
buttonOnSplitPane.textProperty().bind(
Bindings
.when(controlledNode.mouseTransparentProperty()).then("NOT Clickable")
.otherwise("Clickable")
);
CheckBox enableMouseTransparency = new CheckBox("Enable MouseTransparency on ScrollPane");
enableMouseTransparency.setSelected(controlledNode.isMouseTransparent());
controlledNode.mouseTransparentProperty().bind(enableMouseTransparency.selectedProperty());
CheckBox enablePickOnBounds = new CheckBox("Enable Pick On Bounds on ScrollPane");
enablePickOnBounds.setSelected(controlledNode.isPickOnBounds());
controlledNode.pickOnBoundsProperty().bind(enablePickOnBounds.selectedProperty());
VBox controls = new VBox(10);
controls.setStyle("-fx-background-color: cornsilk; -fx-padding: 10;");
controls.getChildren().addAll(
enableMouseTransparency,
enablePickOnBounds
);
return controls;
}
}
答案 0 :(得分:0)
我知道我已经晚了 5 年,但我只是在同一个问题上花了一个上午。
我认为真正的问题是 -fx-background-color:transparent;
,如果您删除它,那么您应该拥有所需的行为。