一个拆分窗格的分隔符的单独 css 规则



>我在 css 文件中有以下 css 类

.split-pane > .split-pane-divider {  
    -fx-background-insets: 0;
    -fx-padding: 0 0 0 0;  
    -fx-background-color: red;
}

我有一个带有两个分隔符的 splitPane,我将这些分隔符引用为 Node(!我的意思是

Node leftDivider;
Node rightDivider;

我以这种方式引用它们

List<Node> nodes=getDividerNodes(splitPane);
leftDivider=nodes.get(0);
rightDivider=nodes.get(1);
...
public static List<Node> getDividerNodes(SplitPane splitPane){
    Map<Double,Node> sortedMap=new TreeMap<>();
    if (splitPane.getOrientation()==Orientation.HORIZONTAL){
        splitPane.lookupAll(".split-pane-divider").stream().forEach(div ->  {
            if (div.getParent()==splitPane){
                sortedMap.put(div.getLayoutX(), div);
            }
        });
    }else{
        splitPane.lookupAll(".split-pane-divider").stream().forEach(div ->  {
            if (div.getParent()==splitPane){
                sortedMap.put(div.getLayoutY(), div);
            }
        });
    }
    return new ArrayList<>(sortedMap.values());
}

现在我不想显示 leftDivider,但不显示 rightDivider。我愿意

leftDivider.setStyle("-fx-padding: 0 5 0 0;");

但是,我看到了两个分隔线 - 左和右。此外,如果我只想看到右分隔线,我这样做

rightDivider.setStyle("-fx-padding: 0 5 0 0;");

我没有看到任何分隔线。

在我看来,在一个 splitPane 内单独控制分隔线是不可能的。如果我错了,请说我怎么能只显示两个分隔线中的一个?

看起来像一个错误。具体而言,SplitPaneSkin类包含以下方法:

private void layoutDividersAndContent(double width, double height) {
    final double paddingX = snappedLeftInset();
    final double paddingY = snappedTopInset();
    final double dividerWidth = contentDividers.isEmpty() ? 0 : contentDividers.get(0).prefWidth(-1);
    for (Content c: contentRegions) {
//        System.out.println("LAYOUT " + c.getId() + " PANELS X " + c.getX() + " Y " + c.getY() + " W " + (horizontal ? c.getArea() : width) + " H " + (horizontal ? height : c.getArea()));
        if (horizontal) {
            c.setClipSize(c.getArea(), height);
            layoutInArea(c, c.getX() + paddingX, c.getY() + paddingY, c.getArea(), height,
                0/*baseline*/,HPos.CENTER, VPos.CENTER);
        } else {
            c.setClipSize(width, c.getArea());
            layoutInArea(c, c.getX() + paddingX, c.getY() + paddingY, width, c.getArea(),
                0/*baseline*/,HPos.CENTER, VPos.CENTER);
        }
    }
    for (ContentDivider c: contentDividers) {
//        System.out.println("LAYOUT DIVIDERS X " + c.getX() + " Y " + c.getY() + " W " + (horizontal ? dividerWidth : width) + " H " + (horizontal ? height : dividerWidth));
        if (horizontal) {
            c.resize(dividerWidth, height);
            positionInArea(c, c.getX() + paddingX, c.getY() + paddingY, dividerWidth, height,
                /*baseline ignored*/0, HPos.CENTER, VPos.CENTER);
        } else {
            c.resize(width, dividerWidth);                
            positionInArea(c, c.getX() + paddingX, c.getY() + paddingY, width, dividerWidth,
                /*baseline ignored*/0, HPos.CENTER, VPos.CENTER);
        }
    }
}

如您所见,dividerWidth是针对单个分隔线计算的,并且在所有分隔线的布局中使用相同的值。因此,所有分隔器的大小都相同,无论它们各自的样式如何。

建议您搜索以查看是否已报告(我进行了快速搜索,没有找到任何内容(,如果没有,请报告。

最新更新