0

运行实例化此类的代码时:

static final class MyFrame extends JFrame {
    private CardLayout layout = new CardLayout();

    public MyFrame() {
        setLayout(layout);
        System.out.println(getLayout());
    }
}

打印的结果是:

java.awt.BorderLayout[hgap=0,vgap=0]

这是JFrame默认布局。布局没有改变。但是,如果我改变

setLayout(layout);

getContentPane().setLayout(layout)

getLayout()将打印正确的布局。

MVCE:

不设置布局:

public class Main {
    public static void main(String[] args) {
        EventQueue.invokeLater(() -> {
            MyFrame frame = new MyFrame();
            frame.setVisible(true);
        });
    }

    static final class MyFrame extends JFrame {
        private CardLayout layout = new CardLayout();

        public MyFrame() {
            setLayout(layout);
            System.out.println(getLayout());
        }
    }
}

设置布局:

public class Main {
    public static void main(String[] args) {
        EventQueue.invokeLater(() -> {
            MyFrame frame = new MyFrame();
            frame.setVisible(true);
        });
    }

    static final class MyFrame extends JFrame {
        private CardLayout layout = new CardLayout();

        public MyFrame() {
            getContentPane().setLayout(layout);
            System.out.println(getLayout());
        }
    }
}
4

1 回答 1

5

我认为你在某处遗漏了一些东西。这是我的电脑上使用

setLayout(layout);
System.out.println(getContentPane().getLayout()); // CardLayout is printed
System.out.println(getLayout()); // BorderLayout is printed

getContentPane().setLayout(layout);
System.out.println(getContentPane().getLayout()); // CardLayout is printed
System.out.println(getLayout()); // BorderLayout is printed

为什么不总是打印 CardLayout?

因为,与 不同JFrame#setLayout(LayoutManager)JFrame#getLayout()不会调用它的contentPane().

事实上,JFrame#getLayout()实际上是从 which 继承的Container#getLayout(),将从实际组件返回实际值LayoutManager(在这种情况下JFrame,而不是它的contentPane())。


JFrame#setLayout

设置布局管理器。被覆盖以有条件地将调用转发到 contentPane。有关详细信息,请参阅 RootPaneContainer。

于 2015-12-04T13:03:43.277 回答