JavaFX - Dock效果模态框

效果

类似DOCK, 在主界面的右方弹出/收回,或者显示/隐藏
这里写图片描述


思路
  • 新创建一个dock_stage
  • dock_stage的模态类型为NONE或者WINDOW_MODAL(否则会挡住主stage)
  • 在主stage的scene的x、y属性增加监听器
  • 监听器动作是更新dock_stage的X和Y坐标

不足
  • 移动主stage时,dock_stage有非常轻微的脱离感,或许有其他更好的方法?比如bind? 欢迎高手指点哈!


实现代码
// MainScene.fxml用于主舞台
// Dock_console.fxml用于子舞台

public class MainScene extends Application {

    private static Stage mainStage;
    private static Scene mainScene;
    private static Stage dockStage;

    private static DoubleProperty docker_X;
    private static DoubleProperty docker_Y;

    @Override
    public void start(Stage primaryStage) throws Exception {
        mainStage = primaryStage;
        final Parent root = FXMLLoader.load(getClass().getResource("MainScene.fxml"));
        mainScene = new Scene(root);
        mainStage.initStyle(StageStyle.DECORATED);
        mainStage.setScene(mainScene);
        mainStage.setTitle("NTT");
        mainStage.show();

        // 获取主stage的位置
        docker_X = new SimpleDoubleProperty( (mainScene.getWindow().getX() + 
        mainScene.getWidth())+2.0);
        docker_Y = new SimpleDoubleProperty(mainScene.getWindow().getY());
        // 绑定位置, DOCK跟随主stage
        mainScene.getWindow().xProperty().addListener(
        (ObservableValue<? extends Number> observable, 
        Number oldValue, Number newValue) -> {
            docker_X.set(docker_X.getValue() + newValue.doubleValue() - 
            oldValue.doubleValue());
            dockStage.setX(docker_X.getValue());
        });
        mainScene.getWindow().yProperty().addListener(
        (ObservableValue<? extends Number> observable, 
        Number oldValue, Number newValue) -> {
            docker_Y.set(docker_Y.getValue() + newValue.doubleValue() - 
            oldValue.doubleValue());
            dockStage.setY(docker_Y.getValue());
        });
    }

    @FXML
    void showOrClose() {

        if (dockStage != null && dockStage.isShowing()) {
            dockStage.close();
            return;
        }

        Parent root = null;
        try {
            root = FXMLLoader.load(getClass().getResource("Dock_console.fxml"));
            final Scene scene = new Scene(root);
            dockStage = new Stage();
            dockStage.initStyle(StageStyle.DECORATED);
            dockStage.initModality(Modality.NONE);  // 重要!

            dockStage.setX(docker_X.getValue());
            dockStage.setY(docker_Y.getValue());
            dockStage.setScene(scene);
            dockStage.setTitle("console");
            dockStage.show();

        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

友情提示 : 转摘请注明出处 , 谢谢!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaFX-Support是一个开源项目,致力于为JavaFX提供友好的支持和工具。JavaFX是一个用于构建丰富用户界面的Java库,而JavaFX-Support项目旨在为开发人员提供便利和增强功能,以提高他们在开发JavaFX应用程序时的效率和体验。 JavaFX-Support项目具有以下特点和功能: 1.样式编辑器:JavaFX-Support项目提供了一个样式编辑器,使开发人员能够轻松编辑和定制JavaFX应用程序的视觉样式。通过这个编辑器,开发人员可以直观地调整应用程序的颜色、字体和其他视觉元素,而无需手动编写代码。 2.视觉组件库:JavaFX-Support项目还包含了一个丰富的视觉组件库,开发人员可以直接在应用程序中使用这些组件,而无需自己编写。这些组件可以帮助开发人员快速构建出现频率较高的界面元素,例如按钮、文本框、列表等。 3.布局助手:JavaFX-Support项目还提供了一个布局助手,用于在JavaFX应用程序中进行布局。开发人员可以方便地使用拖放方式调整和排列组件,从而更加灵活地设计界面。 4.调试工具:JavaFX-Support项目还包含了一些调试工具,用于帮助开发人员在开发过程中定位和修复问题。这些工具可以帮助开发人员追踪布局问题、排查异常和提高性能。 总的来说,JavaFX-Support项目是一个强大而实用的工具集,它使得开发人员可以更加便捷地开发和定制JavaFX应用程序。无论是初学者还是有经验的开发人员都可以从中受益,并提高他们在JavaFX开发中的效率和质量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值