如何在使用鼠标拖动调整选项卡窗格时调整组件大小

时间:2013-06-30 18:46:02

标签: javafx-2 javafx javafx-8

我已经实现了位于中心的标签窗格的非常简单的鼠标拖动。鼠标调整大小是非常基本的,它不能很好地工作但是现在我可以拖动选项卡的边框并增加大小。

enter image description here

现在我发现了一个问题。当我调整位于中心的标签大小时,位于中心旁边的组件不会按照用户的预期自动推回和尖叫,它们会放在我调整大小的组件后面。当我用鼠标拖动扩展主要组件时,我可以以某种方式设置所有组件被推回吗?

2 个答案:

答案 0 :(得分:6)

与其他人一样,我建议使用SplitPane类来为您分割屏幕。这是拆分窗格的示例(基于您的屏幕截图)。如果你不喜欢分隔栏的显示,你可以修改CSS以满足你的需要。

Screenshot of sample code

import javafx.application.Application;
import javafx.geometry.Orientation;
import javafx.scene.Node;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.scene.control.SplitPane;
import javafx.scene.control.Tab;
import javafx.scene.control.TabPane;
import javafx.scene.control.TextArea;
import javafx.scene.layout.BorderPane;
import javafx.stage.Stage;


public class FXSplitTabs extends Application{

    @Override
    public void start(Stage stage) throws Exception {
        stage.setTitle("SplitTabs");
        stage.setWidth(700);
        stage.setHeight(500);

        //Setup Center and Right
        TabPaneWrapper wrapper = new TabPaneWrapper(Orientation.HORIZONTAL, .9);
        TabPane centerPane = new TabPane();
        centerPane.getTabs().addAll(generateTab("Tab 1"),generateTab("Tab 2"), generateTab("Tab 3"), generateTab("Tab N"));

        TabPane rightPane = new TabPane();
        rightPane.getTabs().addAll(generateTab("Tab 1"),generateTab("Tab 2"), generateTab("Tab 3"), generateTab("Tab N"));
        SplitPane.setResizableWithParent(rightPane, false);
        wrapper.addNodes(centerPane, rightPane);

        //Add bottom
        TabPane bottomPane = new TabPane();
        bottomPane.getTabs().addAll(generateTab("Tab 1"),generateTab("Tab 2"), generateTab("Tab 3"), generateTab("Tab N"));
        TabPaneWrapper wrapperBottom = new TabPaneWrapper(Orientation.VERTICAL, .7);
        wrapperBottom.addNodes(wrapper.getNode(), bottomPane);

        //Add left
        TabPane leftPane = new TabPane();
        leftPane.getTabs().addAll(generateTab("Tab 1"),generateTab("Tab 2"), generateTab("Tab 3"), generateTab("Tab N"));
        TabPaneWrapper wrapperleft = new TabPaneWrapper(Orientation.HORIZONTAL, .1);
        wrapperleft.addNodes(leftPane, wrapperBottom.getNode());

        Scene myScene = new Scene(wrapperleft.getNode());
        stage.setScene(myScene);
        stage.sizeToScene();
        stage.show();
    }

    public Tab generateTab(String name){
        Tab result = new Tab(name);
        BorderPane content = new BorderPane();
        TextArea text = new TextArea();
        content.setCenter(text);
        result.setContent(content);
        return result;
    }

    public static void main(String[] args){
        FXSplitTabs.launch(args);
    }

    public static class TabPaneWrapper{
        SplitPane split;

        public TabPaneWrapper(Orientation o, double splitLocation){
            split = new SplitPane();

            //Change the CSS (uncomment if using an external css)
            //split.getStylesheets().add("test.css");

            split.setOrientation(o);
            split.setDividerPosition(0, splitLocation);
        }

        public void addNodes(final Node node1, final Node node2){
            //Add to the split pane
            split.getItems().addAll(node1, node2);
        }

        public Parent getNode(){
            return split;
        }
    }

}

如果您想使用CSS来改变分隔符的外观,请取消注释上面的CSS代码行,在基础包中创建一个文件test.css,然后插入css规范(这里是一个转换为分隔线透明):

.split-pane-divider {
   -fx-border-color: transparent;
   -fx-background-color: transparent;
}

答案 1 :(得分:3)

作为替代解决方案:

我发布了Drombler FX的第一个Early Access版本,这是一个基于OSGi和Maven的新的JavaFX富客户端平台。

它还带有Docking Framework的初始版本,这似乎是您正在寻找的东西。

您可以在此处详细了解Drombler FX:http://puces-blog.blogspot.ch/2012/12/drombler-fx-building-modular-javafx.html